aboutsummaryrefslogtreecommitdiffstats
path: root/components
diff options
context:
space:
mode:
authorMátyás Mustoha <mmatyas@inf.u-szeged.hu>2015-04-21 14:22:06 +0200
committerMátyás Mustoha <mmatyas@inf.u-szeged.hu>2015-04-21 15:21:30 +0200
commit5287cb7fba468b1c4c29e7a23951d0e8def56e8f (patch)
treed8d2f774cffc32b4a493a9cdd33856e9692310c2 /components
parente4b620ea54c94e03095e4108bce94ec750416bba (diff)
downloadservo-5287cb7fba468b1c4c29e7a23951d0e8def56e8f.tar.gz
servo-5287cb7fba468b1c4c29e7a23951d0e8def56e8f.zip
Canvas: implement rectangle drawing.
Diffstat (limited to 'components')
-rw-r--r--components/canvas/canvas_msg.rs1
-rw-r--r--components/canvas/canvas_paint_task.rs10
-rw-r--r--components/script/dom/canvasrenderingcontext2d.rs9
-rw-r--r--components/script/dom/webidls/CanvasRenderingContext2D.webidl2
4 files changed, 21 insertions, 1 deletions
diff --git a/components/canvas/canvas_msg.rs b/components/canvas/canvas_msg.rs
index 3d21da3ae0a..86e1dcc6f81 100644
--- a/components/canvas/canvas_msg.rs
+++ b/components/canvas/canvas_msg.rs
@@ -33,6 +33,7 @@ pub enum Canvas2dMsg {
MoveTo(Point2D<f32>),
PutImageData(Vec<u8>, Rect<f64>, Option<Rect<f64>>),
QuadraticCurveTo(Point2D<f32>, Point2D<f32>),
+ Rect(Rect<f32>),
RestoreContext,
SaveContext,
StrokeRect(Rect<f32>),
diff --git a/components/canvas/canvas_paint_task.rs b/components/canvas/canvas_paint_task.rs
index bbce09cea23..2eceb25331f 100644
--- a/components/canvas/canvas_paint_task.rs
+++ b/components/canvas/canvas_paint_task.rs
@@ -220,6 +220,7 @@ impl<'a> CanvasPaintTask<'a> {
}
Canvas2dMsg::MoveTo(ref point) => painter.move_to(point),
Canvas2dMsg::LineTo(ref point) => painter.line_to(point),
+ Canvas2dMsg::Rect(ref rect) => painter.rect(rect),
Canvas2dMsg::QuadraticCurveTo(ref cp, ref pt) => {
painter.quadratic_curve_to(cp, pt)
}
@@ -351,6 +352,15 @@ impl<'a> CanvasPaintTask<'a> {
self.path_builder.line_to(*point)
}
+ fn rect(&self, rect: &Rect<f32>) {
+ self.path_builder.move_to(Point2D(rect.origin.x, rect.origin.y));
+ self.path_builder.line_to(Point2D(rect.origin.x + rect.size.width, rect.origin.y));
+ self.path_builder.line_to(Point2D(rect.origin.x + rect.size.width,
+ rect.origin.y + rect.size.height));
+ self.path_builder.line_to(Point2D(rect.origin.x, rect.origin.y + rect.size.height));
+ self.path_builder.close();
+ }
+
fn quadratic_curve_to(&self,
cp: &Point2D<AzFloat>,
endpoint: &Point2D<AzFloat>) {
diff --git a/components/script/dom/canvasrenderingcontext2d.rs b/components/script/dom/canvasrenderingcontext2d.rs
index f21d23cd073..5c89b58f276 100644
--- a/components/script/dom/canvasrenderingcontext2d.rs
+++ b/components/script/dom/canvasrenderingcontext2d.rs
@@ -640,6 +640,15 @@ impl<'a> CanvasRenderingContext2DMethods for JSRef<'a, CanvasRenderingContext2D>
self.renderer.send(CanvasMsg::Canvas2d(Canvas2dMsg::LineTo(Point2D(x as f32, y as f32)))).unwrap();
}
+ // https://html.spec.whatwg.org/multipage/#dom-context-2d-rect
+ fn Rect(self, x: f64, y: f64, width: f64, height: f64) {
+ if [x, y, width, height].iter().all(|val| val.is_finite()) {
+ let rect = Rect(Point2D(x as f32, y as f32),
+ Size2D(width as f32, height as f32));
+ self.renderer.send(CanvasMsg::Canvas2d(Canvas2dMsg::Rect(rect))).unwrap();
+ }
+ }
+
// https://html.spec.whatwg.org/multipage/#dom-context-2d-quadraticcurveto
fn QuadraticCurveTo(self, cpx: f64, cpy: f64, x: f64, y: f64) {
if !(cpx.is_finite() && cpy.is_finite() &&
diff --git a/components/script/dom/webidls/CanvasRenderingContext2D.webidl b/components/script/dom/webidls/CanvasRenderingContext2D.webidl
index e1d5416f13e..44f9c707600 100644
--- a/components/script/dom/webidls/CanvasRenderingContext2D.webidl
+++ b/components/script/dom/webidls/CanvasRenderingContext2D.webidl
@@ -171,7 +171,7 @@ interface CanvasPathMethods {
unrestricted double radius);
// NOT IMPLEMENTED [LenientFloat] void arcTo(double x1, double y1, double x2, double y2, double radiusX, double radiusY, double rotation);
- //void rect(double x, double y, double w, double h);
+ void rect(unrestricted double x, unrestricted double y, unrestricted double w, unrestricted double h);
[Throws]
void arc(double x, double y, double radius, double startAngle, double endAngle, optional boolean anticlockwise = false);