From b00a619e2dcb02c129d9f1163c36559c20f76a2a Mon Sep 17 00:00:00 2001 From: Paul Kaplan Date: Wed, 11 Oct 2017 15:58:06 -0400 Subject: [PATCH 1/2] Only flip bubble if it would fit the other way --- src/blocks/scratch3_looks.js | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/blocks/scratch3_looks.js b/src/blocks/scratch3_looks.js index 9061a008f..cb57de7ef 100644 --- a/src/blocks/scratch3_looks.js +++ b/src/blocks/scratch3_looks.js @@ -114,10 +114,12 @@ class Scratch3LooksBlocks { const [bubbleWidth, bubbleHeight] = this.runtime.renderer.getSkinSize(bubbleState.drawableId); const targetBounds = target.getBounds(); const stageBounds = this.runtime.getTargetForStage().getBounds(); - if (bubbleState.onSpriteRight && bubbleWidth + targetBounds.right > stageBounds.right) { + if (bubbleState.onSpriteRight && bubbleWidth + targetBounds.right > stageBounds.right && + (targetBounds.left - bubbleWidth > stageBounds.left)) { // Only flip if it would fit bubbleState.onSpriteRight = false; this._renderBubble(target); - } else if (!bubbleState.onSpriteRight && targetBounds.left - bubbleWidth < stageBounds.left) { + } else if (!bubbleState.onSpriteRight && targetBounds.left - bubbleWidth < stageBounds.left && + (bubbleWidth + targetBounds.right < stageBounds.right)) { // Only flip if it would fit bubbleState.onSpriteRight = true; this._renderBubble(target); } else { From 4599a71dd7a60421b3093f99f98cd215656b4d45 Mon Sep 17 00:00:00 2001 From: Paul Kaplan Date: Wed, 11 Oct 2017 16:34:50 -0400 Subject: [PATCH 2/2] Try to pin the bubbles within the left/right bounds --- src/blocks/scratch3_looks.js | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/blocks/scratch3_looks.js b/src/blocks/scratch3_looks.js index cb57de7ef..8b9e49cc9 100644 --- a/src/blocks/scratch3_looks.js +++ b/src/blocks/scratch3_looks.js @@ -125,7 +125,11 @@ class Scratch3LooksBlocks { } else { this.runtime.renderer.updateDrawableProperties(bubbleState.drawableId, { position: [ - bubbleState.onSpriteRight ? targetBounds.right : targetBounds.left - bubbleWidth, + bubbleState.onSpriteRight ? ( + Math.min(stageBounds.right - bubbleWidth, targetBounds.right) + ) : ( + Math.max(stageBounds.left, targetBounds.left - bubbleWidth) + ), Math.min(stageBounds.top, targetBounds.top + bubbleHeight) ] });