mirror of
https://github.com/libretro/scummvm.git
synced 2024-12-15 22:28:10 +00:00
ea42bad781
svn-id: r20088
174 lines
4.1 KiB
C++
Executable File
174 lines
4.1 KiB
C++
Executable File
/* ScummVM - Scumm Interpreter
|
|
* Copyright (C) 2001 Ludvig Strigeus
|
|
* Copyright (C) 2001-2006 The ScummVM project
|
|
* Copyright (C) 2002-2005 Chris Apers - PalmOS Backend
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version 2
|
|
* of the License, or (at your option) any later version.
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
*
|
|
* $Header$
|
|
*
|
|
*/
|
|
|
|
#include "be_zodiac.h"
|
|
|
|
void OSystem_PalmZodiac::setMouseCursor(const byte *buf, uint w, uint h, int hotspotX, int hotspotY, byte keycolor, int cursorTargetScale) {
|
|
if (w == 0 || h == 0)
|
|
return;
|
|
|
|
_mouseCurState.w = w;
|
|
_mouseCurState.h = h;
|
|
|
|
_mouseHotspotX = hotspotX;
|
|
_mouseHotspotY = hotspotY;
|
|
|
|
_mouseKeyColor = keycolor;
|
|
|
|
// copy new cursor
|
|
byte *dst = _mouseDataP;
|
|
while (h--) {
|
|
memcpy(dst, buf, w);
|
|
dst += MAX_MOUSE_W;
|
|
buf += w;
|
|
}
|
|
}
|
|
|
|
void OSystem_PalmZodiac::draw_mouse() {
|
|
if (_mouseDrawn || !_mouseVisible)
|
|
return;
|
|
|
|
byte *src = _mouseDataP; // Image representing the mouse
|
|
byte color;
|
|
int width;
|
|
|
|
_mouseCurState.y = _mouseCurState.y >= _screenHeight ? _screenHeight - 1 : _mouseCurState.y;
|
|
|
|
int x = _mouseCurState.x - _mouseHotspotX;
|
|
int y = _mouseCurState.y - _mouseHotspotY;
|
|
int w = _mouseCurState.w;
|
|
int h = _mouseCurState.h;
|
|
|
|
int draw_x = x;
|
|
int draw_y = y;
|
|
|
|
// clip the mouse rect
|
|
if (x < 0) {
|
|
w += x;
|
|
src -= x;
|
|
x = 0;
|
|
}
|
|
if (y < 0) {
|
|
h += y;
|
|
src -= y * MAX_MOUSE_W;
|
|
y = 0;
|
|
}
|
|
if (w > _screenWidth - x)
|
|
w = _screenWidth - x;
|
|
if (h > _screenHeight - y)
|
|
h = _screenHeight - y;
|
|
|
|
// Quick check to see if anything has to be drawn at all
|
|
if (w <= 0 || h <= 0)
|
|
return;
|
|
|
|
// Store the bounding box so that undraw mouse can restore the area the
|
|
// mouse currently covers to its original content.
|
|
_mouseOldState.x = x;
|
|
_mouseOldState.y = y;
|
|
_mouseOldState.w = w;
|
|
_mouseOldState.h = h;
|
|
|
|
// Backup the covered area draw the mouse cursor
|
|
if (_overlayVisible) {
|
|
uint16 *bak = (uint16 *)_mouseBackupP; // Surface used to backup the area obscured by the mouse
|
|
uint16 *dst;
|
|
|
|
TwGfxLockSurface(_overlayP, (void **)&dst);
|
|
dst += y * _screenWidth + x;
|
|
|
|
do {
|
|
width = w;
|
|
do {
|
|
*bak++ = *dst;
|
|
color = *src++;
|
|
if (color != _mouseKeyColor) // transparent, don't draw
|
|
*dst = _nativePal[color];
|
|
dst++;
|
|
} while (--width);
|
|
|
|
src += MAX_MOUSE_W - w;
|
|
bak += MAX_MOUSE_W - w;
|
|
dst += _screenWidth - w;
|
|
} while (--h);
|
|
|
|
TwGfxUnlockSurface(_overlayP, true);
|
|
|
|
} else {
|
|
byte *bak = _mouseBackupP; // Surface used to backup the area obscured by the mouse
|
|
byte *dst =_offScreenP + y * _screenWidth + x; // Surface we are drawing into
|
|
|
|
do {
|
|
width = w;
|
|
do {
|
|
*bak++ = *dst;
|
|
color = *src++;
|
|
if (color != _mouseKeyColor) // transparent, don't draw
|
|
*dst = color;
|
|
dst++;
|
|
} while (--width);
|
|
|
|
src += MAX_MOUSE_W - w;
|
|
bak += MAX_MOUSE_W - w;
|
|
dst += _screenWidth - w;
|
|
} while (--h);
|
|
}
|
|
|
|
_mouseDrawn = true;
|
|
}
|
|
|
|
void OSystem_PalmZodiac::undraw_mouse() {
|
|
if (!_mouseDrawn)
|
|
return;
|
|
|
|
int h = _mouseOldState.h;
|
|
// No need to do clipping here, since draw_mouse() did that already
|
|
if (_overlayVisible) {
|
|
uint16 *bak = (uint16 *)_mouseBackupP;
|
|
uint16 *dst;
|
|
|
|
TwGfxLockSurface(_overlayP, (void **)&dst);
|
|
dst += _mouseOldState.y * _screenWidth + _mouseOldState.x;
|
|
|
|
do {
|
|
memcpy(dst, bak, _mouseOldState.w * 2);
|
|
bak += MAX_MOUSE_W;
|
|
dst += _screenWidth;
|
|
} while (--h);
|
|
|
|
TwGfxUnlockSurface(_overlayP, true);
|
|
|
|
} else {
|
|
byte *dst, *bak = _mouseBackupP;
|
|
dst = _offScreenP + _mouseOldState.y * _screenWidth + _mouseOldState.x;
|
|
|
|
do {
|
|
memcpy(dst, bak, _mouseOldState.w);
|
|
bak += MAX_MOUSE_W;
|
|
dst += _screenWidth;
|
|
} while (--h);
|
|
}
|
|
|
|
_mouseDrawn = false;
|
|
}
|