From 617e171fcdb518580359844286f04204646748da Mon Sep 17 00:00:00 2001 From: Christopher Milne-O'Grady Date: Wed, 15 Feb 2023 23:03:32 -0500 Subject: [PATCH] Handle sprite bug on MHA BEM --- .../vb/dim/sprite/UnorderedSpriteReader.java | 34 +++++++++++++++---- 1 file changed, 28 insertions(+), 6 deletions(-) diff --git a/src/main/java/com/github/cfogrady/vb/dim/sprite/UnorderedSpriteReader.java b/src/main/java/com/github/cfogrady/vb/dim/sprite/UnorderedSpriteReader.java index 7dad686..afb9089 100644 --- a/src/main/java/com/github/cfogrady/vb/dim/sprite/UnorderedSpriteReader.java +++ b/src/main/java/com/github/cfogrady/vb/dim/sprite/UnorderedSpriteReader.java @@ -17,6 +17,8 @@ @Slf4j @RequiredArgsConstructor public class UnorderedSpriteReader { + private final static byte[] ONE_BY_ONE = {0x0, 0x0}; + private final SpriteChecksumAreasCalculator spriteChecksumAreasCalculator; @@ -35,18 +37,29 @@ public SpriteData spriteDataFromDimensionsAndStream(List spritesWithIndices = new ArrayList<>(numberOfSprites); - for(PointerWithSpriteIndex pointerWithSpriteIndex : pointersWithSpriteIndices) { + for(int i = 0; i < pointersWithSpriteIndices.size(); i++) { + PointerWithSpriteIndex pointerWithSpriteIndex = pointersWithSpriteIndices.get(i); int offset = pointerWithSpriteIndex.getPointer(); spriteDataSection.readToOffset(offset); SpriteData.SpriteDimensions dimensions = spriteDimensions.get(pointerWithSpriteIndex.getIndex()); int width = dimensions.getWidth(); int height = dimensions.getHeight(); int expectedSize = width * height * 2; - SpriteData.Sprite sprite = SpriteData.Sprite.builder() - .width(width) - .height(height) - .pixelData(spriteDataSection.readNBytes(expectedSize)) - .build(); + SpriteData.Sprite sprite; + if(wouldOverlapWithNextSprite(i, pointersWithSpriteIndices, expectedSize)) { + log.warn("Sprite at index {} has dimensions that would overlap with the next sprite! This is not a valid sprite replacing with a blank 1x1.", i); + sprite = SpriteData.Sprite.builder() + .width(1) + .height(1) + .pixelData(ONE_BY_ONE) + .build(); + } else { + sprite = SpriteData.Sprite.builder() + .width(width) + .height(height) + .pixelData(spriteDataSection.readNBytes(expectedSize)) + .build(); + } spritesWithIndices.add(new SpriteWithIndex(sprite, pointerWithSpriteIndex.getIndex())); } spriteDataSection.readToOffset(endSignalLocation+4); @@ -69,4 +82,13 @@ private List getPointersWithSpriteIndices(int[] pointers } return pointersWithSpriteIndices; } + + private boolean wouldOverlapWithNextSprite(int index, List pointersWithSpriteIndices, int expectedSize) { + if(index + 1 < pointersWithSpriteIndices.size()) { + int spritePointer = pointersWithSpriteIndices.get(index).getPointer(); + int nextSpritePointer = pointersWithSpriteIndices.get(index+1).getPointer(); + return spritePointer + expectedSize > nextSpritePointer; + } + return false; + } }