aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/htmlmediaelement.rs
diff options
context:
space:
mode:
authorVíctor Manuel Jáquez Leal <vjaquez@igalia.com>2019-09-17 18:04:50 +0200
committerVíctor Manuel Jáquez Leal <vjaquez@igalia.com>2019-10-04 18:08:06 +0200
commitbc07154e05f5666b3a8c0e7d1e4a92bd395423a3 (patch)
tree2b3a5ea6b7361252ba1554d9a0516ecdc43c91ca /components/script/dom/htmlmediaelement.rs
parentdc65d825e8a27d6e5604155de7dcb01fcd871123 (diff)
downloadservo-bc07154e05f5666b3a8c0e7d1e4a92bd395423a3.tar.gz
servo-bc07154e05f5666b3a8c0e7d1e4a92bd395423a3.zip
Always hold current frame
Regardless if it contains raw data or a gl texture. It is required to hold current frame because it can be used for webgl's get_image_pixels
Diffstat (limited to 'components/script/dom/htmlmediaelement.rs')
-rw-r--r--components/script/dom/htmlmediaelement.rs20
1 files changed, 12 insertions, 8 deletions
diff --git a/components/script/dom/htmlmediaelement.rs b/components/script/dom/htmlmediaelement.rs
index e3cb0dfb5b2..99b75748687 100644
--- a/components/script/dom/htmlmediaelement.rs
+++ b/components/script/dom/htmlmediaelement.rs
@@ -193,12 +193,12 @@ impl FrameRenderer for MediaFrameRenderer {
ImageData::Raw(frame.get_data()),
&webrender_api::DirtyRect::All,
);
- } else if self.player_id.is_some() {
- self.current_frame_holder
- .get_or_insert_with(|| FrameHolder::new(frame.clone()))
- .set(frame);
}
+ self.current_frame_holder
+ .get_or_insert_with(|| FrameHolder::new(frame.clone()))
+ .set(frame);
+
if let Some(old_image_key) = self.old_frame.take() {
txn.delete_image(old_image_key);
}
@@ -220,9 +220,6 @@ impl FrameRenderer for MediaFrameRenderer {
TextureTarget::Default
};
- self.current_frame_holder
- .get_or_insert_with(|| FrameHolder::new(frame.clone()))
- .set(frame);
ImageData::External(ExternalImageData {
id: ExternalImageId(self.player_id.unwrap()),
channel_index: 0,
@@ -231,6 +228,11 @@ impl FrameRenderer for MediaFrameRenderer {
} else {
ImageData::Raw(frame.get_data())
};
+
+ self.current_frame_holder
+ .get_or_insert_with(|| FrameHolder::new(frame.clone()))
+ .set(frame);
+
txn.add_image(new_image_key, descriptor, image_data, None);
},
None => {
@@ -244,7 +246,6 @@ impl FrameRenderer for MediaFrameRenderer {
TextureTarget::Default
};
- self.current_frame_holder = Some(FrameHolder::new(frame));
ImageData::External(ExternalImageData {
id: ExternalImageId(self.player_id.unwrap()),
channel_index: 0,
@@ -253,6 +254,9 @@ impl FrameRenderer for MediaFrameRenderer {
} else {
ImageData::Raw(frame.get_data())
};
+
+ self.current_frame_holder = Some(FrameHolder::new(frame));
+
txn.add_image(image_key, descriptor, image_data, None);
},
}