camera: fix x-flip crustiness
This commit is contained in:
parent
3f4573574a
commit
af9a77b0b4
|
@ -505,16 +505,29 @@ int Camera::TransferScanline(u32* buffer, int maxlen)
|
||||||
if (FrameReadMode & (1<<1))
|
if (FrameReadMode & (1<<1))
|
||||||
sy = 479 - sy;
|
sy = 479 - sy;
|
||||||
|
|
||||||
|
if (FrameReadMode & (1<<0))
|
||||||
|
{
|
||||||
for (int dx = 0; dx < retlen; dx++)
|
for (int dx = 0; dx < retlen; dx++)
|
||||||
{
|
{
|
||||||
if (dx >= maxlen) break;
|
if (dx >= maxlen) break;
|
||||||
|
|
||||||
int sx = (dx * 640) / FrameWidth;
|
int sx = (dx * 640) / FrameWidth;
|
||||||
if (!(FrameReadMode & (1<<0)))
|
|
||||||
sx = 639 - sx;
|
|
||||||
|
|
||||||
u32 pixel3 = FrameBuffer[sy*320 + sx];
|
u32 val = FrameBuffer[sy*320 + sx];
|
||||||
buffer[dx] = pixel3;
|
buffer[dx] = val;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for (int dx = 0; dx < retlen; dx++)
|
||||||
|
{
|
||||||
|
if (dx >= maxlen) break;
|
||||||
|
|
||||||
|
int sx = 638 - ((dx * 640) / FrameWidth);
|
||||||
|
|
||||||
|
u32 val = FrameBuffer[sy*320 + sx];
|
||||||
|
buffer[dx] = (val & 0xFF00FF00) | ((val >> 16) & 0xFF) | ((val & 0xFF) << 16);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
TransferY++;
|
TransferY++;
|
||||||
|
|
|
@ -447,13 +447,10 @@ void CameraManager::feedFrame_NV12(u8* planeY, u8* planeUV, int width, int heigh
|
||||||
|
|
||||||
void CameraManager::copyFrame_Straight(u32* src, int swidth, int sheight, u32* dst, int dwidth, int dheight, bool xflip, bool yuv)
|
void CameraManager::copyFrame_Straight(u32* src, int swidth, int sheight, u32* dst, int dwidth, int dheight, bool xflip, bool yuv)
|
||||||
{
|
{
|
||||||
u32 alpha = 0xFF000000;
|
|
||||||
|
|
||||||
if (yuv)
|
if (yuv)
|
||||||
{
|
{
|
||||||
swidth /= 2;
|
swidth /= 2;
|
||||||
dwidth /= 2;
|
dwidth /= 2;
|
||||||
alpha = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int dy = 0; dy < dheight; dy++)
|
for (int dy = 0; dy < dheight; dy++)
|
||||||
|
@ -465,7 +462,19 @@ void CameraManager::copyFrame_Straight(u32* src, int swidth, int sheight, u32* d
|
||||||
int sx = (dx * swidth) / dwidth;
|
int sx = (dx * swidth) / dwidth;
|
||||||
if (xflip) sx = swidth-1 - sx;
|
if (xflip) sx = swidth-1 - sx;
|
||||||
|
|
||||||
dst[(dy * dwidth) + dx] = src[(sy * swidth) + sx] | alpha;
|
u32 val = src[(sy * swidth) + sx];
|
||||||
|
|
||||||
|
if (yuv)
|
||||||
|
{
|
||||||
|
if (xflip)
|
||||||
|
val = (val & 0xFF00FF00) |
|
||||||
|
((val >> 16) & 0xFF) |
|
||||||
|
((val & 0xFF) << 16);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
val |= 0xFF000000;
|
||||||
|
|
||||||
|
dst[(dy * dwidth) + dx] = val;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -530,13 +539,22 @@ void CameraManager::copyFrame_YUVtoRGB(u32* src, int swidth, int sheight, u32* d
|
||||||
for (int dx = 0; dx < dwidth; dx+=2)
|
for (int dx = 0; dx < dwidth; dx+=2)
|
||||||
{
|
{
|
||||||
int sx = (dx * swidth) / dwidth;
|
int sx = (dx * swidth) / dwidth;
|
||||||
if (xflip) sx = swidth-1 - sx;
|
if (xflip) sx = swidth-2 - sx;
|
||||||
|
|
||||||
u32 val = src[(sy*swidth + sx) / 2];
|
u32 val = src[(sy*swidth + sx) / 2];
|
||||||
|
|
||||||
int y1 = val & 0xFF;
|
int y1, y2;
|
||||||
|
if (xflip)
|
||||||
|
{
|
||||||
|
y1 = (val >> 16) & 0xFF;
|
||||||
|
y2 = val & 0xFF;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
y1 = val & 0xFF;
|
||||||
|
y2 = (val >> 16) & 0xFF;
|
||||||
|
}
|
||||||
int u = (val >> 8) & 0xFF;
|
int u = (val >> 8) & 0xFF;
|
||||||
int y2 = (val >> 16) & 0xFF;
|
|
||||||
int v = (val >> 24) & 0xFF;
|
int v = (val >> 24) & 0xFF;
|
||||||
|
|
||||||
u -= 128; v -= 128;
|
u -= 128; v -= 128;
|
||||||
|
|
Loading…
Reference in New Issue