diff --git a/src/import/load-costume.js b/src/import/load-costume.js index 6dcb3ff99..79bb5f121 100644 --- a/src/import/load-costume.js +++ b/src/import/load-costume.js @@ -212,8 +212,17 @@ const loadBitmap_ = function (costume, runtime, _rotationCenter) { return fetched; }) .then(({canvas, mergeCanvas, rotationCenter}) => { - // createBitmapSkin does the right thing if costume.bitmapResolution or rotationCenter are undefined... - costume.skinId = runtime.renderer.createBitmapSkin(canvas, costume.bitmapResolution, rotationCenter); + // createBitmapSkin does the right thing if costume.bitmapResolution is undefined... + // TODO: is rotationCenter ever undefined? + let center; + if (rotationCenter) { + center = [ + rotationCenter[0] / 2, + rotationCenter[1] / 2 + ]; + } + + costume.skinId = runtime.renderer.createBitmapSkin(canvas, costume.bitmapResolution, center); canvasPool.release(mergeCanvas); const renderSize = runtime.renderer.getSkinSize(costume.skinId); costume.size = [renderSize[0] * 2, renderSize[1] * 2]; // Actual size, since all bitmaps are resolution 2 diff --git a/src/sprites/rendered-target.js b/src/sprites/rendered-target.js index 018f7cd16..40b774fb2 100644 --- a/src/sprites/rendered-target.js +++ b/src/sprites/rendered-target.js @@ -458,19 +458,7 @@ class RenderedTarget extends Target { ); if (this.renderer) { const costume = this.getCostumes()[this.currentCostume]; - if ( - typeof costume.rotationCenterX !== 'undefined' && - typeof costume.rotationCenterY !== 'undefined' - ) { - const scale = costume.bitmapResolution || 2; - const rotationCenter = [ - costume.rotationCenterX / scale, - costume.rotationCenterY / scale - ]; - this.renderer.updateDrawableSkinIdRotationCenter(this.drawableID, costume.skinId, rotationCenter); - } else { - this.renderer.updateDrawableSkinId(this.drawableID, costume.skinId); - } + this.renderer.updateDrawableSkinId(this.drawableID, costume.skinId); if (this.visible) { this.emit(RenderedTarget.EVENT_TARGET_VISUAL_CHANGE, this); @@ -709,11 +697,7 @@ class RenderedTarget extends Target { this.renderer.updateDrawableVisible(this.drawableID, this.visible); const costume = this.getCostumes()[this.currentCostume]; - const bitmapResolution = costume.bitmapResolution || 2; - this.renderer.updateDrawableSkinIdRotationCenter(this.drawableID, costume.skinId, [ - costume.rotationCenterX / bitmapResolution, - costume.rotationCenterY / bitmapResolution - ]); + this.renderer.updateDrawableSkinId(this.drawableID, costume.skinId); for (const effectName in this.effects) { if (!this.effects.hasOwnProperty(effectName)) continue; diff --git a/test/fixtures/fake-renderer.js b/test/fixtures/fake-renderer.js index 73b37ede6..41ffa7b1c 100644 --- a/test/fixtures/fake-renderer.js +++ b/test/fixtures/fake-renderer.js @@ -17,9 +17,6 @@ FakeRenderer.prototype.getFencedPositionOfDrawable = function (d, p) { // eslint FakeRenderer.prototype.updateDrawableSkinId = function (d, skinId) { // eslint-disable-line no-unused-vars }; -FakeRenderer.prototype.updateDrawableSkinIdRotationCenter = - function (d, skinId, rotationCenter) {}; // eslint-disable-line no-unused-vars - FakeRenderer.prototype.updateDrawablePosition = function (d, position) { // eslint-disable-line no-unused-vars this.x = position[0]; this.y = position[1];