aboutsummaryrefslogtreecommitdiff
path: root/engines/hopkins
diff options
context:
space:
mode:
authorPaul Gilbert2012-09-20 23:30:28 +1000
committerPaul Gilbert2012-09-20 23:30:28 +1000
commit391e3da119b7cf7be8a9422e8fe390a2b5e55398 (patch)
tree5f917511baf437f89fa79fc26145e785643618be /engines/hopkins
parent0ef0ff60993533c58ffec0c02d8c1742b92cc914 (diff)
downloadscummvm-rg350-391e3da119b7cf7be8a9422e8fe390a2b5e55398.tar.gz
scummvm-rg350-391e3da119b7cf7be8a9422e8fe390a2b5e55398.tar.bz2
scummvm-rg350-391e3da119b7cf7be8a9422e8fe390a2b5e55398.zip
HOPKINS: Implemented Affiche_Segment_Vesa and support methods
Diffstat (limited to 'engines/hopkins')
-rw-r--r--engines/hopkins/graphics.cpp168
-rw-r--r--engines/hopkins/graphics.h4
2 files changed, 170 insertions, 2 deletions
diff --git a/engines/hopkins/graphics.cpp b/engines/hopkins/graphics.cpp
index 3785b6ff45..1a22ff42ce 100644
--- a/engines/hopkins/graphics.cpp
+++ b/engines/hopkins/graphics.cpp
@@ -66,6 +66,7 @@ GraphicsManager::GraphicsManager() {
clip_x = clip_y = 0;
clip_x1 = clip_y1 = 0;
clip_flag = false;
+ SDL_NBLOCS = 0;
Common::fill(&SD_PIXELS[0], &SD_PIXELS[PALETTE_SIZE * 2], 0);
Common::fill(&TABLE_COUL[0], &TABLE_COUL[PALETTE_SIZE], 0);
@@ -672,6 +673,99 @@ void GraphicsManager::m_scroll16A(const byte *surface, int xs, int ys, int width
} while (v13 != 1);
}
+void GraphicsManager::Copy_Vga(const byte *surface, int xp, int yp, int width, int height, int destX, int destY) {
+ const byte *v7;
+ byte *v8;
+ int v9;
+ int v10;
+ byte v11;
+ byte *v12;
+ byte *v13;
+ byte *v14;
+ byte *v15;
+ const byte *v16;
+ int v17;
+
+ assert(VideoPtr);
+ v7 = xp + 320 * yp + surface;
+ v8 = 30 * WinScan + destX + destX + WinScan * 2 * destY + (byte *)VideoPtr->pixels;
+ v9 = height;
+
+ do {
+ v17 = v9;
+ v10 = width;
+ v16 = v7;
+ v15 = v8;
+ do {
+ v11 = *v7;
+ *v8 = *v7;
+ v12 = WinScan + v8;
+ *v12 = v11;
+ v13 = v12 - WinScan + 1;
+ *v13 = v11;
+ v14 = WinScan + v13;
+ *v14 = v11;
+ ++v7;
+ v8 = v14 - WinScan + 1;
+ --v10;
+ } while (v10);
+
+ v8 = WinScan + WinScan + v15;
+ v7 = v16 + 320;
+ v9 = v17 - 1;
+ } while (v17 != 1);
+}
+
+void GraphicsManager::Copy_Vga16(const byte *surface, int xp, int yp, int width, int height, int destX, int destY) {
+ const byte *v7;
+ uint16 *v8;
+ int v9;
+ int v10;
+ int v11;
+ const byte *v12;
+ uint16 *v13;
+ uint16 v14;
+ uint16 *v15;
+ int v16;
+ uint16 *v17;
+ const byte *v18;
+ int v19;
+
+ assert(VideoPtr);
+ v7 = xp + 320 * yp + surface;
+ v8 = (uint16 *)(30 * WinScan + destX + destX + destX + destX + WinScan * 2 * destY + (byte *)VideoPtr->pixels);
+ v9 = height;
+ v10 = width;
+
+ do {
+ v19 = v9;
+ v11 = v10;
+ v18 = v7;
+ v17 = v8;
+ v16 = v10;
+ v12 = PAL_PIXELS;
+
+ do {
+ v13 = (uint16 *)(v12 + 2 * *v7);
+ v14 = *v13;
+ *v8 = *v13;
+ *(v8 + 1) = v14;
+
+ v15 = (uint16 *)((byte *)v8 + WinScan);
+ *v15 = v14;
+ *(v15 + 1) = v14;
+ ++v7;
+ v8 = (uint16 *)((byte *)v15 - WinScan + 4);
+ --v11;
+ } while (v11);
+
+ v10 = v16;
+ v8 = (uint16 *)((byte *)v17 + WinScan * 2);
+ v7 = v18 + 320;
+ v9 = v19 - 1;
+ } while (v19 != 1);
+}
+
void GraphicsManager::fade_in(const byte *palette, int step, const byte *surface) {
uint16 palData1[PALETTE_BLOCK_SIZE * 2];
byte palData2[PALETTE_BLOCK_SIZE];
@@ -1399,7 +1493,79 @@ int GraphicsManager::Magic_Number(signed int v) {
}
void GraphicsManager::Affiche_Segment_Vesa() {
- warning("TODO: Affiche_Segment_Vesa");
+ if (_vm->_globals.NBBLOC == 0)
+ return;
+
+ _vm->_graphicsManager.SDL_NBLOCS = _vm->_globals.NBBLOC;
+
+ for (int idx = 1; idx <= _vm->_globals.NBBLOC; ++idx) {
+ BlocItem &bloc = _vm->_globals.BLOC[idx];
+ Common::Rect &dstRect = dstrect[idx - 1];
+ if (bloc.field0 != 1)
+ continue;
+
+ if (_vm->_eventsManager.CASSE != 0) {
+ if (Winbpp == 1) {
+ Copy_Vga(VESA_BUFFER, bloc.x1, bloc.y1, bloc.x2 - bloc.x1, bloc.y2 - bloc.y1, bloc.x1, bloc.y1);
+ } else if (Winbpp == 2) {
+ Copy_Vga16(VESA_BUFFER, bloc.x1, bloc.y1, bloc.x2 - bloc.x1, bloc.y2 - bloc.y1, bloc.x1, bloc.y1);
+ }
+
+ dstRect.left = bloc.x1 * 2;
+ dstRect.top = bloc.y1 * 2 + 30;
+ dstRect.setWidth((bloc.x2 - bloc.x1) * 2);
+ dstRect.setHeight((bloc.y2 - bloc.y1) * 2);
+ } else if (bloc.x2 > start_x && bloc.x1 < (start_x + SCREEN_WIDTH)) {
+ if (bloc.x1 < start_x)
+ bloc.x1 = start_x;
+ if (bloc.x2 > (start_x + SCREEN_WIDTH))
+ bloc.x2 = start_x + SCREEN_WIDTH;
+
+ if (!SDL_ECHELLE) {
+ // Calculate the bounds
+ int xp = Magic_Number(bloc.x1) - 4;
+ if (xp < start_x)
+ xp = start_x;
+ int yp = Magic_Number(bloc.y1) - 4;
+ if (yp < 0)
+ yp = 0;
+ int width = Magic_Number(bloc.x2) + 4 - xp;
+ if (width < 4)
+ width = 4;
+ int height = Magic_Number(bloc.y2) + 4 - yp;
+ if (height < 4)
+ height = 4;
+
+ if ((xp - start_x + width) > SCREEN_WIDTH)
+ xp -= 4;
+ if ((height - yp) > (SCREEN_HEIGHT - 40))
+ yp -= 4;
+
+ if (Winbpp == 2) {
+ m_scroll16A(VESA_BUFFER, xp, yp, width, height,
+ Reel_Zoom(xp - start_x, SDL_ECHELLE), Reel_Zoom(yp, SDL_ECHELLE));
+ } else {
+ m_scroll2A(VESA_BUFFER, xp, yp, width, height,
+ Reel_Zoom(xp - start_x, SDL_ECHELLE), Reel_Zoom(yp, SDL_ECHELLE));
+ }
+
+ dstRect.left = Reel_Zoom(xp - start_x, SDL_ECHELLE);
+ dstRect.top = Reel_Zoom(yp, SDL_ECHELLE);
+ dstRect.setWidth(Reel_Zoom(width, SDL_ECHELLE));
+ dstRect.setHeight(Reel_Zoom(height, SDL_ECHELLE));
+ } else {
+ if (Winbpp == 2) {
+ m_scroll16(VESA_BUFFER, bloc.x1, bloc.y1, bloc.x2 - bloc.x1, bloc.y2 - bloc.y1,
+ bloc.x1 - start_x, bloc.y1);
+ } else {
+ m_scroll(VESA_BUFFER, bloc.x1, bloc.y1, bloc.x2 - bloc.x1, bloc.y2 - bloc.y1,
+ bloc.x1 - start_x, bloc.y1);
+ }
+ }
+ }
+
+ _vm->_globals.BLOC[idx].field0 = 0;
+ }
}
void GraphicsManager::CopyAsm(const byte *surface) {
diff --git a/engines/hopkins/graphics.h b/engines/hopkins/graphics.h
index d57c7b063a..222ba2edd7 100644
--- a/engines/hopkins/graphics.h
+++ b/engines/hopkins/graphics.h
@@ -91,7 +91,7 @@ public:
int clip_x, clip_y;
int clip_x1, clip_y1;
bool clip_flag;
-
+ int SDL_NBLOCS;
public:
GraphicsManager();
~GraphicsManager();
@@ -116,6 +116,8 @@ public:
void m_scroll2A(const byte *surface, int xs, int ys, int width, int height, int destX, int destY);
void m_scroll16(const byte *surface, int xs, int ys, int width, int height, int destX, int destY);
void m_scroll16A(const byte *surface, int xs, int ys, int width, int height, int destX, int destY);
+ void Copy_Vga(const byte *surface, int xp, int yp, int width, int height, int destX, int destY);
+ void Copy_Vga16(const byte *surface, int xp, int yp, int width, int height, int destX, int destY);
void fade_in(const byte *palette, int step, const byte *surface);
void fade_out(const byte *palette, int step, const byte *surface);
void FADE_INS();