mirror of
https://github.com/servo/servo.git
synced 2025-06-17 12:54:28 +00:00
Merge pull request #2934 from saneyuki/canvas
Move CanvasRenderTask to gfx crate.
This commit is contained in:
commit
57aa3813b9
5 changed files with 86 additions and 74 deletions
|
@ -256,7 +256,7 @@ DONE_gfx = $(B)src/components/gfx/libgfx.dummy
|
||||||
|
|
||||||
DEPS_gfx = $(CRATE_gfx) $(SRC_gfx) $(DONE_SUBMODULES) $(DONE_util) $(DONE_style) $(DONE_net) $(DONE_msg) $(DONE_macros)
|
DEPS_gfx = $(CRATE_gfx) $(SRC_gfx) $(DONE_SUBMODULES) $(DONE_util) $(DONE_style) $(DONE_net) $(DONE_msg) $(DONE_macros)
|
||||||
|
|
||||||
RFLAGS_script = $(addprefix -L $(B)src/,$(DEPS_SUBMODULES)) -L $(B)src/components/util -L $(B)src/components/style -L $(B)src/components/net -L $(B)src/components/msg -L$(B)src/components/macros
|
RFLAGS_script = $(addprefix -L $(B)src/,$(DEPS_SUBMODULES)) -L $(B)src/components/util -L $(B)src/components/style -L $(B)src/components/net -L $(B)src/components/msg -L$(B)src/components/macros -L$(B)src/components/gfx
|
||||||
|
|
||||||
BINDINGS_SRC = $(S)src/components/script/dom/bindings/codegen
|
BINDINGS_SRC = $(S)src/components/script/dom/bindings/codegen
|
||||||
WEBIDLS_SRC = $(S)src/components/script/dom/webidls
|
WEBIDLS_SRC = $(S)src/components/script/dom/webidls
|
||||||
|
@ -269,7 +269,7 @@ SRC_script = $(call rwildcard,$(S)src/components/script/,*.rs) $(AUTOGEN_SRC_scr
|
||||||
CRATE_script = $(S)src/components/script/script.rs
|
CRATE_script = $(S)src/components/script/script.rs
|
||||||
DONE_script = $(B)src/components/script/libscript.dummy
|
DONE_script = $(B)src/components/script/libscript.dummy
|
||||||
|
|
||||||
DEPS_script = $(CRATE_script) $(SRC_script) $(DONE_SUBMODULES) $(DONE_util) $(DONE_style) $(DONE_net) $(DONE_msg) $(DONE_macros)
|
DEPS_script = $(CRATE_script) $(SRC_script) $(DONE_SUBMODULES) $(DONE_util) $(DONE_style) $(DONE_net) $(DONE_msg) $(DONE_macros) $(DONE_gfx)
|
||||||
|
|
||||||
RFLAGS_style = $(addprefix -L $(B)src/,$(DEPS_SUBMODULES)) -L $(B)src/components/util -L$(B)src/components/macros
|
RFLAGS_style = $(addprefix -L $(B)src/,$(DEPS_SUBMODULES)) -L $(B)src/components/util -L$(B)src/components/macros
|
||||||
MAKO_ZIP = $(S)src/components/style/Mako-0.9.1.zip
|
MAKO_ZIP = $(S)src/components/style/Mako-0.9.1.zip
|
||||||
|
|
78
src/components/gfx/canvas_render_task.rs
Normal file
78
src/components/gfx/canvas_render_task.rs
Normal file
|
@ -0,0 +1,78 @@
|
||||||
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||||
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||||
|
|
||||||
|
use azure::azure_hl::{DrawTarget, Color, B8G8R8A8, SkiaBackend, StrokeOptions, DrawOptions};
|
||||||
|
use azure::azure_hl::ColorPattern;
|
||||||
|
use geom::rect::Rect;
|
||||||
|
use geom::size::Size2D;
|
||||||
|
|
||||||
|
use std::comm;
|
||||||
|
use std::task::TaskBuilder;
|
||||||
|
|
||||||
|
pub enum CanvasMsg {
|
||||||
|
FillRect(Rect<f32>),
|
||||||
|
ClearRect(Rect<f32>),
|
||||||
|
StrokeRect(Rect<f32>),
|
||||||
|
Recreate(Size2D<i32>),
|
||||||
|
Close,
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct CanvasRenderTask {
|
||||||
|
drawtarget: DrawTarget,
|
||||||
|
fill_color: ColorPattern,
|
||||||
|
stroke_color: ColorPattern,
|
||||||
|
stroke_opts: StrokeOptions,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl CanvasRenderTask {
|
||||||
|
fn new(size: Size2D<i32>) -> CanvasRenderTask {
|
||||||
|
CanvasRenderTask {
|
||||||
|
drawtarget: CanvasRenderTask::create(size),
|
||||||
|
fill_color: ColorPattern::new(Color::new(0., 0., 0., 1.)),
|
||||||
|
stroke_color: ColorPattern::new(Color::new(0., 0., 0., 1.)),
|
||||||
|
stroke_opts: StrokeOptions::new(1.0, 1.0),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn start(size: Size2D<i32>) -> Sender<CanvasMsg> {
|
||||||
|
let (chan, port) = comm::channel::<CanvasMsg>();
|
||||||
|
let builder = TaskBuilder::new().named("CanvasTask");
|
||||||
|
builder.spawn(proc() {
|
||||||
|
let mut renderer = CanvasRenderTask::new(size);
|
||||||
|
|
||||||
|
loop {
|
||||||
|
match port.recv() {
|
||||||
|
FillRect(ref rect) => renderer.fill_rect(rect),
|
||||||
|
StrokeRect(ref rect) => renderer.stroke_rect(rect),
|
||||||
|
ClearRect(ref rect) => renderer.clear_rect(rect),
|
||||||
|
Recreate(size) => renderer.recreate(size),
|
||||||
|
Close => break,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
chan
|
||||||
|
}
|
||||||
|
|
||||||
|
fn fill_rect(&self, rect: &Rect<f32>) {
|
||||||
|
let drawopts = DrawOptions::new(1.0, 0);
|
||||||
|
self.drawtarget.fill_rect(rect, &self.fill_color, Some(&drawopts));
|
||||||
|
}
|
||||||
|
|
||||||
|
fn clear_rect(&self, rect: &Rect<f32>) {
|
||||||
|
self.drawtarget.clear_rect(rect);
|
||||||
|
}
|
||||||
|
|
||||||
|
fn stroke_rect(&self, rect: &Rect<f32>) {
|
||||||
|
let drawopts = DrawOptions::new(1.0, 0);
|
||||||
|
self.drawtarget.stroke_rect(rect, &self.stroke_color, &self.stroke_opts, &drawopts);
|
||||||
|
}
|
||||||
|
|
||||||
|
fn create(size: Size2D<i32>) -> DrawTarget {
|
||||||
|
DrawTarget::new(SkiaBackend, size, B8G8R8A8)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn recreate(&mut self, size: Size2D<i32>) {
|
||||||
|
self.drawtarget = CanvasRenderTask::create(size);
|
||||||
|
}
|
||||||
|
}
|
|
@ -54,6 +54,10 @@ pub mod color;
|
||||||
pub mod display_list;
|
pub mod display_list;
|
||||||
pub mod render_task;
|
pub mod render_task;
|
||||||
|
|
||||||
|
// Canvas Rendering
|
||||||
|
#[allow(dead_code)]
|
||||||
|
pub mod canvas_render_task;
|
||||||
|
|
||||||
// Fonts
|
// Fonts
|
||||||
pub mod font;
|
pub mod font;
|
||||||
pub mod font_context;
|
pub mod font_context;
|
||||||
|
|
|
@ -9,14 +9,11 @@ use dom::bindings::js::{JSRef, Temporary};
|
||||||
use dom::bindings::trace::Untraceable;
|
use dom::bindings::trace::Untraceable;
|
||||||
use dom::bindings::utils::{Reflector, Reflectable, reflect_dom_object};
|
use dom::bindings::utils::{Reflector, Reflectable, reflect_dom_object};
|
||||||
|
|
||||||
use azure::azure_hl::{DrawTarget, Color, B8G8R8A8, SkiaBackend, StrokeOptions, DrawOptions};
|
|
||||||
use azure::azure_hl::ColorPattern;
|
|
||||||
use geom::point::Point2D;
|
use geom::point::Point2D;
|
||||||
use geom::rect::Rect;
|
use geom::rect::Rect;
|
||||||
use geom::size::Size2D;
|
use geom::size::Size2D;
|
||||||
|
|
||||||
use std::comm;
|
use gfx::canvas_render_task::{CanvasMsg, CanvasRenderTask, ClearRect, Close, FillRect, Recreate, StrokeRect};
|
||||||
use std::task::TaskBuilder;
|
|
||||||
|
|
||||||
#[deriving(Encodable)]
|
#[deriving(Encodable)]
|
||||||
pub struct CanvasRenderingContext2D {
|
pub struct CanvasRenderingContext2D {
|
||||||
|
@ -25,73 +22,6 @@ pub struct CanvasRenderingContext2D {
|
||||||
renderer: Untraceable<Sender<CanvasMsg>>,
|
renderer: Untraceable<Sender<CanvasMsg>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
enum CanvasMsg {
|
|
||||||
FillRect(Rect<f32>),
|
|
||||||
ClearRect(Rect<f32>),
|
|
||||||
StrokeRect(Rect<f32>),
|
|
||||||
Recreate(Size2D<i32>),
|
|
||||||
Close,
|
|
||||||
}
|
|
||||||
|
|
||||||
struct CanvasRenderTask {
|
|
||||||
drawtarget: DrawTarget,
|
|
||||||
fill_color: ColorPattern,
|
|
||||||
stroke_color: ColorPattern,
|
|
||||||
stroke_opts: StrokeOptions,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl CanvasRenderTask {
|
|
||||||
fn new(size: Size2D<i32>) -> CanvasRenderTask {
|
|
||||||
CanvasRenderTask {
|
|
||||||
drawtarget: CanvasRenderTask::create(size),
|
|
||||||
fill_color: ColorPattern::new(Color::new(0., 0., 0., 1.)),
|
|
||||||
stroke_color: ColorPattern::new(Color::new(0., 0., 0., 1.)),
|
|
||||||
stroke_opts: StrokeOptions::new(1.0, 1.0),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn start(size: Size2D<i32>) -> Sender<CanvasMsg> {
|
|
||||||
let (chan, port) = comm::channel::<CanvasMsg>();
|
|
||||||
let builder = TaskBuilder::new().named("CanvasTask");
|
|
||||||
builder.spawn(proc() {
|
|
||||||
let mut renderer = CanvasRenderTask::new(size);
|
|
||||||
|
|
||||||
loop {
|
|
||||||
match port.recv() {
|
|
||||||
FillRect(ref rect) => renderer.fill_rect(rect),
|
|
||||||
StrokeRect(ref rect) => renderer.stroke_rect(rect),
|
|
||||||
ClearRect(ref rect) => renderer.clear_rect(rect),
|
|
||||||
Recreate(size) => renderer.recreate(size),
|
|
||||||
Close => break,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
chan
|
|
||||||
}
|
|
||||||
|
|
||||||
fn fill_rect(&self, rect: &Rect<f32>) {
|
|
||||||
let drawopts = DrawOptions::new(1.0, 0);
|
|
||||||
self.drawtarget.fill_rect(rect, &self.fill_color, Some(&drawopts));
|
|
||||||
}
|
|
||||||
|
|
||||||
fn clear_rect(&self, rect: &Rect<f32>) {
|
|
||||||
self.drawtarget.clear_rect(rect);
|
|
||||||
}
|
|
||||||
|
|
||||||
fn stroke_rect(&self, rect: &Rect<f32>) {
|
|
||||||
let drawopts = DrawOptions::new(1.0, 0);
|
|
||||||
self.drawtarget.stroke_rect(rect, &self.stroke_color, &self.stroke_opts, &drawopts);
|
|
||||||
}
|
|
||||||
|
|
||||||
fn create(size: Size2D<i32>) -> DrawTarget {
|
|
||||||
DrawTarget::new(SkiaBackend, size, B8G8R8A8)
|
|
||||||
}
|
|
||||||
|
|
||||||
fn recreate(&mut self, size: Size2D<i32>) {
|
|
||||||
self.drawtarget = CanvasRenderTask::create(size);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl CanvasRenderingContext2D {
|
impl CanvasRenderingContext2D {
|
||||||
pub fn new_inherited(global: &GlobalRef, size: Size2D<i32>) -> CanvasRenderingContext2D {
|
pub fn new_inherited(global: &GlobalRef, size: Size2D<i32>) -> CanvasRenderingContext2D {
|
||||||
CanvasRenderingContext2D {
|
CanvasRenderingContext2D {
|
||||||
|
|
|
@ -19,7 +19,6 @@
|
||||||
#[phase(plugin, link)]
|
#[phase(plugin, link)]
|
||||||
extern crate log;
|
extern crate log;
|
||||||
|
|
||||||
extern crate azure;
|
|
||||||
extern crate debug;
|
extern crate debug;
|
||||||
extern crate cssparser;
|
extern crate cssparser;
|
||||||
extern crate collections;
|
extern crate collections;
|
||||||
|
@ -42,6 +41,7 @@ extern crate style;
|
||||||
extern crate sync;
|
extern crate sync;
|
||||||
extern crate servo_msg = "msg";
|
extern crate servo_msg = "msg";
|
||||||
extern crate url = "url_";
|
extern crate url = "url_";
|
||||||
|
extern crate gfx;
|
||||||
|
|
||||||
pub mod cors;
|
pub mod cors;
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue