Use bitmap skin for video preview

This commit is contained in:
Paul Kaplan 2019-10-11 12:32:03 -04:00
parent 8bba60aaf3
commit 5913cae969

View file

@ -21,12 +21,6 @@ class Video {
*/ */
this._skinId = -1; this._skinId = -1;
/**
* The Scratch Renderer Skin object.
* @type {Skin}
*/
this._skin = null;
/** /**
* Id for a drawable using the video's skin that will render as a video * Id for a drawable using the video's skin that will render as a video
* preview. * preview.
@ -141,8 +135,8 @@ class Video {
} }
_disablePreview () { _disablePreview () {
if (this._skin) { if (this._skinId) {
this._skin.clear(); this.runtime.renderer.updateBitmapSkin(this._skinId, new ImageData(...Video.DIMENSIONS), 1);
this.runtime.renderer.updateDrawableProperties(this._drawable, {visible: false}); this.runtime.renderer.updateDrawableProperties(this._drawable, {visible: false});
} }
this._renderPreviewFrame = null; this._renderPreviewFrame = null;
@ -152,9 +146,8 @@ class Video {
const {renderer} = this.runtime; const {renderer} = this.runtime;
if (!renderer) return; if (!renderer) return;
if (this._skinId === -1 && this._skin === null && this._drawable === -1) { if (this._skinId === -1 && this._drawable === -1) {
this._skinId = renderer.createPenSkin(); this._skinId = renderer.createBitmapSkin(new ImageData(...Video.DIMENSIONS), 1);
this._skin = renderer._allSkins[this._skinId];
this._drawable = renderer.createDrawable(StageLayering.VIDEO_LAYER); this._drawable = renderer.createDrawable(StageLayering.VIDEO_LAYER);
renderer.updateDrawableProperties(this._drawable, { renderer.updateDrawableProperties(this._drawable, {
skinId: this._skinId skinId: this._skinId
@ -176,16 +169,17 @@ class Video {
this._renderPreviewTimeout = setTimeout(this._renderPreviewFrame, this.runtime.currentStepTime); this._renderPreviewTimeout = setTimeout(this._renderPreviewFrame, this.runtime.currentStepTime);
const canvas = this.getFrame({format: Video.FORMAT_CANVAS}); const imageData = this.getFrame({
format: Video.FORMAT_IMAGE_DATA,
cacheTimeout: this.runtime.currentStepTime
});
if (!canvas) { if (!imageData) {
this._skin.clear(); renderer.updateBitmapSkin(this._skinId, new ImageData(...Video.DIMENSIONS), 1);
return; return;
} }
const xOffset = Video.DIMENSIONS[0] / -2; renderer.updateBitmapSkin(this._skinId, imageData, 1);
const yOffset = Video.DIMENSIONS[1] / 2;
this._skin.drawStamp(canvas, xOffset, yOffset);
this.runtime.requestRedraw(); this.runtime.requestRedraw();
}; };