scummvm/engines/avalanche/scrolls2.cpp

759 lines
19 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.
*
*/
/*
* This code is based on the original source code of Lord Avalot d'Argent version 1.3.
* Copyright (c) 1994-1995 Mike, Mark and Thomas Thurman.
*/
/* SCROLLS The scroll driver. */
#include "avalanche/avalanche.h"
#include "avalanche/scrolls2.h"
#include "avalanche/gyro2.h"
2013-06-25 13:05:04 +02:00
#include "avalanche/logger2.h"
2013-06-25 18:04:52 +02:00
#include "avalanche/enhanced2.h"
2013-06-29 16:36:40 +02:00
#include "avalanche/lucerna2.h"
#include "avalanche/trip6.h"
#include "avalanche/acci2.h"
#include "avalanche/visa2.h"
#include "avalanche/timeout2.h"
2013-07-02 01:10:45 +02:00
#include "avalanche/basher2.h"
#include "common/textconsole.h"
#include "common/file.h"
2013-06-29 16:36:40 +02:00
//#include "avalanche/joystick2.h" - Will be implemented later, if it will be implemented at all...
namespace Avalanche {
Scrolls::Scrolls(AvalancheEngine *vm) {
_vm = vm;
}
void Scrolls::init() {
loadfont();
resetscrolldriver();
}
void Scrolls::state(byte x) { /* Sets "Ready" light to whatever */
byte page_;
if (_vm->_gyro->ledstatus == x)
return; /* Already like that! */
byte color;
switch (x) {
case 0:
color = black;
break; /* Off */
case 1:
case 2:
case 3:
color = green;
break; /* Hit a key */
}
//switch (x) {
//case 0:
// setfillstyle(1, black);
// break; /* Off */
//case 1:
// setfillstyle(9, green);
// break; /* Half-on (menus) */
//case 2:
// setfillstyle(1, green);
// break; /* On (kbd) */
//case 3:
// setfillstyle(6, green);
// break; /* Hit a key */
//}
2013-07-02 01:10:45 +02:00
warning("STUB: Scrolls::state()");
_vm->_gyro->super_off();
_vm->_graphics->drawBar(419, 195, 438, 197, color);
_vm->_gyro->super_on();
_vm->_gyro->ledstatus = x;
}
void Scrolls::easteregg() {
2013-07-02 01:10:45 +02:00
warning("STUB: Scrolls::easteregg()");
}
void Scrolls::say(int16 x, int16 y, Common::String z) { /* Fancy FAST screenwriting */
const byte locol = 2;
byte xx, yy, ox, bit, lz, t;
int16 yp;
bool offset;
byte itw[12][80];
offset = x % 8 == 4;
x = x / 8;
lz = z.size();
ox = 0;
_vm->_logger->log_scrollline();
for (xx = 0; xx < lz; xx++) {
switch (z[xx]) {
case kControlRoman: {
cfont = roman;
_vm->_logger->log_roman();
}
break;
case kControlItalic: {
cfont = italic;
_vm->_logger->log_italic();
}
break;
default: {
for (yy = 0; yy < 12; yy ++)
itw[yy][ox] = ~ch[cfont][z[xx]][yy + 1];
ox++;
_vm->_logger->log_scrollchar(Common::String(z[xx]));
}
}
}
lz = ox;
if (offset) {
/* offsetting routine */
for (yy = 0; yy < 12; yy++) {
bit = 240;
itw[yy][lz] = 255;
for (xx = 0; xx < lz; xx++) {
t = itw[yy][xx];
itw[yy][xx] = bit + t / 16;
bit = t << 4;
}
}
lz++;
}
/*yp = x + y * 80 + (1 - _vm->_gyro->cp) * _vm->_gyro->pagetop;
for (yy = 0; yy < 12; yy++) {
yp += 80;
for (bit = 0; bit <= locol; bit ++) {
port[0x3c4] = 2;
port[0x3ce] = 4;
port[0x3c5] = 1 << bit;
port[0x3cf] = bit;
move(itw[yy], mem[0xa000 * yp], lz);
}
}*/
2013-07-02 01:10:45 +02:00
warning("STUB: Scrolls::say()");
}
2013-06-25 13:05:04 +02:00
/* Here are the procedures that Scroll calls */ /* So they must be... */ /*$F+*/
2013-06-25 13:05:04 +02:00
void Scrolls::normscroll() {
warning("STUB: Scrolls::normscroll()");
}
2013-06-25 13:05:04 +02:00
void Scrolls::dialogue() {
warning("STUB: Scrolls::dialogue()");
}
2013-06-25 13:05:04 +02:00
2013-07-02 01:10:45 +02:00
void Scrolls::store_(byte what, tunetype &played) {
2013-07-02 01:10:45 +02:00
memcpy(played+1, played+2, sizeof(played) - 1);
played[31] = what;
}
2013-06-25 13:05:04 +02:00
bool Scrolls::they_match(tunetype &played) {
byte fv, mistakes;
mistakes = 0;
2013-07-02 01:10:45 +02:00
for (fv = 1; fv <= sizeof(played); fv ++)
if (played[fv] != _vm->_gyro->tune[fv]) {
2013-07-02 01:10:45 +02:00
mistakes += 1;
}
2013-07-02 01:10:45 +02:00
return mistakes < 5;
}
void Scrolls::music_scroll() {
2013-07-02 01:10:45 +02:00
warning("STUB: Scrolls::music_scroll()");
}
/* ThatsAll, so put us back to */ /*$F-*/
void Scrolls::resetscrolldriver() { /* phew */
_vm->_gyro->scrollbells = 0;
2013-07-02 01:10:45 +02:00
cfont = roman;
_vm->_logger->log_epsonroman();
2013-07-02 01:10:45 +02:00
use_icon = 0;
_vm->_gyro->interrogation = 0; /* always reset after a scroll comes up. */
2013-07-02 01:10:45 +02:00
}
void Scrolls::dingdongbell() { /* Pussy's in the well. Who put her in? Little... */
byte fv;
for (fv = 1; fv <= _vm->_gyro->scrollbells; fv ++) _vm->_lucerna->errorled(); /* ring the bell "x" times */
2013-07-02 01:10:45 +02:00
}
void Scrolls::dodgem() { /* This moves the mouse pointer off the scroll so that you can read it. */
_vm->_gyro->xycheck(); /* Mx & my now contain xy pos of mouse */
dodgex = _vm->_gyro->mx;
dodgey = _vm->_gyro->my; /* Store 'em */
_vm->_gyro->hopto(dodgex, _vm->_gyro->underscroll); /* Move the pointer off the scroll. */
2013-07-02 01:10:45 +02:00
}
void Scrolls::undodgem() { /* This is the opposite of Dodgem. It moves the
mouse pointer back, IF you haven't moved it in the meantime. */
_vm->_gyro->xycheck();
if ((_vm->_gyro->mx == dodgex) && (_vm->_gyro->my == _vm->_gyro->underscroll))
2013-07-02 01:10:45 +02:00
/* No change, so restore the pointer's original position. */
_vm->_gyro->hopto(dodgex, dodgey);
2013-07-02 01:10:45 +02:00
}
void Scrolls::geticon(int16 x, int16 y, byte which) {
Common::File f;
byte *p;
if (!f.open("icons.avd")) {
warning("AVALANCHE: Scrolls: File not found: icons.avd");
return;
}
which--;
f.seek(which * 426);
p = new byte[426];
f.read(p, 426);
//putimage(x, y, p, 0);
2013-07-02 01:10:45 +02:00
warning("STUB: Scrolls::geticon()");
delete[] p;
f.close();
2013-07-02 01:10:45 +02:00
}
void Scrolls::block_drop(Common::String fn, int16 xl, int16 yl, int16 y) {
Common::File f;
byte bit;
int16 fv;
uint16 st;
st = (y - 1) * 80 + (40 - xl / 2) + ((1 - _vm->_gyro->cp) * _vm->_gyro->pagetop);
Common::String filename;
filename = filename.format("%s.avd", fn.c_str());
if (!f.open(filename)) {
warning("AVALANCHE: Scrolls: File not found: %s", filename.c_str());
return;
}
/*for (fv = 1; fv <= yl; fv ++)
for (bit = 0; bit <= 3; bit ++) {
port[0x3c4] = 2;
port[0x3ce] = 4;
port[0x3c5] = 1 << bit;
port[0x3cf] = bit;
blockread(f, mem[0xa000 * st + (fv * 80)], xl);
}
bit = getpixel(0, 0);*/
2013-07-02 01:10:45 +02:00
warning("STUB: Scrolls::block_drop()");
f.close();
2013-07-02 01:10:45 +02:00
}
void Scrolls::drawscroll(func2 gotoit) { // This is one of the oldest procs in the game.
byte b, groi;
int16 lx, ly, mx, my, ex, ey;
bool centre;
byte icon_indent = 0;
_vm->_gyro->off_virtual();
//setvisualpage(cp);
//setactivepage(1 - cp);
_vm->_gyro->oncandopageswap = false; /* On can now no longer swap pages. So we can do what we want without its interference! */
_vm->_logger->log_epsonroman(); /* Scrolls always START with Roman. */
lx = 0;
ly = (_vm->_gyro->scrolln + 1) * 6;
for (b = 0; b <= _vm->_gyro->scrolln; b++) {
ex = _vm->_gyro->scroll[b].size() * 8;
if (lx < ex)
lx = ex;
}
mx = 320;
my = 100; // Getmaxx & getmaxy div 2, both.
lx = lx / 2;
ly -= 2;
if ((1 <= use_icon) && (use_icon <= 34))
lx += halficonwidth;
_vm->_gyro->off();
/* mblit(mx-lx-46,my-ly-6,mx+lx+15,my+ly+6,0,3);*/
/*setfillstyle(1, 7);
setcolor(7);
pieslice(mx + lx, my - ly, 360, 90, 15);
pieslice(mx + lx, my + ly, 270, 360, 15);
setcolor(4);
arc(mx + lx, my - ly, 360, 90, 15);
arc(mx + lx, my + ly, 270, 360, 15);*/
_vm->_graphics->drawBar(mx - lx - 30, my + ly, mx + lx, my + ly + 6, lightgray);
_vm->_graphics->drawBar(mx - lx - 30, my - ly - 6, mx + lx, my - ly, lightgray);
_vm->_graphics->drawBar(mx - lx - 15, my - ly, mx + lx + 15, my + ly, lightgray);
/*setfillstyle(1, 8);
pieslice(mx - lx - 31, my - ly, 360, 180, 15);
pieslice(mx - lx - 31, my + ly, 180, 360, 15);
setfillstyle(1, 4);*/
_vm->_graphics->drawBar(mx - lx - 30, my - ly - 6, mx + lx, my - ly - 5, red);
_vm->_graphics->drawBar(mx - lx - 30, my + ly + 6, mx + lx, my + ly + 7, red);
_vm->_graphics->drawBar(mx - lx - 15, my - ly, mx - lx - 14, my + ly, red);
_vm->_graphics->drawBar(mx + lx + 15, my - ly, mx + lx + 16, my + ly, red);
ex = mx - lx;
ey = my - ly;
mx -= lx;
my -= ly + 2;
//setcolor(0);
centre = false;
switch (use_icon) {
case 0:
icon_indent = 0;
break; /* No icon. */
case 34: {
block_drop("about", 28, 76, 15);
icon_indent = 0;
}
break;
case 35: {
block_drop("gameover", 52, 59, 71);
icon_indent = 0;
}
break;
}
if ((1 <= use_icon) && (use_icon <= 33)) { // Standard icon.
geticon(mx, my + ly / 2, use_icon);
icon_indent = 53;
}
for (b = 0; b <= _vm->_gyro->scrolln; b++) {
switch (_vm->_gyro->scroll[b][_vm->_gyro->scroll[b].size() - 1]) {
case kControlCenter: {
centre = true;
_vm->_gyro->scroll[b].deleteLastChar();
}
break;
case kControlLeftJustified: {
centre = false;
_vm->_gyro->scroll[b].deleteLastChar();
}
break;
case kControlQuestion: {
//settextjustify(1, 1);
dix = mx + lx;
diy = my + ly;
_vm->_gyro->scroll[b].setChar(' ', 0);
groi = *_vm->_graphics->getPixel(0, 0);
// inc(diy,14);
_vm->_gyro->shbox(dix - 65, diy - 24, dix - 5, diy - 10, "Yes.");
_vm->_gyro->shbox(dix + 5, diy - 24, dix + 65, diy - 10, "No.");
}
break;
}
if (centre)
say(320 - _vm->_gyro->scroll[b].size() * 4 + icon_indent, my, _vm->_gyro->scroll[b]);
else
say(mx + icon_indent, my, _vm->_gyro->scroll[b]);
_vm->_logger->log_scrollendline(centre);
my += 12;
}
_vm->_gyro->underscroll = my + 3;
//setvisualpage(1 - cp);
dingdongbell();
//my = getpixel(0, 0);
_vm->_gyro->dropsok = false;
dodgem();
(this->*gotoit)();
undodgem();
_vm->_gyro->dropsok = true;
_vm->_logger->log_divider();
//setvisualpage(cp);
//mousepage(cp);
_vm->_gyro->off();
/* mblit(ex-46,ey-6,ex+lx*2+15,ey+ly*2+6,3,0);*/
//mblit((ex - 46) / 8, ey - 6, 1 + (ex + lx * 2 + 15) / 8, ey + ly * 2 + 6, cp, 1 - cp);
//blitfix();
_vm->_gyro->oncandopageswap = true; // Normality again.
_vm->_gyro->on();
//settextjustify(0, 0); /*sink*/
resetscrolldriver();
if (_vm->_gyro->mpress > 0)
_vm->_gyro->after_the_scroll = true;
2013-07-02 01:10:45 +02:00
warning("STUB: Scrolls::drawscroll()");
}
void Scrolls::bubble(func2 gotoit) {
warning("STUB: Scrolls::bubble()");
}
bool Scrolls::ask(Common::String question) {
warning("STUB: Scrolls::ask()");
return true;
}
void Scrolls::resetscroll() {
_vm->_gyro->scrolln = 0;
2013-07-02 01:10:45 +02:00
for (int j = 0; j < 15; j ++)
if (!_vm->_gyro->scroll[j].empty())
_vm->_gyro->scroll[j].clear();
2013-07-02 01:10:45 +02:00
}
void Scrolls::natural() { /* Natural state of bubbles */
_vm->_gyro->talkx = 320;
_vm->_gyro->talky = 200;
_vm->_gyro->talkb = 8;
_vm->_gyro->talkf = 15;
2013-07-02 01:10:45 +02:00
}
Common::String Scrolls::lsd() {
Common::String x;
Common::String lsd_result;
if (_vm->_gyro->dna.pence < 12) {
2013-07-02 01:10:45 +02:00
/* just pence */
x = _vm->_gyro->strf(_vm->_gyro->dna.pence) + 'd';
} else if (_vm->_gyro->dna.pence < 240) {
2013-07-02 01:10:45 +02:00
/* shillings & pence */
x = _vm->_gyro->strf(_vm->_gyro->dna.pence / int32(12)) + '/';
if ((_vm->_gyro->dna.pence % int32(12)) == 0) x = x + '-';
else x = x + _vm->_gyro->strf(_vm->_gyro->dna.pence % int32(12));
2013-07-02 01:10:45 +02:00
} else /* L, s & d */
x = Common::String('<EFBFBD>') + _vm->_gyro->strf(_vm->_gyro->dna.pence / int32(240)) + '.' + _vm->_gyro->strf((_vm->_gyro->dna.pence / int32(12)) % int32(20))
+ '.' + _vm->_gyro->strf(_vm->_gyro->dna.pence % int32(12));
if (_vm->_gyro->dna.pence > 12) x = x + " (that's " + _vm->_gyro->strf(_vm->_gyro->dna.pence) + "d)";
2013-07-02 01:10:45 +02:00
lsd_result = x;
return lsd_result;
}
void Scrolls::strip(Common::String &q) {
while (q[q.size() - 1] == ' ') {
q.deleteLastChar();
}
2013-07-02 01:10:45 +02:00
}
void Scrolls::solidify(byte n) {
if (!_vm->_gyro->scroll[n].contains(' '))
return; // No spaces.
// So there MUST be a space there, somewhere...
do {
_vm->_gyro->scroll[n + 1] = _vm->_gyro->scroll[n][_vm->_gyro->scroll[n].size() - 1] + _vm->_gyro->scroll[n + 1];
_vm->_gyro->scroll[n].deleteLastChar();
} while (_vm->_gyro->scroll[n][_vm->_gyro->scroll[n].size() - 1] != ' ');
strip(_vm->_gyro->scroll[n]);
2013-07-02 01:10:45 +02:00
}
void Scrolls::calldrivers() {
uint16 fv;
byte nn;
char nnn;
bool mouthnext;
bool call_spriterun; // Only call sprite_run the FIRST time.
bool was_virtual; // Was the mouse cursor virtual on entry to this proc?
//nosound();
2013-07-02 01:10:45 +02:00
warning("STUB: Scrolls::calldrivers()");
state(0);
_vm->_gyro->screturn = false;
mouthnext = false;
call_spriterun = true;
switch (_vm->_gyro->buffer[_vm->_gyro->bufsize - 1]) {
case kControlToBuffer:
_vm->_gyro->bufsize--;
break; // ^D = (D)on't include pagebreak
case kControlSpeechBubble:
case kControlQuestion:
break; // ^B = speech (B)ubble, ^Q = (Q)uestion in dialogue box
default: {
_vm->_gyro->bufsize++;
_vm->_gyro->buffer[_vm->_gyro->bufsize - 1] = kControlParagraph;
}
}
for (fv = 0; fv < _vm->_gyro->bufsize; fv++)
if (mouthnext) {
if (_vm->_gyro->buffer[fv] == kControlRegister)
param = 0;
else
if (('0' < _vm->_gyro->buffer[fv]) && (_vm->_gyro->buffer[fv] < '9'))
param = _vm->_gyro->buffer[fv] - 48;
else if (('A' < _vm->_gyro->buffer[fv]) && (_vm->_gyro->buffer[fv] < 'Z'))
param = _vm->_gyro->buffer[fv] - 55;
mouthnext = false;
} else
switch (_vm->_gyro->buffer[fv]) {
case kControlParagraph: {
if ((_vm->_gyro->scrolln == 0) && (_vm->_gyro->scroll[0].empty()))
break;
if (call_spriterun)
_vm->_lucerna->sprite_run();
call_spriterun = false;
was_virtual = _vm->_gyro->visible == _vm->_gyro->m_virtual;
if (was_virtual)
_vm->_gyro->off_virtual();
drawscroll(&Avalanche::Scrolls::normscroll);
if (was_virtual)
_vm->_gyro->on_virtual();
resetscroll();
if (_vm->_gyro->screturn)
return;
}
break;
case kControlBell:
_vm->_gyro->scrollbells++;
break; // #7 = "Bel"
case kControlSpeechBubble: {
if ((_vm->_gyro->scrolln == 0) && (_vm->_gyro->scroll[0].empty()))
break;
if (call_spriterun)
_vm->_lucerna->sprite_run();
call_spriterun = false;
if (param == 0)
natural();
else if ((1 <= param) && (param <= 9))
if ((param > _vm->_trip->numtr) || (!_vm->_trip->tr[param].quick)) { // Not valid.
_vm->_lucerna->errorled();
natural();
} else
_vm->_trip->tr[param].chatter(); // Normal sprite talking routine.
else if ((10 <= param) && (param <= 36)) {
/* Quasi-peds. (This routine performs the same
thing with QPs as triptype.chatter does with the
sprites.) */
_vm->_gyro->talkx = _vm->_gyro->peds[_vm->_gyro->quasipeds[param].whichped].x;
_vm->_gyro->talky = _vm->_gyro->peds[_vm->_gyro->quasipeds[param].whichped].y; // Position.
_vm->_gyro->talkf = _vm->_gyro->quasipeds[param].fgc;
_vm->_gyro->talkb = _vm->_gyro->quasipeds[param].bgc; // Colours.
} else {
_vm->_lucerna->errorled(); // Not valid.
natural();
}
was_virtual = _vm->_gyro->visible == _vm->_gyro->m_virtual;
if (was_virtual)
_vm->_gyro->off_virtual();
bubble(&Avalanche::Scrolls::normscroll);
if (was_virtual)
_vm->_gyro->on_virtual();
resetscroll();
if (_vm->_gyro->screturn)
return;
}
break;
case kControlNegative: {
switch (param) {
case 1:
display(lsd() + kControlToBuffer);
break; /* insert cash balance (recursion) */
case 2:
display(_vm->_acci->words[_vm->_acci->first_password + _vm->_gyro->dna.pass_num].w + kControlToBuffer);
break;
case 3:
display(_vm->_gyro->dna.like2drink + kControlToBuffer);
break;
case 4:
display(_vm->_gyro->dna.favourite_song + kControlToBuffer);
break;
case 5:
display(_vm->_gyro->dna.worst_place_on_earth + kControlToBuffer);
break;
case 6:
display(_vm->_gyro->dna.spare_evening + kControlToBuffer);
break;
case 9:
display(_vm->_gyro->strf(_vm->_gyro->dna.cat_x) + ',' + _vm->_gyro->strf(_vm->_gyro->dna.cat_y) + kControlToBuffer);
break;
case 10:
switch (_vm->_gyro->dna.box_contents) {
case 0: { // Sixpence.
_vm->_visa->dixi('q', 37); // You find the sixpence.
_vm->_gyro->dna.pence += 6;
_vm->_gyro->dna.box_contents = _vm->_acci->nowt;
_vm->_lucerna->points(2);
return;
}
break;
case _vm->_acci->nowt:
display("nothing at all. It's completely empty.");
break;
default:
display(_vm->_gyro->get_better(_vm->_gyro->dna.box_contents) + '.');
}
break;
case 11: {
nn = 1;
for (nnn = 0; nnn < numobjs; nnn++)
if (_vm->_gyro->dna.obj[nnn]) {
nn ++;
display(_vm->_gyro->get_better(nnn) + ", " + kControlToBuffer);
}
}
break;
}
}
break;
case kControlIcon:
use_icon = param;
break;
case kControlNewLine:
_vm->_gyro->scrolln++;
break;
case kControlQuestion: {
if (call_spriterun)
_vm->_lucerna->sprite_run();
call_spriterun = false;
_vm->_gyro->scrolln++;
_vm->_gyro->scroll[_vm->_gyro->scrolln] = kControlQuestion;
was_virtual = _vm->_gyro->visible == _vm->_gyro->m_virtual;
if (was_virtual)
_vm->_gyro->off_virtual();
drawscroll(&Avalanche::Scrolls::dialogue);
if (was_virtual)
_vm->_gyro->on_virtual();
resetscroll();
}
break;
case kControlRegister:
mouthnext = true;
break;
case kControlInsertSpaces:
for (nn = 0; nn < 9; nn++) _vm->_gyro->scroll[_vm->_gyro->scrolln] = _vm->_gyro->scroll[_vm->_gyro->scrolln] + ' ';
break;
default: { // Add new char.
if (_vm->_gyro->scroll[_vm->_gyro->scrolln].size() == 50) {
solidify(_vm->_gyro->scrolln);
_vm->_gyro->scrolln++;
}
_vm->_gyro->scroll[_vm->_gyro->scrolln] += _vm->_gyro->buffer[fv];
}
}
2013-07-02 01:10:45 +02:00
}
void Scrolls::display(Common::String z) { // TODO: REPLACE BUFFER WITH A STRING!!!!!!!!!!
_vm->_gyro->bufsize = z.size();
memcpy(_vm->_gyro->buffer, z.c_str(), _vm->_gyro->bufsize);
2013-07-02 01:10:45 +02:00
calldrivers();
}
void Scrolls::loadfont() {
Common::File f;
if (!f.open("avalot.fnt")) {
warning("AVALANCHE: Scrolls: File not found: avalot.fnt");
return;
}
for (int16 i = 0; i < 256; i++)
f.read(ch[0][i],16);
f.close();
if (!f.open("avitalic.fnt")) {
warning("AVALANCHE: Scrolls: File not found: avitalic.fnt");
return;
}
for (int16 i = 0; i < 256; i++)
f.read(ch[1][i],16);
f.close();
if (!f.open("ttsmall.fnt")) {
warning("AVALANCHE: Scrolls: File not found: ttsmall.fnt");
return;
}
for (int16 i = 0; i < 256; i++)
f.read(_vm->_gyro->characters[i],16);
f.close();
2013-07-02 01:10:45 +02:00
}
void Scrolls::okay() {
display("Okay!");
}
void Scrolls::musical_scroll() {
bool was_virtual;
2013-07-02 01:10:45 +02:00
display(Common::String("To play the harp...\r\rUse these keys:\r\n") +
"Q W E R T Y U I O P [ ]\r\rOr press Enter to stop playing.\4");
_vm->_lucerna->sprite_run();
was_virtual = _vm->_gyro->visible == _vm->_gyro->m_virtual;
2013-07-02 01:10:45 +02:00
if (was_virtual)
_vm->_gyro->off_virtual();
2013-06-25 13:05:04 +02:00
2013-07-02 01:10:45 +02:00
drawscroll(&Avalanche::Scrolls::music_scroll);
2013-06-25 13:05:04 +02:00
2013-07-02 01:10:45 +02:00
if (was_virtual)
_vm->_gyro->on_virtual();
2013-07-02 01:10:45 +02:00
resetscroll();
}
2013-06-25 13:05:04 +02:00
} // End of namespace Avalanche