GBA Video: Copy higher priority target 1 flag
This commit is contained in:
parent
28383d4d31
commit
ec4c91dbda
1
CHANGES
1
CHANGES
@ -95,6 +95,7 @@ Emulation fixes:
|
|||||||
- GBA Video: Fix OpenGL renderer 512x512 backgrounds (fixes mgba.io/i/1572)
|
- GBA Video: Fix OpenGL renderer 512x512 backgrounds (fixes mgba.io/i/1572)
|
||||||
- GBA Video: Fix BLDY for semitransparent sprite on non-target-2 backgrounds
|
- GBA Video: Fix BLDY for semitransparent sprite on non-target-2 backgrounds
|
||||||
- GBA Video: Fix effects blending improperly in some non-last windows
|
- GBA Video: Fix effects blending improperly in some non-last windows
|
||||||
|
- GBA Video: Copy higher priority target 1 flag
|
||||||
Other fixes:
|
Other fixes:
|
||||||
- 3DS: Fix screen darkening (fixes mgba.io/i/1562)
|
- 3DS: Fix screen darkening (fixes mgba.io/i/1562)
|
||||||
- Core: Fix uninitialized memory issues with graphics caches
|
- Core: Fix uninitialized memory issues with graphics caches
|
||||||
|
BIN
cinema/gba/blend/obj-semitrans-overwrite/baseline_0000.png
Normal file
BIN
cinema/gba/blend/obj-semitrans-overwrite/baseline_0000.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 4.6 KiB |
BIN
cinema/gba/blend/obj-semitrans-overwrite/baseline_0001.png
Normal file
BIN
cinema/gba/blend/obj-semitrans-overwrite/baseline_0001.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 4.6 KiB |
BIN
cinema/gba/blend/obj-semitrans-overwrite/test.mvl
Normal file
BIN
cinema/gba/blend/obj-semitrans-overwrite/test.mvl
Normal file
Binary file not shown.
@ -84,7 +84,7 @@
|
|||||||
if (tileData) { \
|
if (tileData) { \
|
||||||
renderer->spriteLayer[outX] = palette[tileData] | flags; \
|
renderer->spriteLayer[outX] = palette[tileData] | flags; \
|
||||||
} else if (current != FLAG_UNWRITTEN) { \
|
} else if (current != FLAG_UNWRITTEN) { \
|
||||||
renderer->spriteLayer[outX] = (current & ~FLAG_ORDER_MASK) | GBAObjAttributesCGetPriority(sprite->c) << OFFSET_PRIORITY; \
|
renderer->spriteLayer[outX] = (current & ~(FLAG_ORDER_MASK | FLAG_REBLEND | FLAG_TARGET_1)) | (flags & (FLAG_ORDER_MASK | FLAG_REBLEND | FLAG_TARGET_1)); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -97,7 +97,7 @@
|
|||||||
unsigned color = (renderer->row[outX] & FLAG_OBJWIN) ? objwinPalette[tileData] : palette[tileData]; \
|
unsigned color = (renderer->row[outX] & FLAG_OBJWIN) ? objwinPalette[tileData] : palette[tileData]; \
|
||||||
renderer->spriteLayer[outX] = color | flags; \
|
renderer->spriteLayer[outX] = color | flags; \
|
||||||
} else if (current != FLAG_UNWRITTEN) { \
|
} else if (current != FLAG_UNWRITTEN) { \
|
||||||
renderer->spriteLayer[outX] = (current & ~FLAG_ORDER_MASK) | GBAObjAttributesCGetPriority(sprite->c) << OFFSET_PRIORITY; \
|
renderer->spriteLayer[outX] = (current & ~(FLAG_ORDER_MASK | FLAG_REBLEND | FLAG_TARGET_1)) | (flags & (FLAG_ORDER_MASK | FLAG_REBLEND | FLAG_TARGET_1)); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -119,7 +119,7 @@
|
|||||||
if (tileData) { \
|
if (tileData) { \
|
||||||
renderer->spriteLayer[outX] = palette[tileData] | flags; \
|
renderer->spriteLayer[outX] = palette[tileData] | flags; \
|
||||||
} else if (current != FLAG_UNWRITTEN) { \
|
} else if (current != FLAG_UNWRITTEN) { \
|
||||||
renderer->spriteLayer[outX] = (current & ~FLAG_ORDER_MASK) | GBAObjAttributesCGetPriority(sprite->c) << OFFSET_PRIORITY; \
|
renderer->spriteLayer[outX] = (current & ~(FLAG_ORDER_MASK | FLAG_REBLEND | FLAG_TARGET_1)) | (flags & (FLAG_ORDER_MASK | FLAG_REBLEND | FLAG_TARGET_1)); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -132,7 +132,7 @@
|
|||||||
unsigned color = (renderer->row[outX] & FLAG_OBJWIN) ? objwinPalette[tileData] : palette[tileData]; \
|
unsigned color = (renderer->row[outX] & FLAG_OBJWIN) ? objwinPalette[tileData] : palette[tileData]; \
|
||||||
renderer->spriteLayer[outX] = color | flags; \
|
renderer->spriteLayer[outX] = color | flags; \
|
||||||
} else if (current != FLAG_UNWRITTEN) { \
|
} else if (current != FLAG_UNWRITTEN) { \
|
||||||
renderer->spriteLayer[outX] = (current & ~FLAG_ORDER_MASK) | GBAObjAttributesCGetPriority(sprite->c) << OFFSET_PRIORITY; \
|
renderer->spriteLayer[outX] = (current & ~(FLAG_ORDER_MASK | FLAG_REBLEND | FLAG_TARGET_1)) | (flags & (FLAG_ORDER_MASK | FLAG_REBLEND | FLAG_TARGET_1)); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user