aboutsummaryrefslogtreecommitdiff
path: root/engines
diff options
context:
space:
mode:
Diffstat (limited to 'engines')
-rw-r--r--engines/sci/gui/gui_palette.cpp12
-rw-r--r--engines/sci/gui/gui_screen.cpp41
2 files changed, 36 insertions, 17 deletions
diff --git a/engines/sci/gui/gui_palette.cpp b/engines/sci/gui/gui_palette.cpp
index 56072ecaef..2e2ae650ae 100644
--- a/engines/sci/gui/gui_palette.cpp
+++ b/engines/sci/gui/gui_palette.cpp
@@ -143,7 +143,7 @@ bool SciGuiPalette::setAmiga() {
void SciGuiPalette::setEGA() {
int i;
- byte color, color1, color2;
+ byte color1, color2;
_sysPalette.colors[1].r = 0x000; _sysPalette.colors[1].g = 0x000; _sysPalette.colors[1].b = 0x0AA;
_sysPalette.colors[2].r = 0x000; _sysPalette.colors[2].g = 0x0AA; _sysPalette.colors[2].b = 0x000;
_sysPalette.colors[3].r = 0x000; _sysPalette.colors[3].g = 0x0AA; _sysPalette.colors[3].b = 0x0AA;
@@ -165,13 +165,11 @@ void SciGuiPalette::setEGA() {
// Now setting colors 16-254 to the correct mix colors that occur when not doing a dithering run on
// finished pictures
for (i = 0x10; i <= 0xFE; i++) {
- color = i;
- _sysPalette.colors[color].used = 1;
- color ^= color << 4;
+ _sysPalette.colors[i].used = 1;
color1 = i & 0x0F; color2 = i >> 4;
- _sysPalette.colors[color].r = (_sysPalette.colors[color1].r >> 1) + (_sysPalette.colors[color2].r >> 1);
- _sysPalette.colors[color].g = (_sysPalette.colors[color1].g >> 1) + (_sysPalette.colors[color2].g >> 1);
- _sysPalette.colors[color].b = (_sysPalette.colors[color1].b >> 1) + (_sysPalette.colors[color2].b >> 1);
+ _sysPalette.colors[i].r = (_sysPalette.colors[color1].r >> 1) + (_sysPalette.colors[color2].r >> 1);
+ _sysPalette.colors[i].g = (_sysPalette.colors[color1].g >> 1) + (_sysPalette.colors[color2].g >> 1);
+ _sysPalette.colors[i].b = (_sysPalette.colors[color1].b >> 1) + (_sysPalette.colors[color2].b >> 1);
}
setOnScreen();
}
diff --git a/engines/sci/gui/gui_screen.cpp b/engines/sci/gui/gui_screen.cpp
index f9a63c3d81..26a81ef833 100644
--- a/engines/sci/gui/gui_screen.cpp
+++ b/engines/sci/gui/gui_screen.cpp
@@ -222,17 +222,38 @@ void SciGuiScreen::dither() {
byte *screenPtr = _visualScreen;
byte *displayPtr = _displayScreen;
- for (y = 0; y < _height; y++) {
- for (x = 0; x < _width; x++) {
- color = *screenPtr;
- if (color & 0xF0) {
- color ^= color << 4;
- color = ((x^y) & 1) ? color >> 4 : color & 0x0F;
- *screenPtr = color;
- if (!_unditherState)
- *displayPtr = color;
+ if (!_unditherState) {
+ // Do dithering on visual and display-screen
+ for (y = 0; y < _height; y++) {
+ for (x = 0; x < _width; x++) {
+ color = *screenPtr;
+ if (color & 0xF0) {
+ color ^= color << 4;
+ color = ((x^y) & 1) ? color >> 4 : color & 0x0F;
+ *screenPtr = color; *displayPtr = color;
+ }
+ screenPtr++; displayPtr++;
+ }
+ }
+ } else {
+ // Do dithering on visual screen and put decoded but undithered byte onto display-screen
+ for (y = 0; y < _height; y++) {
+ for (x = 0; x < _width; x++) {
+ color = *screenPtr;
+ if (color & 0xF0) {
+ color ^= color << 4;
+ // if decoded color wants do dither with black on left side, we turn it around
+ // otherwise the normal ega color would get used for display
+ if (color & 0xF0) {
+ *displayPtr = color;
+ } else {
+ *displayPtr = color << 4;
+ }
+ color = ((x^y) & 1) ? color >> 4 : color & 0x0F;
+ *screenPtr = color;
+ }
+ screenPtr++; displayPtr++;
}
- screenPtr++; displayPtr++;
}
}
}