Skip to content

Commit

Permalink
Always hold current frame
Browse files Browse the repository at this point in the history
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
  • Loading branch information
ceyusa committed Oct 4, 2019
1 parent dc65d82 commit bc07154
Showing 1 changed file with 12 additions and 8 deletions.
20 changes: 12 additions & 8 deletions components/script/dom/htmlmediaelement.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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);
}
Expand All @@ -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,
Expand All @@ -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 => {
Expand All @@ -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,
Expand All @@ -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);
},
}
Expand Down

0 comments on commit bc07154

Please sign in to comment.