mirror of
https://github.com/Ninjdai1/pokeemerald.git
synced 2024-11-16 11:37:40 +01:00
Give sensical names to Unused_AdjustBgMosaic
This commit is contained in:
parent
fa2d25d366
commit
998900bd1b
79
gflib/bg.c
79
gflib/bg.c
@ -776,75 +776,86 @@ void SetBgAffine(u8 bg, s32 srcCenterX, s32 srcCenterY, s16 dispCenterX, s16 dis
|
|||||||
SetBgAffineInternal(bg, srcCenterX, srcCenterY, dispCenterX, dispCenterY, scaleX, scaleY, rotationAngle);
|
SetBgAffineInternal(bg, srcCenterX, srcCenterY, dispCenterX, dispCenterY, scaleX, scaleY, rotationAngle);
|
||||||
}
|
}
|
||||||
|
|
||||||
u8 Unused_AdjustBgMosaic(u8 a1, u8 a2)
|
enum
|
||||||
{
|
{
|
||||||
u16 result = GetGpuReg(REG_OFFSET_MOSAIC);
|
MOSAIC_SET_HV,
|
||||||
s16 test1 = result & 0xF;
|
MOSAIC_SET_H,
|
||||||
s16 test2 = (result >> 4) & 0xF;
|
MOSAIC_ADD_H,
|
||||||
|
MOSAIC_SUB_H,
|
||||||
|
MOSAIC_SET_V,
|
||||||
|
MOSAIC_ADD_V,
|
||||||
|
MOSAIC_SUB_V,
|
||||||
|
};
|
||||||
|
|
||||||
result &= 0xFF00;
|
u8 Unused_AdjustBgMosaic(u8 val, u8 mode)
|
||||||
|
|
||||||
switch (a2)
|
|
||||||
{
|
{
|
||||||
case 0:
|
u16 mosaic = GetGpuReg(REG_OFFSET_MOSAIC);
|
||||||
|
s16 bgH = mosaic & 0xF;
|
||||||
|
s16 bgV = (mosaic >> 4) & 0xF;
|
||||||
|
|
||||||
|
mosaic &= 0xFF00; // clear background mosaic sizes
|
||||||
|
|
||||||
|
switch (mode)
|
||||||
|
{
|
||||||
|
case MOSAIC_SET_HV:
|
||||||
default:
|
default:
|
||||||
test1 = a1 & 0xF;
|
bgH = val & 0xF;
|
||||||
test2 = a1 >> 0x4;
|
bgV = val >> 0x4;
|
||||||
break;
|
break;
|
||||||
case 1:
|
case MOSAIC_SET_H:
|
||||||
test1 = a1 & 0xF;
|
bgH = val & 0xF;
|
||||||
break;
|
break;
|
||||||
case 2:
|
case MOSAIC_ADD_H:
|
||||||
if ((test1 + a1) > 0xF)
|
if ((bgH + val) > 0xF)
|
||||||
{
|
{
|
||||||
test1 = 0xF;
|
bgH = 0xF;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
test1 += a1;
|
bgH += val;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 3:
|
case MOSAIC_SUB_H:
|
||||||
if ((test1 - a1) < 0)
|
if ((bgH - val) < 0)
|
||||||
{
|
{
|
||||||
test1 = 0x0;
|
bgH = 0x0;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
test1 -= a1;
|
bgH -= val;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 4:
|
case MOSAIC_SET_V:
|
||||||
test2 = a1 & 0xF;
|
bgV = val & 0xF;
|
||||||
break;
|
break;
|
||||||
case 5:
|
case MOSAIC_ADD_V:
|
||||||
if ((test2 + a1) > 0xF)
|
if ((bgV + val) > 0xF)
|
||||||
{
|
{
|
||||||
test2 = 0xF;
|
bgV = 0xF;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
test2 += a1;
|
bgV += val;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 6:
|
case MOSAIC_SUB_V:
|
||||||
if ((test2 - a1) < 0)
|
if ((bgV - val) < 0)
|
||||||
{
|
{
|
||||||
test2 = 0x0;
|
bgV = 0x0;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
test2 -= a1;
|
bgV -= val;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
result |= ((test2 << 0x4) & 0xF0);
|
mosaic |= ((bgV << 0x4) & 0xF0);
|
||||||
result |= (test1 & 0xF);
|
mosaic |= (bgH & 0xF);
|
||||||
|
|
||||||
SetGpuReg(REG_OFFSET_MOSAIC, result);
|
SetGpuReg(REG_OFFSET_MOSAIC, mosaic);
|
||||||
|
|
||||||
return result;
|
return mosaic;
|
||||||
}
|
}
|
||||||
|
|
||||||
void SetBgTilemapBuffer(u8 bg, void *tilemap)
|
void SetBgTilemapBuffer(u8 bg, void *tilemap)
|
||||||
|
Loading…
Reference in New Issue
Block a user