mirror of
https://github.com/scratchfoundation/scratch-vm.git
synced 2025-01-11 23:30:09 -05:00
Merge pull request #703 from paulkaplan/fix-say-think-loop
⭐️ Fix the infinite loop in say/think ⭐️
This commit is contained in:
commit
c807f02e37
1 changed files with 9 additions and 3 deletions
|
@ -114,16 +114,22 @@ class Scratch3LooksBlocks {
|
||||||
const [bubbleWidth, bubbleHeight] = this.runtime.renderer.getSkinSize(bubbleState.drawableId);
|
const [bubbleWidth, bubbleHeight] = this.runtime.renderer.getSkinSize(bubbleState.drawableId);
|
||||||
const targetBounds = target.getBounds();
|
const targetBounds = target.getBounds();
|
||||||
const stageBounds = this.runtime.getTargetForStage().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;
|
bubbleState.onSpriteRight = false;
|
||||||
this._renderBubble(target);
|
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;
|
bubbleState.onSpriteRight = true;
|
||||||
this._renderBubble(target);
|
this._renderBubble(target);
|
||||||
} else {
|
} else {
|
||||||
this.runtime.renderer.updateDrawableProperties(bubbleState.drawableId, {
|
this.runtime.renderer.updateDrawableProperties(bubbleState.drawableId, {
|
||||||
position: [
|
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)
|
Math.min(stageBounds.top, targetBounds.top + bubbleHeight)
|
||||||
]
|
]
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue