aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/webgltexture.rs
diff options
context:
space:
mode:
Diffstat (limited to 'components/script/dom/webgltexture.rs')
-rw-r--r--components/script/dom/webgltexture.rs38
1 files changed, 33 insertions, 5 deletions
diff --git a/components/script/dom/webgltexture.rs b/components/script/dom/webgltexture.rs
index d871bc598da..6848e3a7f71 100644
--- a/components/script/dom/webgltexture.rs
+++ b/components/script/dom/webgltexture.rs
@@ -9,31 +9,59 @@ use dom::bindings::js::Root;
use dom::bindings::utils::reflect_dom_object;
use dom::webglobject::WebGLObject;
+use canvas_traits::{CanvasMsg, CanvasWebGLMsg};
+use std::sync::mpsc::{channel, Sender};
+use std::cell::Cell;
+
#[dom_struct]
pub struct WebGLTexture {
webgl_object: WebGLObject,
id: u32,
+ is_deleted: Cell<bool>,
+ renderer: Sender<CanvasMsg>,
}
impl WebGLTexture {
- fn new_inherited(id: u32) -> WebGLTexture {
+ fn new_inherited(renderer: Sender<CanvasMsg>, id: u32) -> WebGLTexture {
WebGLTexture {
webgl_object: WebGLObject::new_inherited(),
id: id,
+ is_deleted: Cell::new(false),
+ renderer: renderer,
}
}
- pub fn new(global: GlobalRef, id: u32) -> Root<WebGLTexture> {
- reflect_dom_object(box WebGLTexture::new_inherited(id), global, WebGLTextureBinding::Wrap)
+ pub fn maybe_new(global: GlobalRef, renderer: Sender<CanvasMsg>) -> Option<Root<WebGLTexture>> {
+ let (sender, receiver) = channel();
+ renderer.send(CanvasMsg::WebGL(CanvasWebGLMsg::CreateTexture(sender))).unwrap();
+ receiver.recv().unwrap()
+ .map(|texture_id| WebGLTexture::new(global, renderer, *texture_id))
+ }
+
+ pub fn new(global: GlobalRef, renderer: Sender<CanvasMsg>, id: u32) -> Root<WebGLTexture> {
+ reflect_dom_object(box WebGLTexture::new_inherited(renderer, id), global, WebGLTextureBinding::Wrap)
}
}
pub trait WebGLTextureHelpers {
- fn get_id(self) -> u32;
+ fn id(self) -> u32;
+ fn bind(self, target: u32);
+ fn delete(self);
}
impl<'a> WebGLTextureHelpers for &'a WebGLTexture {
- fn get_id(self) -> u32 {
+ fn id(&self) -> u32 {
self.id
}
+
+ fn bind(self, target: u32) {
+ self.renderer.send(CanvasMsg::WebGL(CanvasWebGLMsg::BindTexture(self.id, target))).unwrap();
+ }
+
+ fn delete(self) {
+ if !self.is_deleted.get() {
+ self.is_deleted.set(true);
+ self.renderer.send(CanvasMsg::WebGL(CanvasWebGLMsg::DeleteTexture(self.id))).unwrap();
+ }
+ }
}