GTK : Color init change (patch by chrono)
This fixes the wrong colors when using Cairo output
This commit is contained in:
parent
93cdd07256
commit
437eb7dc39
|
@ -63,17 +63,7 @@ void ScreenAreaCairo::vDrawPixels(u8 * _puiData)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// TODO : Find a way to use systemXXXShift cleanly to avoid this loop
|
memcpy(m_puiPixels, _puiData + iSrcPitch, m_iHeight * iSrcPitch);
|
||||||
u32 * puiPixel = m_puiPixels;
|
|
||||||
u8 * puiSrc = _puiData + iSrcPitch;
|
|
||||||
for (int i = 0; i < (m_iWidth + 1) * m_iHeight; i++)
|
|
||||||
{
|
|
||||||
u8 iR = *puiSrc++;
|
|
||||||
u8 iG = *puiSrc++;
|
|
||||||
u8 iB = *puiSrc++;
|
|
||||||
puiSrc++;
|
|
||||||
*puiPixel++ = (iR << 16) + (iG << 8) + iB;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
queue_draw();
|
queue_draw();
|
||||||
|
|
|
@ -686,6 +686,56 @@ Window::~Window()
|
||||||
m_poInstance = NULL;
|
m_poInstance = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Window::vInitColors(EColorFormat _eColorFormat)
|
||||||
|
{
|
||||||
|
switch (_eColorFormat)
|
||||||
|
{
|
||||||
|
case ColorFormatBGR:
|
||||||
|
#if G_BYTE_ORDER == G_LITTLE_ENDIAN
|
||||||
|
systemRedShift = 3;
|
||||||
|
systemGreenShift = 11;
|
||||||
|
systemBlueShift = 19;
|
||||||
|
RGB_LOW_BITS_MASK = 0x00010101;
|
||||||
|
#else
|
||||||
|
systemRedShift = 27;
|
||||||
|
systemGreenShift = 19;
|
||||||
|
systemBlueShift = 11;
|
||||||
|
RGB_LOW_BITS_MASK = 0x01010100;
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
#if G_BYTE_ORDER == G_LITTLE_ENDIAN
|
||||||
|
systemRedShift = 19;
|
||||||
|
systemGreenShift = 11;
|
||||||
|
systemBlueShift = 3;
|
||||||
|
RGB_LOW_BITS_MASK = 0x00010101;
|
||||||
|
#else
|
||||||
|
systemRedShift = 11;
|
||||||
|
systemGreenShift = 19;
|
||||||
|
systemBlueShift = 27;
|
||||||
|
RGB_LOW_BITS_MASK = 0x01010100;
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i < 0x10000; i++)
|
||||||
|
{
|
||||||
|
systemColorMap32[i] = (((i & 0x1f) << systemRedShift)
|
||||||
|
| (((i & 0x3e0) >> 5) << systemGreenShift)
|
||||||
|
| (((i & 0x7c00) >> 10) << systemBlueShift));
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i < 24; )
|
||||||
|
{
|
||||||
|
systemGbPalette[i++] = (0x1f) | (0x1f << 5) | (0x1f << 10);
|
||||||
|
systemGbPalette[i++] = (0x15) | (0x15 << 5) | (0x15 << 10);
|
||||||
|
systemGbPalette[i++] = (0x0c) | (0x0c << 5) | (0x0c << 10);
|
||||||
|
systemGbPalette[i++] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
Init_2xSaI(32);
|
||||||
|
}
|
||||||
|
|
||||||
void Window::vInitScreenArea(EVideoOutput _eVideoOutput)
|
void Window::vInitScreenArea(EVideoOutput _eVideoOutput)
|
||||||
{
|
{
|
||||||
Gtk::Alignment * poC;
|
Gtk::Alignment * poC;
|
||||||
|
@ -700,14 +750,17 @@ void Window::vInitScreenArea(EVideoOutput _eVideoOutput)
|
||||||
{
|
{
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
case OutputOpenGL:
|
case OutputOpenGL:
|
||||||
|
vInitColors(ColorFormatBGR);
|
||||||
m_poScreenArea = Gtk::manage(new ScreenAreaGl(m_iScreenWidth, m_iScreenHeight));
|
m_poScreenArea = Gtk::manage(new ScreenAreaGl(m_iScreenWidth, m_iScreenHeight));
|
||||||
break;
|
break;
|
||||||
#endif // USE_OPENGL
|
#endif // USE_OPENGL
|
||||||
case OutputXvideo:
|
case OutputXvideo:
|
||||||
|
vInitColors(ColorFormatBGR);
|
||||||
m_poScreenArea = Gtk::manage(new ScreenAreaXv(m_iScreenWidth, m_iScreenHeight));
|
m_poScreenArea = Gtk::manage(new ScreenAreaXv(m_iScreenWidth, m_iScreenHeight));
|
||||||
break;
|
break;
|
||||||
case OutputCairo:
|
case OutputCairo:
|
||||||
default:
|
default:
|
||||||
|
vInitColors(ColorFormatRGB);
|
||||||
m_poScreenArea = Gtk::manage(new ScreenAreaCairo(m_iScreenWidth, m_iScreenHeight));
|
m_poScreenArea = Gtk::manage(new ScreenAreaCairo(m_iScreenWidth, m_iScreenHeight));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -725,18 +778,6 @@ void Window::vInitScreenArea(EVideoOutput _eVideoOutput)
|
||||||
|
|
||||||
void Window::vInitSystem()
|
void Window::vInitSystem()
|
||||||
{
|
{
|
||||||
#if G_BYTE_ORDER == G_LITTLE_ENDIAN
|
|
||||||
systemRedShift = 3;
|
|
||||||
systemGreenShift = 11;
|
|
||||||
systemBlueShift = 19;
|
|
||||||
RGB_LOW_BITS_MASK = 0x00010101;
|
|
||||||
#else
|
|
||||||
systemRedShift = 27;
|
|
||||||
systemGreenShift = 19;
|
|
||||||
systemBlueShift = 11;
|
|
||||||
RGB_LOW_BITS_MASK = 0x01010100;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
systemColorDepth = 32;
|
systemColorDepth = 32;
|
||||||
systemVerbose = 0;
|
systemVerbose = 0;
|
||||||
systemSaveUpdateCounter = SYSTEM_SAVE_NOT_UPDATED;
|
systemSaveUpdateCounter = SYSTEM_SAVE_NOT_UPDATED;
|
||||||
|
@ -747,25 +788,8 @@ void Window::vInitSystem()
|
||||||
|
|
||||||
emulating = 0;
|
emulating = 0;
|
||||||
|
|
||||||
for (int i = 0; i < 0x10000; i++)
|
|
||||||
{
|
|
||||||
systemColorMap32[i] = (((i & 0x1f) << systemRedShift)
|
|
||||||
| (((i & 0x3e0) >> 5) << systemGreenShift)
|
|
||||||
| (((i & 0x7c00) >> 10) << systemBlueShift));
|
|
||||||
}
|
|
||||||
|
|
||||||
gbFrameSkip = 0;
|
gbFrameSkip = 0;
|
||||||
|
|
||||||
for (int i = 0; i < 24; )
|
|
||||||
{
|
|
||||||
systemGbPalette[i++] = (0x1f) | (0x1f << 5) | (0x1f << 10);
|
|
||||||
systemGbPalette[i++] = (0x15) | (0x15 << 5) | (0x15 << 10);
|
|
||||||
systemGbPalette[i++] = (0x0c) | (0x0c << 5) | (0x0c << 10);
|
|
||||||
systemGbPalette[i++] = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
Init_2xSaI(32);
|
|
||||||
|
|
||||||
soundInit();
|
soundInit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -116,6 +116,12 @@ protected:
|
||||||
EmulatorSGB2
|
EmulatorSGB2
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum EColorFormat
|
||||||
|
{
|
||||||
|
ColorFormatRGB,
|
||||||
|
ColorFormatBGR
|
||||||
|
};
|
||||||
|
|
||||||
enum EVideoOutput
|
enum EVideoOutput
|
||||||
{
|
{
|
||||||
OutputCairo,
|
OutputCairo,
|
||||||
|
@ -258,6 +264,7 @@ private:
|
||||||
void vInitSDL();
|
void vInitSDL();
|
||||||
void vInitConfig();
|
void vInitConfig();
|
||||||
void vCheckConfig();
|
void vCheckConfig();
|
||||||
|
void vInitColors(EColorFormat _eColorFormat);
|
||||||
void vInitScreenArea(EVideoOutput _eVideoOutput);
|
void vInitScreenArea(EVideoOutput _eVideoOutput);
|
||||||
void vLoadConfig(const std::string & _rsFile);
|
void vLoadConfig(const std::string & _rsFile);
|
||||||
void vSaveConfig(const std::string & _rsFile);
|
void vSaveConfig(const std::string & _rsFile);
|
||||||
|
|
Loading…
Reference in New Issue