aboutsummaryrefslogtreecommitdiff
path: root/engines/dreamweb/print.cpp
diff options
context:
space:
mode:
authorBertrand Augereau2011-08-11 03:19:51 +0200
committerBertrand Augereau2011-08-11 03:19:51 +0200
commit707c6ed01c6f19ec192efe915636f256e12898b0 (patch)
tree4057849e8ebcfca89ded556ffa19644f95b50550 /engines/dreamweb/print.cpp
parentb701deed4f192f29b92fadb50275e2bdb5c39959 (diff)
downloadscummvm-rg350-707c6ed01c6f19ec192efe915636f256e12898b0.tar.gz
scummvm-rg350-707c6ed01c6f19ec192efe915636f256e12898b0.tar.bz2
scummvm-rg350-707c6ed01c6f19ec192efe915636f256e12898b0.zip
DREAMWEB: 'printslow' API improved
Diffstat (limited to 'engines/dreamweb/print.cpp')
-rw-r--r--engines/dreamweb/print.cpp29
1 files changed, 7 insertions, 22 deletions
diff --git a/engines/dreamweb/print.cpp b/engines/dreamweb/print.cpp
index 9e4c416015..3d571f939e 100644
--- a/engines/dreamweb/print.cpp
+++ b/engines/dreamweb/print.cpp
@@ -26,12 +26,6 @@
namespace DreamGen {
-void DreamGenContext::printboth() {
- uint16 x = di;
- printboth((const Frame *)ds.ptr(0, 0), &x, bx, al, ah);
- di = x;
-}
-
void DreamGenContext::printboth(const Frame *charSet, uint16 *x, uint16 y, uint8 c, uint8 nextChar) {
uint16 newX = *x;
uint8 width, height;
@@ -100,28 +94,23 @@ void DreamGenContext::printchar(const Frame *charSet, uint16* x, uint16 y, uint8
}
void DreamGenContext::printslow() {
- al = printslow(di, bx, dl, (bool)(dl & 1));
+ al = printslow(es.ptr(si, 0), di, bx, dl, (bool)(dl & 1));
}
-uint8 DreamGenContext::printslow(uint16 x, uint16 y, uint8 maxWidth, bool centered) {
+uint8 DreamGenContext::printslow(const uint8 *string, uint16 x, uint16 y, uint8 maxWidth, bool centered) {
data.byte(kPointerframe) = 1;
data.byte(kPointermode) = 3;
const Frame* charSet = (const Frame *)segRef(data.word(kCharset1)).ptr(0, 0);
do {
uint16 offset = x;
- uint16 charCount = getnumber(charSet, es.ptr(si, 0), maxWidth, centered, &offset);
+ uint16 charCount = getnumber(charSet, string, maxWidth, centered, &offset);
do {
- push(si);
- push(es);
- uint8 c0 = es.byte(si);
- uint8 c1 = es.byte(si+1);
- uint8 c2 = es.byte(si+2);
+ uint8 c0 = string[0];
+ uint8 c1 = string[1];
+ uint8 c2 = string[2];
c0 = engine->modifyChar(c0);
printboth(charSet, &offset, y, c0, c1);
- ++si;
if ((c1 == 0) || (c1 == ':')) {
- es = pop();
- si = pop();
return 0;
}
if (charCount != 1) {
@@ -135,16 +124,12 @@ uint8 DreamGenContext::printslow(uint16 x, uint16 y, uint8 maxWidth, bool center
if (ax == 0)
continue;
if (ax != data.word(kOldbutton)) {
- es = pop();
- si = pop();
return 1;
}
}
}
- es = pop();
- si = pop();
- ++si;
+ ++string;
--charCount;
} while (charCount);
y += 10;