mirror of https://github.com/bsnes-emu/bsnes.git
PPU Mosaic fixes imported from higan
This commit is contained in:
parent
9517080349
commit
fcc982dff0
|
@ -28,13 +28,13 @@ auto PPU::Line::renderBackground(PPU::IO::Background& self, uint8 source) -> voi
|
||||||
uint vmask = (width << self.tileSize << !!(self.screenSize & 2)) - 1;
|
uint vmask = (width << self.tileSize << !!(self.screenSize & 2)) - 1;
|
||||||
|
|
||||||
uint y = this->y;
|
uint y = this->y;
|
||||||
if(self.mosaicEnable) y -= io.mosaic.size - io.mosaic.counter;
|
|
||||||
if(hires) {
|
if(hires) {
|
||||||
hscroll <<= 1;
|
hscroll <<= 1;
|
||||||
if(io.interlace) {
|
if(io.interlace) y = y << 1 | (field() && !self.mosaicEnable);
|
||||||
y = y << 1 | field();
|
|
||||||
if(self.mosaicEnable) y -= io.mosaic.size - io.mosaic.counter + field();
|
|
||||||
}
|
}
|
||||||
|
if(self.mosaicEnable) {
|
||||||
|
y -= (io.mosaic.size - io.mosaic.counter) << (hires && io.interlace);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint mosaicCounter = 1;
|
uint mosaicCounter = 1;
|
||||||
|
@ -112,7 +112,7 @@ auto PPU::Line::renderBackground(PPU::IO::Background& self, uint8 source) -> voi
|
||||||
color += data >> shift + 49 & 128;
|
color += data >> shift + 49 & 128;
|
||||||
}
|
}
|
||||||
|
|
||||||
mosaicCounter = self.mosaicEnable ? io.mosaic.size : 1;
|
mosaicCounter = self.mosaicEnable ? io.mosaic.size << hires : 1;
|
||||||
mosaicPalette = color;
|
mosaicPalette = color;
|
||||||
mosaicPriority = tilePriority;
|
mosaicPriority = tilePriority;
|
||||||
if(directColorMode) {
|
if(directColorMode) {
|
||||||
|
|
|
@ -37,13 +37,12 @@ auto PPU::Background::fetchNameTable() -> void {
|
||||||
uint hscroll = io.hoffset;
|
uint hscroll = io.hoffset;
|
||||||
uint vscroll = io.voffset;
|
uint vscroll = io.voffset;
|
||||||
|
|
||||||
if(mosaic.enable) vpixel -= ppu.mosaic.voffset();
|
|
||||||
if(hires()) {
|
if(hires()) {
|
||||||
hscroll <<= 1;
|
hscroll <<= 1;
|
||||||
if(ppu.io.interlace) {
|
if(ppu.io.interlace) vpixel = vpixel << 1 | (ppu.field() && !mosaic.enable);
|
||||||
vpixel = vpixel << 1 | ppu.field();
|
|
||||||
if(mosaic.enable) vpixel -= ppu.mosaic.voffset() + ppu.field();
|
|
||||||
}
|
}
|
||||||
|
if(mosaic.enable) {
|
||||||
|
vpixel -= ppu.mosaic.voffset() << (hires() && ppu.io.interlace);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool repeated = false;
|
bool repeated = false;
|
||||||
|
@ -197,7 +196,8 @@ auto PPU::Background::run(bool screen) -> void {
|
||||||
if(++pixelCounter == 0) renderingIndex++;
|
if(++pixelCounter == 0) renderingIndex++;
|
||||||
|
|
||||||
uint x = ppu.hcounter() - 56 >> 2;
|
uint x = ppu.hcounter() - 56 >> 2;
|
||||||
if(x == 0) {
|
|
||||||
|
if(x == 0 && (!hires() || screen == Screen::Below)) {
|
||||||
mosaic.hcounter = ppu.mosaic.size;
|
mosaic.hcounter = ppu.mosaic.size;
|
||||||
mosaic.pixel = pixel;
|
mosaic.pixel = pixel;
|
||||||
} else if((!hires() || screen == Screen::Below) && --mosaic.hcounter == 0) {
|
} else if((!hires() || screen == Screen::Below) && --mosaic.hcounter == 0) {
|
||||||
|
|
Loading…
Reference in New Issue