scummvm/engines/dreamweb/monitor.cpp

163 lines
4.1 KiB
C++
Raw Normal View History

/* ScummVM - Graphic Adventure Engine
*
* ScummVM is the legal property of its developers, whose names
* are too numerous to list here. Please refer to the COPYRIGHT
* file distributed with this source distribution.
*
* 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.
*
*/
#include "dreamweb/dreamweb.h"
namespace DreamGen {
struct MonitorKeyEntry {
uint8 b0;
uint8 b1;
char b2[24];
};
void DreamGenContext::usemon() {
data.byte(kLasttrigger) = 0;
memset(cs.ptr(kCurrentfile+1, 0), ' ', 12);
memset(cs.ptr(offset_operand1+1, 0), ' ', 12);
MonitorKeyEntry *monitorKeyEntries = (MonitorKeyEntry *)cs.ptr(offset_keys, 0);
monitorKeyEntries[0].b0 = 1;
monitorKeyEntries[1].b0 = 0;
monitorKeyEntries[2].b0 = 0;
monitorKeyEntries[3].b0 = 0;
createpanel();
showpanel();
showicon();
drawfloor();
getridofall();
loadintotemp("DREAMWEB.G03");
loadpersonal();
loadnews();
loadcart();
loadtempcharset("DREAMWEB.C01");
printoutermon();
initialmoncols();
printlogo();
worktoscreen();
turnonpower();
fadeupyellows();
fadeupmonfirst();
data.word(kMonadx) = 76;
data.word(kMonady) = 141;
al = 1;
monmessage();
hangoncurs(120);
al = 2;
monmessage();
cx = 60;
randomaccess();
al = 3;
monmessage();
hangoncurs(100);
printlogo();
scrollmonitor();
data.word(kBufferin) = 0;
data.word(kBufferout) = 0;
do {
di = data.word(kMonadx);
bx = data.word(kMonady);
push(di);
push(bx);
input();
bx = pop();
di = pop();
data.word(kMonadx) = di;
data.word(kMonady) = bx;
execcommand();
} while (al == 0);
getridoftemp();
getridoftempcharset();
deallocatemem(data.word(kTextfile1));
deallocatemem(data.word(kTextfile2));
deallocatemem(data.word(kTextfile3));
data.byte(kGetback) = 1;
al = 26;
playchannel1();
data.byte(kManisoffscreen) = 0;
restoreall();
redrawmainscrn();
worktoscreenm();
}
void DreamGenContext::printlogo() {
showframe((Frame *)segRef(data.word(kTempgraphics)).ptr(0, 0), 56, 32, 0, 0);
showcurrentfile();
}
2011-11-18 07:48:07 +01:00
void DreamGenContext::input() {
char *inputLine = (char *)cs.ptr(kInputline, 64);
memset(inputLine, 0, 64);
data.word(kCurpos) = 0;
ds = data.word(kTempcharset);
{
uint16 x = data.word(kMonadx);
uint8 width, height;
printchar((Frame *)segRef(data.word(kTempcharset)).ptr(0, 0), &x, data.word(kMonady), '>', 0, &width, &height);
}
multidump(data.word(kMonadx), data.word(kMonady), 6, 8);
data.word(kMonadx) += 6;
data.word(kCurslocx) = data.word(kMonadx);
data.word(kCurslocy) = data.word(kMonady);
while (true) {
printcurs();
vsync();
delcurs();
readkey();
uint8 currentKey = data.byte(kCurrentkey);
if (currentKey == 0)
continue;
if (currentKey == 13)
return;
if (currentKey == 8) {
if (data.word(kCurpos) > 0)
delchar();
continue;
}
if (data.word(kCurpos) == 28)
continue;
if ((currentKey == 32) && (data.word(kCurpos) == 0))
continue;
al = currentKey;
makecaps();
currentKey = al;
inputLine[data.word(kCurpos) * 2 + 0] = currentKey;
if (currentKey > 'Z')
continue;
multiget(segRef(data.word(kMapstore)).ptr(data.word(kCurpos) * 256, 0), data.word(kMonadx), data.word(kMonady), 8, 8);
uint8 charWidth;
{
uint16 x = data.word(kMonadx);
uint8 height;
printchar((Frame *)segRef(data.word(kTempcharset)).ptr(0, 0), &x, data.word(kMonady), currentKey, 0, &charWidth, &height);
}
inputLine[data.word(kCurpos) * 2 + 1] = charWidth;
data.word(kMonadx) += charWidth;
++data.word(kCurpos);
data.word(kCurslocx) += charWidth;
}
}
} /*namespace dreamgen */