Paper Mario DX
Paper Mario (N64) modding
 
Loading...
Searching...
No Matches
msg.c File Reference

Go to the source code of this file.

Macros

#define MSG_ROM_START   0x1B83000
 
#define CHOICE_POINTER_MOVE_RATE   6.0
 
#define CHAR_SPACE_MULTIPLIER   0.6
 

Typedefs

typedef MessageImageDataMessageImageDataList[1]
 

Enumerations

enum  RewindArrowStates {
  REWIND_ARROW_STATE_INIT = 0 , REWIND_ARROW_STATE_GROW = 1 , REWIND_ARROW_STATE_NEUTRAL = 2 , REWIND_ARROW_STATE_CHANGE_COLOR = 3 ,
  REWIND_ARROW_STATE_CHANGE_COLOR_BACK = 4
}
 

Functions

s32 draw_image_with_clipping (IMG_PTR raster, s32 width, s32 height, s32 fmt, s32 bitDepth, s16 posX, s16 posY, u16 clipULx, u16 clipULy, u16 clipLRx, u16 clipRLy)
 
s32 _update_message (MessagePrintState *printer)
 
void msg_copy_to_print_buffer (MessagePrintState *printer, s32 arg1, s32 arg2)
 
void initialize_printer (MessagePrintState *printer, s32 arg1, s32 arg2)
 
MessagePrintState_msg_get_printer_for_msg (s32 msgID, s32 *donePrintingWriteback, s32 arg2)
 
void msg_update_rewind_arrow (s32)
 
void msg_draw_rewind_arrow (s32)
 
void msg_draw_choice_pointer (MessagePrintState *printer)
 
void draw_message_window (MessagePrintState *printer)
 
void appendGfx_message (MessagePrintState *, s16, s16, u16, u16, u16, u8)
 
void clear_character_set (void)
 
void clear_printers (void)
 
void load_font_data (Addr offset, u16 size, void *dest)
 
void load_font (s32 font)
 
void update_messages (void)
 
void render_messages (void)
 
void msg_play_speech_sound (MessagePrintState *printer, u8 character)
 
void dma_load_msg (u32 msgID, void *dest)
 
s8load_message_to_buffer (s32 msgID)
 
MessagePrintStatemsg_get_printer_for_msg (s32 msgID, s32 *donePrintingWriteback)
 
s32 msg_printer_load_msg (s32 msgID, MessagePrintState *printer)
 
void msg_printer_set_origin_pos (MessagePrintState *msgPrintState, s32 x, s32 y)
 
s32 cancel_message (MessagePrintState *msgPrintState)
 
void set_message_images (MessageImageData *images)
 
void set_message_text_var (s32 msgID, s32 index)
 
void set_message_int_var (s32 value, s32 index)
 
void close_message (MessagePrintState *msgPrintState)
 
s32 msg_get_print_char_width (s32 character, s32 charset, s32 variation, f32 msgScale, s32 overrideCharWidth, u8 flags)
 
s32 msg_get_draw_char_width (s32 character, s32 charset, s32 variation, f32 msgScale, s32 overrideCharWidth, u16 flags)
 
void get_msg_properties (s32 msgID, s32 *height, s32 *width, s32 *maxLineChars, s32 *numLines, s32 *maxLinesPerPage, s32 *numSpaces, u16 charset)
 
s32 get_msg_width (s32 msgID, u16 charset)
 
s32 get_msg_lines (s32 msgID)
 
void draw_msg (s32 msgID, s32 posX, s32 posY, s32 opacity, s32 palette, u8 style)
 
void draw_digit (IMG_PTR img, s32 charset, s32 posX, s32 posY)
 
void draw_number (s32 value, s32 x, s32 y, s32 charset, s32 palette, s32 opacity, u16 style)
 

Variables

Vp D_8014C280
 
u8 MessagePlural [] = { MSG_CHAR_LOWER_S, MSG_CHAR_READ_END }
 
u8 MessageSingular [] = { MSG_CHAR_READ_ENDL, MSG_CHAR_READ_END }
 
s16 gNextMessageBuffer = 0
 
Vtx gRewindArrowQuad []
 
Gfx D_8014C2D8 []
 
s32 gMsgBGScrollAmtX
 
u16 gMsgGlobalWaveCounter
 
MessageImageDataList gMsgVarImages
 
s32 gMsgBGScrollAmtY
 
u8D_8015131C
 
GfxD_80151338
 
IMG_BIN D_80159B50 [0x200]
 
PAL_BIN D_8015C7E0 [0x10]
 
s16 MsgStyleVerticalLineOffsets []
 
IMG_BIN ui_msg_rewind_arrow_png []
 
PAL_BIN ui_msg_rewind_arrow_pal []
 
IMG_BIN ui_msg_star_png []
 
IMG_BIN ui_msg_star_silhouette_png []
 
IMG_BIN MsgCharImgTitle []
 
IMG_BIN MsgCharImgNormal []
 
MessageCharsetMsgCharsets [5]
 
IMG_BIN MsgCharImgSubtitle []
 
PAL_BIN D_802F4560 [80][8]
 
IMG_BIN ui_point_right_png []
 
PAL_BIN ui_point_right_pal []
 
MessageNumber gMsgNumbers []
 
Gfx gMsgDlistInitDrawNumber []
 
s32 gItemIconRasterOffsets []
 
s32 gItemIconPaletteOffsets []
 
IMG_PTR MsgLetterRasterOffsets []
 
PAL_PTR MsgLetterPaletteOffsets []
 
MsgVoice MsgVoices []
 

Macro Definition Documentation

◆ MSG_ROM_START

#define MSG_ROM_START   0x1B83000

Definition at line 23 of file msg.c.

Referenced by dma_load_msg().

◆ CHOICE_POINTER_MOVE_RATE

#define CHOICE_POINTER_MOVE_RATE   6.0

Definition at line 29 of file msg.c.

Referenced by msg_draw_choice_pointer().

◆ CHAR_SPACE_MULTIPLIER

#define CHAR_SPACE_MULTIPLIER   0.6

Definition at line 1581 of file msg.c.

Referenced by msg_get_draw_char_width(), and msg_get_print_char_width().

Typedef Documentation

◆ MessageImageDataList

typedef MessageImageData* MessageImageDataList[1]

Definition at line 32 of file msg.c.

Enumeration Type Documentation

◆ RewindArrowStates

Enumerator
REWIND_ARROW_STATE_INIT 
REWIND_ARROW_STATE_GROW 
REWIND_ARROW_STATE_NEUTRAL 
REWIND_ARROW_STATE_CHANGE_COLOR 
REWIND_ARROW_STATE_CHANGE_COLOR_BACK 

Definition at line 10 of file msg.c.

10 {
16};
@ REWIND_ARROW_STATE_NEUTRAL
Definition msg.c:13
@ REWIND_ARROW_STATE_INIT
Definition msg.c:11
@ REWIND_ARROW_STATE_CHANGE_COLOR_BACK
Definition msg.c:15
@ REWIND_ARROW_STATE_GROW
Definition msg.c:12
@ REWIND_ARROW_STATE_CHANGE_COLOR
Definition msg.c:14

Function Documentation

◆ draw_image_with_clipping()

s32 draw_image_with_clipping ( IMG_PTR raster,
s32 width,
s32 height,
s32 fmt,
s32 bitDepth,
s16 posX,
s16 posY,
u16 clipULx,
u16 clipULy,
u16 clipLRx,
u16 clipRLy )

Referenced by msg_draw_choice_pointer().

◆ _update_message()

s32 _update_message ( MessagePrintState * printer)

Definition at line 277 of file msg.c.

277 {
278 f32 speechPan;
279 u8 cond;
280 s32 buttons;
283 s32 charsToPrint;
284 s32 i;
285
286 printer->effectFrameCounter++;
287 if (printer->effectFrameCounter >= 3600) {
288 printer->effectFrameCounter = 0;
289 }
290
291 speechPan = (((f32)printer->initOpenPos.x - (SCREEN_WIDTH / 2.0)) / 3.8) + 64.0;
292 if (speechPan < 5.0) {
293 speechPan = 5.0f;
294 } else if (speechPan > 122.0) {
295 speechPan = 122.0f;
296 }
297 printer->speechPan = speechPan;
298
299 cond = FALSE;
300 if (!(printer->stateFlags & MSG_STATE_FLAG_40)) {
301 if (!(printer->stateFlags & (MSG_STATE_FLAG_20 | MSG_STATE_FLAG_10))) {
302 s32 buttons = BUTTON_A;
303
304 switch (printer->windowState) {
306 if (printer->stateFlags & MSG_STATE_FLAG_80000) {
308 }
310 printer->windowState = MSG_WINDOW_STATE_PRINTING;
311 printer->curPrintDelay = 0;
312 printer->stateFlags |= MSG_STATE_FLAG_4;
314 cond = TRUE;
316 } else if (printer->srcBuffer[printer->srcBufferPos] != MSG_CHAR_READ_END) {
318 if (printer->fontVariant != 0 || printer->srcBuffer[printer->srcBufferPos] != MSG_CHAR_UNK_C3) {
320 }
322 } else if (printer->style == MSG_STYLE_RIGHT ||
323 printer->style == MSG_STYLE_LEFT ||
324 printer->style == MSG_STYLE_CENTER ||
325 printer->style == MSG_STYLE_TATTLE)
326 {
328 }
329 } else if ((gGameStatusPtr->pressedButtons[0] & BUTTON_Z) &&
330 !(printer->stateFlags & MSG_STATE_FLAG_40000) &&
331 (printer->curLine != 0))
332 {
333 printer->windowState = MSG_WINDOW_STATE_B;
334 printer->unk_4CC = 0;
335 printer->unkArraySize = printer->curLine - 1;
336 printer->unk_4C8 = abs(printer->curLinePos - printer->lineEndPos[printer->unkArraySize]);
338 }
339 break;
342 printer->windowState = MSG_WINDOW_STATE_B;
343 printer->unk_4CC = 0;
344 printer->unkArraySize = printer->curLine;
345 printer->unk_4C8 = abs(printer->curLinePos - printer->lineEndPos[printer->unkArraySize]);
347 } else if (gGameStatusPtr->pressedButtons[0] & BUTTON_Z) {
348 if (printer->unkArraySize > 0) {
349 printer->windowState = MSG_WINDOW_STATE_B;
350 printer->unk_4CC = 0;
351 printer->unkArraySize--;
352 printer->unk_4C8 = abs(printer->curLinePos - printer->lineEndPos[printer->unkArraySize]);
354 }
355 } else {
357 printer->windowState = MSG_WINDOW_STATE_B;
358 printer->unk_4CC = 0;
359 printer->unkArraySize++;
360 printer->unk_4C8 = abs(printer->curLinePos - printer->lineEndPos[printer->unkArraySize]);
362 }
363 }
364 break;
367 printer->madeChoice = 1;
368 printer->windowState = MSG_WINDOW_STATE_PRINTING;
369 printer->scrollingTime = 0;
370 printer->stateFlags |= MSG_STATE_FLAG_20000;
372 } else if (printer->cancelOption != 0xFF && (gGameStatusPtr->pressedButtons[0] & BUTTON_B)) {
373 if (printer->cancelOption >= printer->maxOption) {
374 printer->selectedOption = printer->curOption;
375 } else {
376 printer->selectedOption = printer->cancelOption;
377 }
378 printer->madeChoice = 1;
379 printer->windowState = MSG_WINDOW_STATE_PRINTING;
380 printer->scrollingTime = 0;
381 printer->curOption = printer->cancelOption;
382 printer->stateFlags |= MSG_STATE_FLAG_20000;
385 if (printer->curOption != printer->maxOption - 1) {
386 printer->targetOption = printer->curOption + 1;
388 printer->scrollingTime = 1;
390 }
391 } else if (gGameStatusPtr->heldButtons[0] & BUTTON_STICK_UP) {
392 if (printer->curOption != 0) {
393 printer->targetOption = printer->curOption - 1;
395 printer->scrollingTime = 1;
397 }
398 }
399
400 if (printer->windowState != MSG_WINDOW_STATE_SCROLLING_BACK) {
401 break;
402 }
404 printer->scrollingTime++;
405 if (printer->scrollingTime >= (s32)(5 * DT)) {
407 printer->curOption = printer->targetOption;
408 printer->selectedOption = printer->curOption;
409 }
410 break;
411 }
412 } else if (!(printer->stateFlags & MSG_STATE_FLAG_20) &&
413 printer->windowState == MSG_WINDOW_STATE_WAITING &&
415 {
416 printer->windowState = MSG_WINDOW_STATE_PRINTING;
417 printer->curPrintDelay = 0;
418 printer->stateFlags |= MSG_STATE_FLAG_4;
419 }
420
421 if (printer->stateFlags & MSG_STATE_FLAG_4 && !(gGameStatusPtr->curButtons[0] & BUTTON_A)) {
422 printer->stateFlags &= ~MSG_STATE_FLAG_4;
423 }
424
425 for (i = 0; i < ARRAY_COUNT(printer->animTimers); i++) {
426 if (printer->animTimers[i] > 0) {
427 printer->animTimers[i]--;
428 }
429 }
430
431 switch (printer->windowState) {
434 if (!(printer->stateFlags & (MSG_STATE_FLAG_20 | MSG_STATE_FLAG_10)) && !cond) {
436
437 }
438 }
439 // fallthrough
441 charsToPrint = printer->charsPerChunk;
442 if (printer->windowState == MSG_WINDOW_STATE_INIT) {
443 printer->windowState = MSG_WINDOW_STATE_PRINTING;
444 printer->curPrintDelay = 0;
445 } else if (printer->stateFlags & MSG_STATE_FLAG_PRINT_QUICKLY) {
446 charsToPrint = 12;
447 printer->curPrintDelay = 0;
448 } else if (!(printer->stateFlags & MSG_STATE_FLAG_4)) {
449 if (!(printer->stateFlags & (MSG_STATE_FLAG_20 | MSG_STATE_FLAG_10)) &&
451 {
452 charsToPrint = 6;
453 printer->curPrintDelay = 0;
454 }
455 }
456 if ((printer->curPrintDelay == 0) || --printer->curPrintDelay == 0) {
458 }
459 break;
462 if (!(printer->stateFlags & (MSG_STATE_FLAG_20 | MSG_STATE_FLAG_10))) {
464 }
465 }
466 printer->curLinePos += printer->windowScrollRate;
467 if ((printer->stateFlags & MSG_STATE_FLAG_PRINT_QUICKLY) ||
468 (!(printer->stateFlags & (MSG_STATE_FLAG_10 | MSG_STATE_FLAG_4)) &&
470 {
471 printer->curLinePos += (s32)(6 / DT);
472 }
473
474 if (printer->curLinePos >= printer->nextLinePos) {
475 printer->windowState = MSG_WINDOW_STATE_PRINTING;
476 printer->curLinePos = printer->nextLinePos;
477 printer->stateFlags |= MSG_STATE_FLAG_4;
478
479 if (printer->style == MSG_STYLE_SIGN ||
480 printer->style == MSG_STYLE_LAMPPOST ||
481 printer->srcBuffer[printer->srcBufferPos] == MSG_CHAR_READ_WAIT)
482 {
483 printer->curPrintDelay = 0;
484 } else {
485 printer->curPrintDelay = 5;
486 }
487 printer->lineEndPos[printer->curLine] = printer->curLinePos;
488 }
489 break;
491 printer->unk_4CC++;
492 endPosDist = abs(printer->curLinePos - printer->lineEndPos[printer->unkArraySize]);
493 lineIncAmt = 2;
494
495 if (printer->unk_4C8 <= 16) {
496 if (endPosDist >= 15) {
497 lineIncAmt = 4;
498 } else if (endPosDist >= 9) {
499 lineIncAmt = 3;
500 }
501 } else if (endPosDist > 96) {
502 lineIncAmt = 10;
503 } else if (endPosDist > 48) {
504 lineIncAmt = 9;
505 } else if (endPosDist >= 24) {
506 lineIncAmt = 7;
507 } else if (endPosDist >= 16) {
508 lineIncAmt = 5;
509 } else if (endPosDist >= 8) {
510 lineIncAmt = 4;
511 } else if (endPosDist > 4) {
512 lineIncAmt = 3;
513 }
514
515 printer->unk_4CA = lineIncAmt;
516
517 if (printer->lineEndPos[printer->unkArraySize] < printer->curLinePos) {
518 printer->curLinePos -= printer->unk_4CA;
519 if (printer->lineEndPos[printer->unkArraySize] >= printer->curLinePos) {
520 printer->curLinePos = printer->lineEndPos[printer->unkArraySize];
521 printer->windowState = MSG_WINDOW_STATE_C;
522 }
523 } else {
524 printer->curLinePos += printer->unk_4CA;
525 if (printer->curLinePos >= printer->lineEndPos[printer->unkArraySize]) {
526 printer->curLinePos = printer->lineEndPos[printer->unkArraySize];
527 printer->windowState = MSG_WINDOW_STATE_C;
528 if (printer->unkArraySize == printer->curLine) {
529 printer->windowState = MSG_WINDOW_STATE_WAITING;
530 printer->rewindArrowAnimState = REWIND_ARROW_STATE_INIT;
531 printer->rewindArrowCounter = 0;
532 }
533 }
534 }
535 break;
546 break;
547 }
548 }
549
550 if (printer->stateFlags & MSG_STATE_FLAG_1) {
551 printer->windowState = MSG_WINDOW_STATE_DONE;
552 printer->stateFlags = 0;
553 if (printer->letterBackgroundImg != NULL) {
554 general_heap_free(printer->letterBackgroundImg);
555 }
556 if (printer->letterBackgroundPal != NULL) {
557 general_heap_free(printer->letterBackgroundPal);
558 }
559 if (printer->letterContentImg != NULL) {
560 general_heap_free(printer->letterContentImg);
561 }
562 if (printer->letterContentPal != NULL) {
563 general_heap_free(printer->letterContentPal);
564 }
565 if (printer->closedWritebackBool != NULL) {
566 *printer->closedWritebackBool = TRUE;
567 printer->closedWritebackBool = NULL;
568 }
569 }
570
571 return printer->windowState;
572}
BSS s32 PopupMenu_SelectedIndex
u32 pressedButtons[4]
@ MSG_STATE_FLAG_4
Definition enums.h:6240
@ MSG_STATE_FLAG_40
Definition enums.h:6243
@ MSG_STATE_FLAG_PRINT_QUICKLY
Definition enums.h:6245
@ MSG_STATE_FLAG_1
Definition enums.h:6238
@ MSG_STATE_FLAG_80000
Definition enums.h:6254
@ MSG_STATE_FLAG_10
Definition enums.h:6241
@ MSG_STATE_FLAG_20
Definition enums.h:6242
@ MSG_STATE_FLAG_20000
Definition enums.h:6252
@ MSG_STATE_FLAG_40000
Definition enums.h:6253
@ MSG_STATE_FLAG_SPEAKING
Definition enums.h:6244
@ BUTTON_A
Definition enums.h:2790
@ BUTTON_C_DOWN
Definition enums.h:2779
@ BUTTON_STICK_UP
Definition enums.h:2791
@ BUTTON_STICK_DOWN
Definition enums.h:2792
@ BUTTON_B
Definition enums.h:2789
@ BUTTON_Z
Definition enums.h:2788
@ MSG_STYLE_CENTER
Definition enums.h:6198
@ MSG_STYLE_LEFT
Definition enums.h:6197
@ MSG_STYLE_SIGN
Definition enums.h:6202
@ MSG_STYLE_LAMPPOST
Definition enums.h:6203
@ MSG_STYLE_RIGHT
Definition enums.h:6196
@ MSG_STYLE_TATTLE
Definition enums.h:6199
@ SOUND_MSG_REWIND
Definition enums.h:704
@ SOUND_MENU_BACK
Definition enums.h:701
@ SOUND_MSG_UNREWIND
Definition enums.h:705
@ SOUND_MENU_CHANGE_SELECTION
Definition enums.h:698
@ SOUND_MSG_SKIP
Definition enums.h:703
@ SOUND_MENU_NEXT
Definition enums.h:700
@ MSG_CHAR_READ_WAIT
Definition enums.h:6043
@ MSG_CHAR_UNK_C3
Definition enums.h:6033
@ MSG_CHAR_READ_END
Definition enums.h:6055
@ MSG_WINDOW_STATE_DONE
Definition enums.h:6266
@ MSG_WINDOW_STATE_B
Definition enums.h:6277
@ MSG_WINDOW_STATE_WAITING
Definition enums.h:6271
@ MSG_WINDOW_STATE_WAITING_FOR_CHOICE
Definition enums.h:6273
@ MSG_WINDOW_STATE_INIT
Definition enums.h:6267
@ MSG_WINDOW_STATE_OPENING
Definition enums.h:6268
@ MSG_WINDOW_STATE_SCROLLING
Definition enums.h:6272
@ MSG_WINDOW_STATE_PRINTING
Definition enums.h:6270
@ MSG_WINDOW_STATE_C
Definition enums.h:6278
@ MSG_WINDOW_STATE_E
Definition enums.h:6280
@ MSG_WINDOW_STATE_SCROLLING_BACK
Definition enums.h:6274
@ MSG_WINDOW_STATE_D
Definition enums.h:6279
@ MSG_WINDOW_STATE_CLOSING
Definition enums.h:6269
@ MSG_WINDOW_STATE_VIEWING_PREV
Definition enums.h:6275
@ MSG_WINDOW_STATE_A
Definition enums.h:6276
s32 general_heap_free(void *data)
Definition heap.c:18
void msg_copy_to_print_buffer(MessagePrintState *printer, s32 arg1, s32 arg2)
Definition msg.c:648
void sfx_play_sound_with_params(s32 soundID, u8 volume, u8 pan, s16 pitchShift)
Definition sfx.c:458
#define SCREEN_WIDTH
Definition macros.h:109
#define ARRAY_COUNT(arr)
Definition macros.h:40
#define DT
Definition macros.h:526
GameStatus * gGameStatusPtr
Definition main_loop.c:31

Referenced by update_messages().

◆ msg_copy_to_print_buffer()

void msg_copy_to_print_buffer ( MessagePrintState * printer,
s32 arg1,
s32 arg2 )

Definition at line 648 of file msg.c.

648 {
649 u8 arg;
650 u8 argQ;
651 u8 argW;
652 u8 argE;
653 u8 sp10[4];
654 s32 addr;
655 s16 offset;
656 s32 i;
657 u8* romAddr;
658 u8* romEnd;
659 s32 temp;
660 void* a2;
661 s8 s8 = arg2 & 1;
662 u8* printBuf = &printer->printBuffer[printer->printBufferPos];
663 u8* srcBuf = &printer->srcBuffer[printer->srcBufferPos];
664
665 do {
666 u8 c = *srcBuf++; // a1
667 u8 nextArg = *srcBuf; // a2
668 switch (c) {
671 printer->lineCount += (u8)printer->sizeScale;
672 break;
674 printer->windowState = MSG_WINDOW_STATE_WAITING;
675 printer->delayFlags |= MSG_DELAY_FLAG_1;
676 printer->delayFlags &= ~MSG_DELAY_FLAG_2;
677 printer->rewindArrowAnimState = REWIND_ARROW_STATE_INIT;
678 printer->rewindArrowCounter = 0;
679 printer->stateFlags &= ~MSG_STATE_FLAG_SPEAKING;
681 if (printer->style != MSG_STYLE_F) {
683 }
684 break;
686 printer->curPrintDelay = *srcBuf++;
687 printer->delayFlags |= MSG_DELAY_FLAG_1;
688 printer->stateFlags &= ~MSG_STATE_FLAG_SPEAKING;
689 break;
695 printer->fontVariant = c + 13;
696 break;
699 break;
702 break;
705 break;
708 arg1--;
709 break;
711 if (printer->lineCount != 0) {
712 printer->lineEndPos[printer->curLine] = printer->curLinePos;
713 printer->curLine++;
715 printer->nextLinePos = printer->curLinePos + (MsgCharsets[printer->font]->newLineY
716#if !VERSION_JP
718#endif
719 ) * printer->lineCount;
720 printer->windowState = MSG_WINDOW_STATE_SCROLLING;
721 printer->delayFlags |= MSG_DELAY_FLAG_1;
722 }
723 printer->lineCount = 0;
724 break;
727 arg = *srcBuf++;
728 printer->style = arg;
729 *printBuf++ = arg;
730 printer->fadeInCounter = 0;
731 switch (arg) {
732 case MSG_STYLE_RIGHT:
733 case MSG_STYLE_LEFT:
734 case MSG_STYLE_CENTER:
735 case MSG_STYLE_TATTLE:
737 printer->maxLinesPerPage = 3;
738 }
739 printer->delayFlags |= MSG_DELAY_FLAG_1;
741 if (nextArg != MSG_CHAR_UNK_C3) {
742 printer->stateFlags |= MSG_STATE_FLAG_SPEAKING;
743 }
744 printer->speechSoundIDA = SOUND_MSG_VOICE_1A;
745 printer->speechSoundIDB = SOUND_MSG_VOICE_1B;
746 printer->windowState = MSG_WINDOW_STATE_OPENING;
747 break;
748 case MSG_STYLE_CHOICE:
749 printer->windowBasePos.x = *srcBuf++;
750 printer->windowBasePos.y = *srcBuf++;
751 printer->windowSize.x = *srcBuf++;
752 printer->windowSize.y = *srcBuf++;
753 printer->windowState = MSG_WINDOW_STATE_OPENING;
754 printer->stateFlags |= MSG_STATE_FLAG_800;
755 break;
758 case MSG_STYLE_F:
759 if (!s8) {
760#if VERSION_JP
761 printer->windowBasePos.x = 40;
762#else
763 printer->windowBasePos.x = 20;
764#endif
765 printer->windowBasePos.y = 28;
766 printer->windowSize.y = 58;
767#if VERSION_JP
768 printer->windowSize.x = 240;
769#else
770 printer->windowSize.x = 280;
771#endif
772 printer->windowState = MSG_WINDOW_STATE_OPENING;
773 printer->stateFlags |= MSG_STATE_FLAG_800;
774 printer->delayFlags |= MSG_DELAY_FLAG_1;
775 if (arg == MSG_STYLE_INSPECT) {
777 }
778 }
779 break;
781 printer->windowBasePos.x = *srcBuf++;
782 printer->windowBasePos.y = *srcBuf++;
783 printer->windowSize.x = *srcBuf++;
784 printer->windowSize.y = *srcBuf++;
786 printer->windowState = MSG_WINDOW_STATE_OPENING;
787 printer->delayFlags |= MSG_DELAY_FLAG_1;
788 printer->stateFlags |= MSG_STATE_FLAG_800;
789 break;
791 printer->windowSize.y = *srcBuf++;
792 // fallthrough
793 case MSG_STYLE_SIGN:
794 if (!s8) {
795 printer->windowState = MSG_WINDOW_STATE_OPENING;
796 printer->stateFlags |= MSG_STATE_FLAG_800;
797 printer->delayFlags |= MSG_DELAY_FLAG_1;
798 }
799 break;
801 arg = *srcBuf++;
802 printer->windowState = MSG_WINDOW_STATE_OPENING;
803 printer->stateFlags |= MSG_STATE_FLAG_800;
804 printer->delayFlags |= MSG_DELAY_FLAG_1;
808 printer->letterBackgroundPal = heap_malloc(0x20);
810 dma_copy(romAddr, romAddr + 0x20, printer->letterBackgroundPal);
814 printer->letterContentPal = heap_malloc(0x200);
816 dma_copy(romAddr, romAddr + 0x200, printer->letterContentPal);
817 break;
818 case MSG_STYLE_POPUP:
819 case MSG_STYLE_B:
820 printer->windowSize.x = printer->msgWidth + 32;
821#if VERSION_JP
822 printer->windowSize.y = 32;
823#else
824 printer->windowSize.y = 40;
825#endif
826 printer->stateFlags |= MSG_STATE_FLAG_8000;
827 if (!s8) {
829 printer->windowState = MSG_WINDOW_STATE_D;
830 printer->delayFlags |= MSG_DELAY_FLAG_1;
831 }
832 break;
834 printer->windowState = MSG_WINDOW_STATE_PRINTING;
835 break;
836 }
837 if ((printer->delayFlags & MSG_DELAY_FLAG_1) && (printer->delayFlags & (MSG_DELAY_FLAG_4 | MSG_DELAY_FLAG_2))) {
838 printer->delayFlags &= ~MSG_DELAY_FLAG_1;
839 }
840 break;
843 if (printer->stateFlags & MSG_STATE_FLAG_800) {
844 if (printer->stateFlags & MSG_STATE_FLAG_1000) {
845 if (printer->closedWritebackBool != NULL) {
846 *printer->closedWritebackBool = TRUE;
847 }
848 }
849 if (printer->style != MSG_STYLE_POPUP && printer->style != MSG_STYLE_B) {
850 printer->windowState = MSG_WINDOW_STATE_CLOSING;
851 } else {
852 printer->windowState = MSG_WINDOW_STATE_E;
853 }
854 printer->fadeOutCounter = 0;
855 } else {
856 printer->stateFlags |= MSG_STATE_FLAG_1;
857 }
858 printer->delayFlags |= MSG_DELAY_FLAG_1;
859 printer->delayFlags &= ~MSG_DELAY_FLAG_2;
860 break;
862 switch (*srcBuf++) {
866 *printBuf++ = printer->font = *srcBuf++;
867 break;
871 *printBuf++ = printer->fontVariant = *srcBuf++;
872 break;
876 *printBuf++ = *srcBuf++;
877 break;
879 printer->stateFlags |= MSG_STATE_FLAG_10;
880 break;
882 printer->stateFlags |= MSG_STATE_FLAG_20;
884 break;
886 printer->stateFlags &= ~MSG_STATE_FLAG_20;
887 break;
891 *printBuf++ = *srcBuf++;
892 break;
894 printer->delayFlags |= MSG_DELAY_FLAG_2;
895 break;
897 printer->delayFlags &= ~MSG_DELAY_FLAG_2;
898 printer->delayFlags |= MSG_DELAY_FLAG_1;
899 break;
901 printer->lineEndPos[printer->curLine] = printer->curLinePos;
902 printer->curLine++;
904 arg = *srcBuf++;
905 printer->nextLinePos = printer->curLinePos + (MsgCharsets[printer->font]->newLineY
906#if !VERSION_JP
908#endif
909 ) * arg;
910 printer->windowState = MSG_WINDOW_STATE_SCROLLING;
911 printer->delayFlags |= MSG_DELAY_FLAG_1;
912 printer->lineCount = 0;
913 break;
914#if !VERSION_IQUE
918 *printBuf++ = *srcBuf++;
919 *printBuf++ = arg = *srcBuf++;
920 printer->sizeScale = (arg >> 4) + (arg & 0xF) * 0.0625f;
921 break;
925 printer->sizeScale = 1.0f;
926 break;
927#endif
929 printer->printDelayTime = *srcBuf++;
930 printer->charsPerChunk = *srcBuf++;
931 break;
935 *printBuf++ = *srcBuf++;
936 *printBuf++ = *srcBuf++;
937 break;
941 *printBuf++ = *srcBuf++;
942 break;
946 *printBuf++ = *srcBuf++;
947 break;
951 *printBuf++ = *srcBuf++;
952 break;
953 case MSG_READ_FUNC_UP:
956 *printBuf++ = *srcBuf++;
957 break;
961 *printBuf++ = *srcBuf++;
962 arg1--;
963 printer->curPrintDelay = printer->printDelayTime;
964 if (arg1 <= 0) {
965 printer->delayFlags |= MSG_DELAY_FLAG_1;
966 }
967 if (printer->delayFlags & (MSG_DELAY_FLAG_4 | MSG_DELAY_FLAG_2)) {
968 printer->delayFlags &= ~MSG_DELAY_FLAG_1;
969 }
970 break;
974 *printBuf++ = *srcBuf++;
975 *printBuf++ = *srcBuf++;
976 *printBuf++ = *srcBuf++;
977 printer->curPrintDelay = printer->printDelayTime;
978 if (--arg1 <= 0) {
979 printer->delayFlags |= MSG_DELAY_FLAG_1;
980 }
981 if (printer->delayFlags & (MSG_DELAY_FLAG_4 | MSG_DELAY_FLAG_2)) {
982 printer->delayFlags &= ~MSG_DELAY_FLAG_1;
983 }
984 break;
988
989 arg = *srcBuf++;
990 argQ = *srcBuf++;
991
992 a2 = D_80159B50;
993 offset = arg << 8 | argQ;
994
997 icon_ROM_START + gItemIconRasterOffsets[offset] + 0x200, a2);
998 romEnd = icon_ROM_START + gItemIconPaletteOffsets[offset] + 0x20;
1000 romEnd, D_8015C7E0);
1001 printer->curPrintDelay = printer->printDelayTime;
1002 if (--arg1 <= 0) {
1003 printer->delayFlags |= MSG_DELAY_FLAG_1;
1004 }
1005 if (printer->delayFlags & (MSG_DELAY_FLAG_4 | MSG_DELAY_FLAG_2)) {
1006 printer->delayFlags &= ~MSG_DELAY_FLAG_1;
1007 }
1008 break;
1010 printer->curImageIndex = *srcBuf++;
1011 arg = *srcBuf++;
1012 argQ = *srcBuf++;
1013 printer->varImageScreenPos.x = arg << 8 | argQ;
1014 printer->varImageScreenPos.y = *srcBuf++;
1015 printer->varImgHasBorder = *srcBuf++;
1016 printer->varImgFinalAlpha = *srcBuf++;
1017 printer->varImgAlphaFadeStep = *srcBuf++;
1018 printer->varImageDisplayState = 0;
1019 printer->varImageFadeTimer = 0;
1020 if (--arg1 <= 0) {
1021 printer->delayFlags |= MSG_DELAY_FLAG_1;
1022 }
1023 if (printer->delayFlags & (MSG_DELAY_FLAG_4 | MSG_DELAY_FLAG_2)) {
1024 printer->delayFlags &= ~MSG_DELAY_FLAG_1;
1025 }
1026 break;
1028 arg = *srcBuf++;
1029 if (arg != 0) {
1030 printer->varImageDisplayState = 2;
1031 printer->varImgAlphaFadeStep = arg;
1032 printer->varImageFadeTimer = 0;
1033 } else {
1034 printer->varImageScreenPos.x = 0;
1035 }
1036 break;
1040 *printBuf++ = *srcBuf++;
1041 *printBuf++ = *srcBuf++;
1042 *printBuf++ = *srcBuf++;
1043 printer->delayFlags |= MSG_DELAY_FLAG_4;
1044 break;
1048 *printBuf++ = *srcBuf++;
1049 *printBuf++ = *srcBuf++;
1050 break;
1054 *printBuf++ = *srcBuf++;
1055 printer->delayFlags &= ~MSG_DELAY_FLAG_4;
1056 if (--arg1 <= 0) {
1057 printer->delayFlags |= MSG_DELAY_FLAG_1;
1058 }
1059 break;
1061 arg = *srcBuf++;
1062 argQ = *srcBuf++;
1063 argW = *srcBuf++;
1064 argE = *srcBuf++;
1065 printer->cursorPosX[arg] = argQ << 8 | argW;
1066 printer->cursorPosY[arg] = argE;
1067 break;
1071 *printBuf++ = *srcBuf++;
1072 break;
1075 printer->maxOption = *srcBuf++;
1076 printer->madeChoice = 0;
1077 printer->curOption = 0;
1078 printer->selectedOption = 0;
1080 printer->delayFlags |= MSG_DELAY_FLAG_1;
1081 break;
1083 printer->cancelOption = *srcBuf++;
1084 break;
1088 *printBuf++ = *srcBuf++;
1089 break;
1093 break;
1096 printer->delayFlags |= MSG_DELAY_FLAG_1;
1097 printer->stateFlags &= ~MSG_STATE_FLAG_SPEAKING;
1099 break;
1103 break;
1107 break;
1111 break;
1115 break;
1119 arg = *srcBuf++;
1120 switch (arg) {
1121 case MSG_FX_SHAKE:
1122 case MSG_FX_WAVE:
1124 case MSG_FX_RAINBOW:
1125 case MSG_FX_GLOBAL_WAVE:
1127 case MSG_FX_RISE_PRINT:
1128 case MSG_FX_GROW_PRINT:
1129 case MSG_FX_SIZE_JITTER:
1130 case MSG_FX_SIZE_WAVE:
1131 case MSG_FX_DROP_SHADOW:
1132 *printBuf++ = arg;
1133 break;
1134 case MSG_FX_STATIC:
1135 case MSG_FX_BLUR:
1136 case MSG_FX_DITHER_FADE:
1137 *printBuf++ = arg;
1138 *printBuf++ = *srcBuf++;
1139 break;
1140 }
1141 break;
1145 *printBuf++ = *srcBuf++;
1146 break;
1147 case MSG_READ_FUNC_VAR:
1148 arg = *srcBuf++;
1149 srcBuf -= 3;
1150 if (printer->varBufferReadPos == 0) {
1151 printer->unk_52A = printer->fontVariant;
1153 }
1154
1155 do {
1156 s32 a0 = 1;
1157 argQ = gMessageMsgVars[arg][printer->varBufferReadPos++];
1158 if (argQ >= MSG_CONTROL_CHAR) {
1159 s32 tmp;
1160
1161 switch (argQ) {
1162 case MSG_CHAR_READ_ENDL:
1163 if (gMessageMsgVars[arg][printer->varBufferReadPos] != MSG_CHAR_READ_END) {
1165 } else {
1166 a0 = 0;
1167 }
1168 break;
1174 printer->fontVariant = sp10[0] + 0x10F;
1175 break;
1176#if !VERSION_JP
1179 break;
1180#endif
1183 switch (gMessageMsgVars[arg][printer->varBufferReadPos++]) {
1186 sp10[2] = gMessageMsgVars[arg][printer->varBufferReadPos++];
1187 a0 = 3;
1188 break;
1191 a0 = 2;
1192 break;
1195 a0 = 2;
1196 break;
1197 }
1198 break;
1199 }
1200 } else {
1201 sp10[0] = argQ;
1202 }
1203 for (i = 0; i < a0; i++) {
1204 arg1--;
1205 *printBuf++ = sp10[i];
1206 }
1207
1208 if (gMessageMsgVars[arg][printer->varBufferReadPos] == MSG_CHAR_READ_END) {
1209 srcBuf += 3;
1210 printer->varBufferReadPos = 0;
1211 printer->fontVariant = printer->unk_52A;
1212 *printBuf++ = MSG_CHAR_PRINT_VARIANT0 + printer->fontVariant;
1213 break;
1214 }
1215 } while ((printer->delayFlags & (MSG_DELAY_FLAG_4 | MSG_DELAY_FLAG_2)) || arg1 > 0);
1216
1217 if (!(printer->delayFlags & (MSG_DELAY_FLAG_4 | MSG_DELAY_FLAG_2)) && arg1 <= 0) {
1218 printer->delayFlags |= MSG_DELAY_FLAG_1;
1219 printer->curPrintDelay = printer->printDelayTime;
1220 }
1222 if (printer->stateFlags & MSG_STATE_FLAG_800000) {
1223 printer->stateFlags |= MSG_STATE_FLAG_SPEAKING;
1224 }
1225 break;
1227 arg = *srcBuf++;
1228 printer->speechSoundType = arg;
1229 printer->speechSoundIDA = MsgVoices[arg].voiceA;
1230 printer->speechSoundIDB = MsgVoices[arg].voiceB;
1231 printer->speechPitchShift = MsgVoices[arg].pitchShift;
1232 break;
1234 printer->volume = *srcBuf++;
1235 break;
1237 arg = *srcBuf++;
1238 argQ = *srcBuf++;
1239 argW = *srcBuf++;
1240 argE = *srcBuf++;
1241 printer->speechSoundIDA = (arg << 0x18) + (argQ << 0x10) + (argW << 0x8) + (argE);
1242 arg = *srcBuf++;
1243 argQ = *srcBuf++;
1244 argW = *srcBuf++;
1245 argE = *srcBuf++;
1246 printer->speechSoundIDB = (arg << 0x18) + (argQ << 0x10) + (argW << 0x8) + (argE);
1247 break;
1251 *printBuf++ = *srcBuf++;
1252 break;
1254 if (*srcBuf++) {
1255 printer->stateFlags |= MSG_STATE_FLAG_40000;
1256 } else {
1257 printer->stateFlags &= ~MSG_STATE_FLAG_40000;
1258 }
1259 break;
1261 printer->stateFlags |= MSG_STATE_FLAG_80000;
1262 break;
1263 }
1264 break;
1265 default:
1266 *printBuf++ = c;
1267 arg1--;
1268#if VERSION_IQUE
1270 *printBuf++ = nextArg;
1271 srcBuf++;
1272 arg1--;
1273 }
1274#endif
1275 if (printer->fontVariant == 0 && c == MSG_CHAR_UNK_C3) {
1276 printer->stateFlags &= ~MSG_STATE_FLAG_SPEAKING;
1277 } else {
1279 if (printer->stateFlags & MSG_STATE_FLAG_800000) {
1280 printer->stateFlags |= MSG_STATE_FLAG_SPEAKING;
1281 }
1282 }
1283 break;
1284 }
1285
1286 if (!(printer->delayFlags & (MSG_DELAY_FLAG_4 | MSG_DELAY_FLAG_2)) && arg1 <= 0) {
1287 printer->delayFlags |= MSG_DELAY_FLAG_1;
1288 printer->curPrintDelay = printer->printDelayTime;
1289 }
1290 if (!(printer->delayFlags & MSG_DELAY_FLAG_1)) {
1291 continue;
1292 }
1293 if (!s8) {
1294 break;
1295 }
1296 if (srcBuf[-1] == MSG_CHAR_READ_END) {
1297 break;
1298 }
1299 arg1 = 10000;
1300 } while (TRUE);
1301
1302 printer->printBufferPos = printBuf - printer->printBuffer;
1303 printer->delayFlags = 0;
1304 printer->srcBufferPos = (u16)(s32)(srcBuf - (s32)printer->srcBuffer);
1306}
unsigned char charset_postcard_OFFSET[]
unsigned short charset_postcard_pal_OFFSET[]
@ MSG_STATE_FLAG_100000
Definition enums.h:6255
@ MSG_STATE_FLAG_800
Definition enums.h:6247
@ MSG_STATE_FLAG_800000
Definition enums.h:6256
@ MSG_STATE_FLAG_8000
Definition enums.h:6250
@ MSG_STATE_FLAG_1000
Definition enums.h:6248
@ MSG_PRINT_FUNC_RIGHT
Definition enums.h:6140
@ MSG_READ_FUNC_COLOR
Definition enums.h:6086
@ MSG_READ_FUNC_CURSOR
Definition enums.h:6111
@ MSG_READ_FUNC_RESTORE_COLOR
Definition enums.h:6118
@ MSG_READ_FUNC_VOLUME
Definition enums.h:6126
@ MSG_READ_FUNC_RESET_GFX
Definition enums.h:6084
@ MSG_PRINT_FUNC_UP
Definition enums.h:6142
@ MSG_READ_FUNC_START_FX
Definition enums.h:6119
@ MSG_READ_FUNC_INPUT_OFF
Definition enums.h:6088
@ MSG_PRINT_FUNC_COLOR
Definition enums.h:6133
@ MSG_PRINT_FUNC_OPTION
Definition enums.h:6150
@ MSG_READ_FUNC_VAR
Definition enums.h:6121
@ MSG_READ_FUNC_VARIANT
Definition enums.h:6082
@ MSG_READ_FUNC_SET_CURSOR
Definition enums.h:6110
@ MSG_READ_FUNC_SET_CANCEL
Definition enums.h:6113
@ MSG_READ_FUNC_DELAY_OFF
Definition enums.h:6090
@ MSG_PRINT_FUNC_FONT
Definition enums.h:6129
@ MSG_PRINT_FUNC_ITEM_ICON
Definition enums.h:6145
@ MSG_PRINT_FUNC_SPACING
Definition enums.h:6134
@ MSG_READ_FUNC_SAVE_COLOR
Definition enums.h:6117
@ MSG_READ_FUNC_VOICE
Definition enums.h:6127
@ MSG_READ_FUNC_SAVE_POS
Definition enums.h:6115
@ MSG_READ_FUNC_CUSTOM_VOICE
Definition enums.h:6125
@ MSG_PRINT_FUNC_ANIM_DELAY
Definition enums.h:6146
@ MSG_READ_FUNC_INLINE_IMAGE
Definition enums.h:6102
@ MSG_READ_FUNC_SET_X
Definition enums.h:6097
@ MSG_PRINT_FUNC_SET_Y
Definition enums.h:6139
@ MSG_PRINT_FUNC_ANIM_LOOP
Definition enums.h:6147
@ MSG_PRINT_FUNC_ANIM_SPRITE
Definition enums.h:6144
@ MSG_READ_FUNC_END_FX
Definition enums.h:6120
@ MSG_READ_FUNC_SET_Y
Definition enums.h:6098
@ MSG_PRINT_FUNC_INLINE_IMAGE
Definition enums.h:6143
@ MSG_PRINT_FUNC_SET_X
Definition enums.h:6138
@ MSG_PRINT_FUNC_SIZE_RESET
Definition enums.h:6137
@ MSG_READ_FUNC_SCROLL
Definition enums.h:6093
@ MSG_PRINT_FUNC_DOWN
Definition enums.h:6141
@ MSG_READ_FUNC_DOWN
Definition enums.h:6100
@ MSG_READ_FUNC_YIELD
Definition enums.h:6085
@ MSG_READ_FUNC_NO_SKIP
Definition enums.h:6087
@ MSG_PRINT_FUNC_SAVE_COLOR
Definition enums.h:6153
@ MSG_READ_FUNC_SPACING
Definition enums.h:6092
@ MSG_READ_FUNC_RESTORE_POS
Definition enums.h:6116
@ MSG_PRINT_FUNC_VARIANT
Definition enums.h:6130
@ MSG_READ_FUNC_SPEED
Definition enums.h:6096
@ MSG_READ_FUNC_OPTION
Definition enums.h:6114
@ MSG_READ_FUNC_SIZE
Definition enums.h:6094
@ MSG_READ_FUNC_ENABLE_CDOWN_NEXT
Definition enums.h:6124
@ MSG_READ_FUNC_HIDE_IMAGE
Definition enums.h:6106
@ MSG_READ_FUNC_DELAY_ON
Definition enums.h:6091
@ MSG_PRINT_FUNC_RESTORE_COLOR
Definition enums.h:6154
@ MSG_PRINT_FUNC_END_FX
Definition enums.h:6156
@ MSG_PRINT_FUNC_START_FX
Definition enums.h:6155
@ MSG_READ_FUNC_END_CHOICE
Definition enums.h:6112
@ MSG_READ_FUNC_IMAGE
Definition enums.h:6105
@ MSG_READ_FUNC_RIGHT
Definition enums.h:6099
@ MSG_PRINT_FUNC_RESTORE_POS
Definition enums.h:6152
@ MSG_READ_FUNC_ANIM_LOOP
Definition enums.h:6108
@ MSG_PRINT_FUNC_CURSOR
Definition enums.h:6149
@ MSG_READ_FUNC_CENTER_X
Definition enums.h:6122
@ MSG_READ_FUNC_ANIM_DELAY
Definition enums.h:6107
@ MSG_READ_FUNC_ITEM_ICON
Definition enums.h:6104
@ MSG_READ_FUNC_SET_REWIND
Definition enums.h:6123
@ MSG_PRINT_FUNC_SIZE
Definition enums.h:6136
@ MSG_READ_FUNC_UP
Definition enums.h:6101
@ MSG_PRINT_FUNC_ANIM_DONE
Definition enums.h:6148
@ MSG_READ_FUNC_INPUT_ON
Definition enums.h:6089
@ MSG_READ_FUNC_FONT
Definition enums.h:6081
@ MSG_READ_FUNC_SIZE_RESET
Definition enums.h:6095
@ MSG_PRINT_FUNC_CENTER_X
Definition enums.h:6157
@ MSG_PRINT_FUNC_SAVE_POS
Definition enums.h:6151
@ MSG_READ_FUNC_ANIM_SPRITE
Definition enums.h:6103
@ MSG_PRINT_RESET_GFX
Definition enums.h:6132
@ MSG_READ_FUNC_ANIM_DONE
Definition enums.h:6109
MsgVoices
Definition enums.h:6221
@ MSG_DELAY_FLAG_4
Definition enums.h:6262
@ MSG_DELAY_FLAG_2
Definition enums.h:6261
@ MSG_DELAY_FLAG_1
Definition enums.h:6260
@ MSG_STYLE_POSTCARD
Definition enums.h:6204
@ MSG_STYLE_UPGRADE
Definition enums.h:6207
@ MSG_STYLE_F
Definition enums.h:6210
@ MSG_STYLE_B
Definition enums.h:6206
@ MSG_STYLE_NARRATE
Definition enums.h:6208
@ MSG_STYLE_INSPECT
Definition enums.h:6201
@ MSG_STYLE_POPUP
Definition enums.h:6205
@ MSG_STYLE_EPILOGUE
Definition enums.h:6209
@ MSG_STYLE_CHOICE
Definition enums.h:6200
@ SOUND_MSG_VOICE_1A
Definition enums.h:562
@ SOUND_MENU_SHOW_CHOICE
Definition enums.h:554
@ SOUND_MSG_WAIT
Definition enums.h:702
@ SOUND_APPROVE
Definition enums.h:932
@ SOUND_MSG_VOICE_1B
Definition enums.h:563
@ MSG_FX_NOISE_OUTLINE
Definition enums.h:6163
@ MSG_FX_RISE_PRINT
Definition enums.h:6170
@ MSG_FX_SIZE_JITTER
Definition enums.h:6172
@ MSG_FX_SHAKE
Definition enums.h:6161
@ MSG_FX_GLOBAL_WAVE
Definition enums.h:6168
@ MSG_FX_GLOBAL_RAINBOW
Definition enums.h:6169
@ MSG_FX_DROP_SHADOW
Definition enums.h:6174
@ MSG_FX_SIZE_WAVE
Definition enums.h:6173
@ MSG_FX_STATIC
Definition enums.h:6164
@ MSG_FX_BLUR
Definition enums.h:6165
@ MSG_FX_DITHER_FADE
Definition enums.h:6167
@ MSG_FX_WAVE
Definition enums.h:6162
@ MSG_FX_RAINBOW
Definition enums.h:6166
@ MSG_FX_GROW_PRINT
Definition enums.h:6171
@ MSG_CHAR_READ_VARIANT2
Definition enums.h:6047
@ MSG_CHAR_READ_PAUSE
Definition enums.h:6044
@ MSG_CHAR_PRINT_SPACE
Definition enums.h:6066
@ MSG_CHAR_READ_HALF_SPACE
Definition enums.h:6051
@ MSG_CHAR_READ_SPACE
Definition enums.h:6049
@ MSG_CHAR_PRINT_NEXT
Definition enums.h:6071
@ MSG_CHAR_READ_VARIANT3
Definition enums.h:6048
@ MSG_CHAR_READ_STYLE
Definition enums.h:6054
@ MSG_CHAR_PRINT_END
Definition enums.h:6072
@ MSG_CHAR_PRINT_ENDL
Definition enums.h:6061
@ MSG_CHAR_READ_FULL_SPACE
Definition enums.h:6050
@ MSG_CHAR_READ_UNK_CHAR_FA
Definition enums.h:6052
@ MSG_CHAR_READ_NEXT
Definition enums.h:6053
@ MSG_CHAR_PRINT_FULL_SPACE
Definition enums.h:6067
@ MSG_CHAR_READ_VARIANT0
Definition enums.h:6045
@ MSG_CHAR_PRINT_VARIANT0
Definition enums.h:6062
@ MSG_CHAR_PRINT_FUNCTION
Definition enums.h:6076
@ MSG_CHAR_PRINT_STYLE
Definition enums.h:6069
@ MSG_CHAR_PRINT_UNK_CHAR_FA
Definition enums.h:6070
@ MSG_CHAR_READ_ENDL
Definition enums.h:6042
@ MSG_CHAR_PRINT_HALF_SPACE
Definition enums.h:6068
@ MSG_CHAR_READ_VARIANT1
Definition enums.h:6046
@ MSG_CONTROL_CHAR
Definition enums.h:6060
@ MSG_CHAR_READ_FUNCTION
Definition enums.h:6057
u32 dma_copy(Addr romStart, Addr romEnd, void *vramDest)
Definition 43F0.c:442
void * heap_malloc(s32 size)
Definition heap.c:34
s32 gItemIconPaletteOffsets[]
PAL_BIN D_8015C7E0[0x10]
Definition msg.c:105
IMG_BIN D_80159B50[0x200]
Definition msg.c:104
s16 MsgStyleVerticalLineOffsets[]
Definition msg_data.c:927
PAL_PTR MsgLetterPaletteOffsets[]
Definition msg_data.c:893
s32 gItemIconRasterOffsets[]
void msg_play_speech_sound(MessagePrintState *printer, u8 character)
Definition msg.c:615
MessageCharset * MsgCharsets[5]
Definition msg_data.c:865
IMG_PTR MsgLetterRasterOffsets[]
Definition msg_data.c:878
u8 * D_8015131C
Definition msg.c:92

Referenced by _update_message(), and draw_msg().

◆ initialize_printer()

void initialize_printer ( MessagePrintState * printer,
s32 arg1,
s32 arg2 )

Definition at line 1309 of file msg.c.

1309 {
1310 s32 i;
1311
1312 printer->printBufferSize = ARRAY_COUNT(printer->printBuffer);
1313 printer->printBuffer[0] = MSG_CHAR_PRINT_END;
1314 printer->printDelayTime = 1;
1315 printer->charsPerChunk = 1;
1316 printer->windowScrollRate = (s32)(6 / DT);
1317 printer->srcBuffer = NULL;
1318 printer->msgID = 0;
1319 printer->curPrintDelay = 0;
1320 printer->windowOffsetPos.x = 0;
1321 printer->windowOffsetPos.y = 0;
1322 printer->windowBasePos.x = 0;
1323 printer->windowBasePos.y = 0;
1324 printer->rewindArrowAnimState = REWIND_ARROW_STATE_INIT;
1325 printer->rewindArrowCounter = 0;
1326 printer->rewindArrowPos.x = 0;
1327 printer->rewindArrowPos.y = 0;
1328 printer->curLine = 0;
1329 printer->unkArraySize = 0;
1330 printer->maxOption = 0;
1331 printer->madeChoice = 0;
1332 printer->curOption = 0;
1333 printer->selectedOption = 0;
1334 printer->cancelOption = -1;
1335 printer->windowState = MSG_WINDOW_STATE_DONE;
1336 printer->stateFlags = 0;
1337 printer->delayFlags = 0;
1338 printer->closedWritebackBool = NULL;
1339 printer->printBufferPos = 0;
1340 printer->srcBufferPos = 0;
1341 printer->font = 0;
1342 printer->fontVariant = 0;
1343 printer->effectFrameCounter = 0;
1344 printer->curLinePos = 0;
1345 printer->unk_46C = 0;
1346 printer->lineCount = 0;
1347
1348 for (i = 0; i < ARRAY_COUNT(printer->animTimers); i++) {
1349 printer->curAnimFrame[i] = 0;
1350 printer->animTimers[i] = -1;
1351 }
1352
1353 printer->initOpenPos.x = 160;
1354 printer->initOpenPos.y = 40;
1355 printer->speechSoundType = -1;
1356 printer->speechPan = 64;
1357 printer->volume = 75;
1358 printer->rewindArrowCounter = 0;
1359 printer->style = 0;
1360 printer->fadeInCounter = 0;
1361 printer->openStartPos.x = 0;
1362 printer->openStartPos.y = 0;
1363 printer->fadeOutCounter = 0;
1364 printer->windowSize.y = 0;
1365 printer->windowSize.x = 0;
1366 printer->speechPitchShift = 0;
1367 printer->speechSoundIDA = 0;
1368 printer->speechSoundIDB = 0;
1369 printer->varBufferReadPos = 0;
1370 printer->curImageIndex = 0;
1371 printer->varImageScreenPos.x = 0;
1372 printer->varImageScreenPos.y = 0;
1373 printer->varImgHasBorder = 0;
1374 printer->varImgFinalAlpha = 255;
1375 printer->varImageDisplayState = 0;
1376 printer->varImageFadeTimer = 0;
1377 printer->letterBackgroundImg = NULL;
1378 printer->letterBackgroundPal = NULL;
1379 printer->letterContentImg = NULL;
1380 printer->letterContentPal = NULL;
1381 printer->sizeScale = 1.0f;
1382}

Referenced by _msg_get_printer_for_msg(), clear_printers(), and draw_msg().

◆ _msg_get_printer_for_msg()

MessagePrintState * _msg_get_printer_for_msg ( s32 msgID,
s32 * donePrintingWriteback,
s32 arg2 )

Definition at line 1434 of file msg.c.

1434 {
1436 s8* srcBuffer;
1437 s32 height;
1438 s32 width;
1439 s32 maxLineChars;
1440 s32 numLines;
1441 s32 maxLinesPerPage;
1442 s32 i;
1443
1444 if (msgID == MSG_NONE) {
1445 return NULL;
1446 }
1447
1448 srcBuffer = (s8*) msgID;
1449 if (msgID >= 0) {
1450 srcBuffer = load_message_to_buffer((s32)srcBuffer);
1451 }
1452
1453 for (i = 0; i < ARRAY_COUNT(gMessagePrinters); i++) {
1454 printer = &gMessagePrinters[i];
1455
1456 if (!(printer->stateFlags & MSG_STATE_FLAG_2)) {
1458 printer->windowState = MSG_WINDOW_STATE_INIT;
1459 printer->srcBuffer = srcBuffer;
1460 printer->msgID = msgID;
1461 printer->stateFlags |= MSG_STATE_FLAG_2;
1462 get_msg_properties(msgID, &height, &width, &maxLineChars, &numLines, &maxLinesPerPage, NULL, 0);
1463 printer->msgHeight = height;
1464 printer->msgWidth = width;
1465 printer->maxLineChars = maxLineChars;
1466 printer->numLines = numLines;
1467 printer->maxLinesPerPage = maxLinesPerPage;
1468 printer->closedWritebackBool = donePrintingWriteback;
1469
1470 if (donePrintingWriteback != NULL) {
1472 }
1473 return printer;
1474 }
1475 }
1476
1477 return NULL;
1478}
@ MSG_STATE_FLAG_2
Definition enums.h:6239
void get_msg_properties(s32 msgID, s32 *height, s32 *width, s32 *maxLineChars, s32 *numLines, s32 *maxLinesPerPage, s32 *numSpaces, u16 charset)
Definition msg.c:1677
s8 * load_message_to_buffer(s32 msgID)
Definition msg.c:1416
void initialize_printer(MessagePrintState *printer, s32 arg1, s32 arg2)
Definition msg.c:1309

Referenced by msg_get_printer_for_msg().

◆ msg_update_rewind_arrow()

void msg_update_rewind_arrow ( s32 printerIndex)

Definition at line 2067 of file msg.c.

2067 {
2068 MessagePrintState* printer = &gMessagePrinters[printerIndex];
2069 f32 angle = 0.0f;
2070 f32 scale = 1.0f;
2071 f32 colorG = 255.0f;
2072 f32 colorR = 255.0f;
2073 f32 colorB = 255.0f;
2074 Matrix4f sp18;
2075 Matrix4f sp58;
2076 f32 temp;
2077
2080
2081 switch (printer->rewindArrowAnimState) {
2083 printer->rewindArrowCounter = 0;
2084 printer->rewindArrowSwingPhase = 0;
2085 printer->rewindArrowAnimState = REWIND_ARROW_STATE_GROW;
2086 // fallthrough
2088 temp = printer->rewindArrowCounter;
2089 scale = temp * 0.2 + 0.5;
2090 if (++printer->rewindArrowCounter >= 4) {
2091 printer->rewindArrowCounter = 0;
2092 printer->rewindArrowAnimState = REWIND_ARROW_STATE_NEUTRAL;
2093 }
2094 break;
2096 if (++printer->rewindArrowCounter >= 25) {
2097 printer->rewindArrowCounter = 0;
2098 printer->rewindArrowAnimState = REWIND_ARROW_STATE_CHANGE_COLOR;
2099 }
2100 break;
2102 colorR = update_lerp(EASING_LINEAR, 255.0f, 224.0f, printer->rewindArrowCounter, 15);
2103 colorG = update_lerp(EASING_LINEAR, 255.0f, 224.0f, printer->rewindArrowCounter, 15);
2104 colorB = update_lerp(EASING_LINEAR, 255.0f, 208.0f, printer->rewindArrowCounter, 15);
2105 if (++printer->rewindArrowCounter >= 15) {
2106 printer->rewindArrowCounter = 0;
2107 printer->rewindArrowAnimState = REWIND_ARROW_STATE_CHANGE_COLOR_BACK;
2108 }
2109 break;
2111 colorR = update_lerp(EASING_LINEAR, 224.0f, 255.0f, printer->rewindArrowCounter, 15);
2112 colorG = update_lerp(EASING_LINEAR, 224.0f, 255.0f, printer->rewindArrowCounter, 15);
2113 colorB = update_lerp(EASING_LINEAR, 208.0f, 255.0f, printer->rewindArrowCounter, 15);
2114 if (++printer->rewindArrowCounter >= 15) {
2115 printer->rewindArrowCounter = 0;
2116 printer->rewindArrowAnimState = REWIND_ARROW_STATE_NEUTRAL;
2117 }
2118 break;
2119 }
2120
2122
2123 if (printer->rewindArrowAnimState == REWIND_ARROW_STATE_NEUTRAL ||
2124 printer->rewindArrowAnimState == REWIND_ARROW_STATE_CHANGE_COLOR ||
2125 printer->rewindArrowAnimState == REWIND_ARROW_STATE_CHANGE_COLOR_BACK) {
2126 angle = cosine(printer->rewindArrowSwingPhase) * 30.0f;
2127 printer->rewindArrowSwingPhase += 15;
2128 if (printer->rewindArrowSwingPhase >= 360) {
2129 printer->rewindArrowSwingPhase -= 360;
2130 }
2131 }
2132
2133 guTranslateF(sp18, printer->rewindArrowPos.x + 12, -(printer->rewindArrowPos.y + 12), 0);
2134 if (angle != 0.0) {
2135 guRotateF(sp58, angle, 0, 0, 1.0f);
2137 }
2138 if (scale != 1.0) {
2139 guScaleF(sp58, scale, scale, 1.0f);
2141 }
2142
2148 gSP2Triangles(gMainGfxPos++, 0, 2, 1, 0, 1, 2, 3, 0);
2149}
Mtx matrixStack[0x200]
f32 Matrix4f[4][4]
#define guRotateF
#define guMtxF2L
#define guTranslateF
#define guMtxCatF
#define guScaleF
@ EASING_LINEAR
Definition enums.h:510
f32 update_lerp(s32 easing, f32 start, f32 end, s32 elapsed, s32 duration)
Definition 43F0.c:733
f32 cosine(s16 arg0)
Definition 43F0.c:352
Vtx gRewindArrowQuad[]
Definition msg.c:64
IMG_BIN ui_msg_star_png[]
Gfx D_8014C2D8[]
Definition msg.c:71
IMG_BIN ui_msg_star_silhouette_png[]
#define VIRTUAL_TO_PHYSICAL(addr)
Definition macros.h:47
Gfx * gMainGfxPos
Definition cam_main.c:14
u16 gMatrixListPos
Definition main_loop.c:44
DisplayContext * gDisplayContext
Definition cam_main.c:15

Referenced by render_messages().

◆ msg_draw_rewind_arrow()

void msg_draw_rewind_arrow ( s32 printerIndex)

Definition at line 2151 of file msg.c.

2151 {
2152 MessagePrintState* printer = &gMessagePrinters[printerIndex];
2153
2154 if (printer->rewindArrowCounter < 6) {
2156 printer->rewindArrowPos.y, 10, 10, SCREEN_WIDTH - 20, SCREEN_HEIGHT - 20, 255);
2157 }
2158
2159 printer->rewindArrowCounter++;
2160 if (printer->rewindArrowCounter >= 12) {
2161 printer->rewindArrowCounter = 0;
2162 }
2163}
s32 draw_ci_image_with_clipping(u8 *raster, s32 width, s32 height, s32 fmt, s32 bitDepth, u16 *palette, s16 posX, s16 posY, u16 clipULx, u16 clipULy, u16 clipLRx, u16 clipRLy, u8 opacity)
IMG_BIN ui_msg_rewind_arrow_png[]
PAL_BIN ui_msg_rewind_arrow_pal[]
#define SCREEN_HEIGHT
Definition macros.h:110

Referenced by render_messages().

◆ msg_draw_choice_pointer()

void msg_draw_choice_pointer ( MessagePrintState * printer)

Definition at line 2165 of file msg.c.

2165 {
2166 s32 pointerAlpha = 255;
2167 s32 shadowAlpha = 72;
2169 s32 posX, posY;
2170
2171 if (printer->windowState == MSG_WINDOW_STATE_WAITING_FOR_CHOICE || (printer->stateFlags & MSG_STATE_FLAG_20000)) {
2172 posX = printer->windowOffsetPos.x + printer->windowBasePos.x + printer->cursorPosX[printer->selectedOption];
2173 posY = printer->windowOffsetPos.y + printer->windowBasePos.y + printer->cursorPosY[printer->selectedOption];
2174 } else {
2175 s32 baseX, baseY, targetX, targetY;
2176 f32 moveToTargetAlpha = (f32)(printer->scrollingTime + 1.0) / CHOICE_POINTER_MOVE_RATE;
2177
2178 baseX = printer->windowOffsetPos.x + printer->windowBasePos.x + printer->cursorPosX[printer->selectedOption];
2179 targetX = printer->windowOffsetPos.x + printer->windowBasePos.x + printer->cursorPosX[printer->targetOption];
2180 posX = baseX + (targetX - baseX) * moveToTargetAlpha;
2181
2182 baseY = printer->windowOffsetPos.y + printer->windowBasePos.y + printer->cursorPosY[printer->selectedOption];
2183 targetY = printer->windowOffsetPos.y + printer->windowBasePos.y + printer->cursorPosY[printer->targetOption];
2184 posY = baseY + (targetY - baseY) * moveToTargetAlpha;
2185 }
2186
2187 posY++;
2188 posX += (cosine(posInterpPhase * 38 + 270) + 1.0) * 0.5 * 3.2;
2189 posX -= 2;
2190
2191 if (printer->stateFlags & MSG_STATE_FLAG_20000) {
2192 u32 opacity;
2193 opacity = 255.0 - printer->fadeOutCounter * 46.0;
2194 pointerAlpha = opacity;
2195 opacity = 72.0 - printer->fadeOutCounter * 14.4;
2196 shadowAlpha = opacity;
2197 }
2198
2204 gDPSetPrimColor(gMainGfxPos++, 0, 0, 40, 40, 40, shadowAlpha);
2205 draw_image_with_clipping(ui_point_right_png, 16, 16, G_IM_FMT_CI, G_IM_SIZ_4b, posX + 2, posY + 2, 10, 10, 300, 220);
2207}
s32 draw_image_with_clipping(IMG_PTR raster, s32 width, s32 height, s32 fmt, s32 bitDepth, s16 posX, s16 posY, u16 clipULx, u16 clipULy, u16 clipLRx, u16 clipRLy)
#define CHOICE_POINTER_MOVE_RATE
Definition msg.c:29
IMG_BIN ui_point_right_png[]
PAL_BIN ui_point_right_pal[]
#define PM_CC_07
Definition macros.h:286

Referenced by render_messages().

◆ draw_message_window()

void draw_message_window ( MessagePrintState * printer)

Definition at line 137 of file msg_draw.c.

137 {
138 f32 scale = 1.0f;
139 s32 rotZ = 0;
140
141 switch (printer->windowState) {
143 scale = (f32)D_8014C580[printer->fadeInCounter] / 100.0;
144 rotZ = (4 - printer->fadeInCounter) * 3;
145 printer->fadeInCounter++;
146 if (D_8014C580[printer->fadeInCounter] == 0) {
147 printer->windowState = MSG_WINDOW_STATE_PRINTING;
148 }
149 break;
151 scale = (f32)D_8014C588[printer->fadeOutCounter] / 100.0;
152 rotZ = -printer->fadeOutCounter;
153 printer->fadeOutCounter++;
154 if (D_8014C588[printer->fadeOutCounter] == 0) {
155 printer->stateFlags |= MSG_STATE_FLAG_1;
156 }
157 break;
158 }
159
160 switch (printer->windowState) {
163 printer->windowBasePos.x = 160 - (printer->windowSize.x / 2);
164 printer->windowBasePos.y = 56;
165 draw_box(DRAW_FLAG_ROTSCALE, WINDOW_STYLE_0, printer->windowBasePos.x, 56, 0, printer->windowSize.x, printer->windowSize.y, 255, 0,
166 scale, scale, 0.0f, 0.0f, rotZ, drawbox_message_delegate, printer, NULL, SCREEN_WIDTH,
168 break;
169 default:
170 appendGfx_message(printer, printer->windowOffsetPos.x, printer->windowOffsetPos.y, printer->unk_46C,
171 printer->curLinePos, 4, 0);
172 break;
173 }
174}
#define draw_box
@ WINDOW_STYLE_0
Definition enums.h:6369
@ DRAW_FLAG_ROTSCALE
Definition enums.h:5002
void drawbox_message_delegate(s32 data, s32 baseX, s32 baseY, s32 width, s32 height, s32 opacity, s32 darkening)
Definition msg_draw.c:131
u8 D_8014C588[]
Definition msg_draw.c:114
void appendGfx_message(MessagePrintState *, s16, s16, u16, u16, u16, u8)
Definition msg_draw.c:213
u8 D_8014C580[]
Definition msg_draw.c:113

Referenced by render_messages().

◆ appendGfx_message()

void appendGfx_message ( MessagePrintState * printer,
s16 posX,
s16 posY,
u16 additionalOffsetX,
u16 additionalOffsetY,
u16 flag,
u8 alpha )

Definition at line 213 of file msg_draw.c.

214 {
216 u16 sp80bool;
217 s16 sp8E;
218 s16 sp96;
219 s16 sp9E;
220 s16 palette;
221 s16 spAE;
222 u16 spB6;
223 u8 spB8;
224#if VERSION_IQUE
225 u16 byte = 0;
226#endif
234 f32 bubbleX;
235 f32 bubbleY;
238 f32 temp_f8;
240 f64 temp_f0;
245 f32 temp_f2;
247 s32 temp_s0_7;
248 s32 temp_s0_8;
249 s32 temp_a2;
250 s32 temp_s1_5;
251 s32 i;
252 s16 temp_s3;
253 s16 temp_s4;
254 s32 windowSizeX;
255 s32 windowSizeY;
256 s16 temp_s5;
257 s16 temp_s6;
259 s32 animIdx;
264 s32 phi_a0;
265 s32 straightWidth;
266 s32 curveWidth;
267 s32 height;
268 s32 frameX;
269 s32 frameY;
270 s32 frameSizeX;
271 s32 frameSizeY;
272 s32 frameFading;
274 u16 fading;
275 u8 phi_s0_5;
278 s8 phi_s2_4;
279 u8 phi_s3_2;
280 s32 phi_v0_3;
281 s32 phi_a0_4;
282 s16 phi_t5;
284 s16 phi_t3;
285 s32 dbPos;
289 s32 phi_s0_7;
290 s32 phi_s1_8;
291 s8 varImgHasBorder;
294 f32 z1;
295 f32 z2;
296 f32 temp1;
297 f32 temp2;
298#if VERSION_JP
300#else
302#endif
304
305 msg_drawState = &D_80155D20;
306 msg_drawState->printBuffer = printer->printBuffer;
307 msg_drawState->printModeFlags = 0;
308 if (gMainGfxPos != D_80151338) {
310 }
312 sp8E = 255;
313 if (flag & 1) {
314 sp8E = alpha;
315 }
316 msg_drawState->textStartPos[0] = 0;
317 msg_drawState->textStartPos[1] = 0;
318 msg_drawState->clipX[0] = 0;
319 msg_drawState->clipY[0] = 0;
320 msg_drawState->clipX[1] = SCREEN_WIDTH - 1;
321 msg_drawState->clipY[1] = SCREEN_HEIGHT - 1;
322 msg_drawState->msgScale.x = 1.0f;
323 msg_drawState->msgScale.y = 1.0f;
324 msg_drawState->unk_29 = 0;
325 msg_drawState->framePalette = 0;
326 msg_drawState->unk_2C = 0;
327 msg_drawState->visiblePrintedCount = 0;
328 msg_drawState->centerPos = 0;
329 msg_drawState->fontVariant = 0;
330 msg_drawState->curPosX = 0;
331 msg_drawState->nextPos[0] = 0;
332 msg_drawState->nextPos[1] = 0;
333 msg_drawState->font = 0;
334 msg_drawState->effectFlags = 0;
335 msg_drawState->nextCounter = 0;
336 msg_drawState->textColor = MSG_PAL_WHITE;
337 sp96 = 0xFF;
338 spAE = 0xFF;
339 spB6 = 0;
340 spB8 = 0;
341 sp9E = -1;
342
343 if (flag & 2) {
344 msg_drawState->font = 1;
345 }
346
347 if (flag & 4) {
349 }
350
351 sp80bool = FALSE;
352 msg_drawState->drawBufferPos = 0;
353
354 while (!sp80bool) {
355#if VERSION_IQUE
357
358 lastbyte = byte;
359 byte = msg_drawState->printBuffer[msg_drawState->drawBufferPos];
360 byte2 = msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1];
361
362 switch (byte)
363#else
364 switch (msg_drawState->printBuffer[msg_drawState->drawBufferPos])
365#endif
366 {
368 msg_drawState->nextPos[0] = 0;
369 msg_drawState->nextPos[1] += (s32)((msg_drawState->msgScale.y * MsgCharsets[msg_drawState->font]->newLineY)
370#if !VERSION_JP
372#endif
373 );
374 if (msg_drawState->printModeFlags & MSG_PRINT_FLAG_40) {
375 msg_drawState->printModeFlags |= MSG_PRINT_FLAG_80;
376 }
377 msg_drawState->drawBufferPos++;
378 break;
380 msg_drawState->drawBufferPos++;
381 break;
386 msg_drawState->fontVariant = msg_drawState->printBuffer[msg_drawState->drawBufferPos] - MSG_CHAR_PRINT_VARIANT0;
387 msg_drawState->drawBufferPos++;
388 break;
392 msg_drawState->nextPos[0] += msg_get_draw_char_width(msg_drawState->printBuffer[msg_drawState->drawBufferPos],
393 msg_drawState->font, msg_drawState->fontVariant, msg_drawState->msgScale.x, msg_drawState->curPosX,
394 msg_drawState->printModeFlags);
395 msg_drawState->drawBufferPos++;
396 break;
398 switch (msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1]) {
399 case MSG_STYLE_RIGHT:
400#if VERSION_IQUE
401 msg_drawState->nextPos[1] += 5;
402#endif
403 case MSG_STYLE_LEFT:
404 case MSG_STYLE_CENTER:
405 case MSG_STYLE_TATTLE:
406 if (printer->windowState == MSG_WINDOW_STATE_OPENING && printer->fadeInCounter == 0) {
407 printer->openStartPos.x = printer->initOpenPos.x;
408 printer->openStartPos.y = printer->initOpenPos.y;
409 }
410 temp_s6 = printer->openStartPos.x;
411 temp_s5 = printer->openStartPos.y;
412 temp_s4 = printer->windowBasePos.x + (f32) printer->windowSize.x * 0.5;
413 temp_s3 = printer->windowBasePos.y + (f32) printer->windowSize.y * 0.5;
414 msg_drawState->textColor = MSG_PAL_STANDARD;
415 msg_drawState->printModeFlags |= MSG_PRINT_FLAG_10;
416
417 if (printer->style == MSG_STYLE_RIGHT || printer->style == MSG_STYLE_LEFT || printer->style == MSG_STYLE_CENTER) {
419 printer->windowBasePos.x = MSG_NORMAL_X;
420 printer->windowBasePos.y = 13;
421 printer->windowSize.x = MSG_NORMAL_WIN_WIDTH;
422 printer->windowSize.y = MSG_NORMAL_WIN_HEIGHT;
423 msg_drawState->textStartPos[0] = 26;
424 msg_drawState->textStartPos[1] = MSG_NORMAL_TEXT_Y;
425 printer->rewindArrowPos.x = MSG_NORMAL_ARROW_X;
426 printer->rewindArrowPos.y = MSG_NORMAL_ARROW_Y;
427 curveWidth = 32;
428 height = MSG_NORMAL_HEIGHT_CAP;
429 } else {
430 straightWidth = 218;
431
432#if VERSION_JP
433 if (printer->maxLinesPerPage == 1) {
434 msg_drawState->textStartPos[0] = 18;
435 msg_drawState->textStartPos[1] = 10;
436 curveWidth = 24;
437 } else if (printer->maxLinesPerPage == 2) {
438 msg_drawState->textStartPos[0] = 22;
439 msg_drawState->textStartPos[1] = 8;
440 curveWidth = 28;
441 } else {
442 msg_drawState->textStartPos[0] = 26;
443 msg_drawState->textStartPos[1] = 8;
444 curveWidth = 32;
445 }
446#else
447 switch (printer->maxLinesPerPage) {
448 case 1:
449 msg_drawState->textStartPos[0] = 18;
450 msg_drawState->textStartPos[1] = 10;
451 curveWidth = 24;
452 break;
453 case 2:
454 msg_drawState->textStartPos[0] = 22;
455 msg_drawState->textStartPos[1] = 6;
456 curveWidth = 28;
457 break;
458 case 3:
459 msg_drawState->textStartPos[0] = 26;
460 msg_drawState->textStartPos[1] = 8;
461 curveWidth = 32;
462 break;
463 default:
464 msg_drawState->textStartPos[0] = 26;
465 msg_drawState->textStartPos[1] = 6;
466 curveWidth = 32;
467 break;
468 }
469#endif
470
471 straightWidth = printer->msgWidth;
472 if (straightWidth > 256) {
473 straightWidth = 256;
474 }
475 if (straightWidth < 70) {
476 straightWidth = 70;
477 }
478 straightWidth -= 12;
479
480 printer->windowSize.x = straightWidth + (curveWidth * 2);
481
482 height = (printer->maxLinesPerPage * MSG_NORMAL_PAGE_HT) + 16;
483 if (height > MSG_NORMAL_HEIGHT_CAP) {
484 height = MSG_NORMAL_HEIGHT_CAP;
485 }
486 if (height < 36) {
487 height = 36;
488 }
489 printer->windowSize.y = height;
490
491 temp_a2 = printer->openStartPos.x - printer->windowSize.x / 2;
492 if (temp_a2 < 18) {
493 temp_a2 = 18;
494 }
495 if (temp_a2 + printer->windowSize.x > SCREEN_WIDTH - 18) {
496 temp_a2 = SCREEN_WIDTH - 18 - printer->windowSize.x;
497 }
498 phi_a0 = printer->openStartPos.y - 38 - printer->windowSize.y;
499 if (phi_a0 < 20) {
500 phi_a0 = 20;
501 }
502 if (phi_a0 + printer->windowSize.y > 170) {
503 phi_a0 = 170 - printer->windowSize.y;
504 }
505 printer->windowBasePos.x = temp_a2;
506 printer->windowBasePos.y = phi_a0;
507 printer->rewindArrowPos.x = (printer->windowSize.x + temp_a2) - 30;
508 printer->rewindArrowPos.y = (printer->windowSize.y + phi_a0) - 18;
509 }
510
511 if (printer->windowState == MSG_WINDOW_STATE_B || printer->windowState == MSG_WINDOW_STATE_C) {
512 msg_drawState->framePalette = 1;
513 }
514
515 if (printer->windowState == MSG_WINDOW_STATE_OPENING) {
516 windowScaleX = update_lerp(EASING_LINEAR, 0.07f, 1.0f, printer->fadeInCounter, 7);
517 windowScaleY = update_lerp(EASING_LINEAR, 0.3f, 1.0f, printer->fadeInCounter, 7);
518 temp_f28 = update_lerp(EASING_LINEAR, 96.0f, 200.0f, printer->fadeInCounter, 7);
521 temp_f2_2 = printer->windowSize.x * windowScaleX;
522 temp_f0_2 = printer->windowSize.y * windowScaleY;
523 bubbleX = (temp_f24 - temp_f2_2 * 0.5) + 0.5;
524 bubbleY = (temp_f20 - temp_f0_2 * 0.5) + 0.5;
526 printer->fadeInCounter++;
527 if (printer->fadeInCounter == 7) {
528 printer->windowState = MSG_WINDOW_STATE_PRINTING;
529 }
530 } else if (printer->windowState == MSG_WINDOW_STATE_CLOSING) {
531 printer->fadeOutCounter++;
532 windowScaleX = update_lerp(EASING_LINEAR, 1.0f, 0.6f, printer->fadeOutCounter, 5);
533 windowScaleY = update_lerp(EASING_LINEAR, 1.0f, 0.8f, printer->fadeOutCounter, 5);
534 temp_f2 = (printer->windowSize.x * windowScaleX);
535 temp_f0 = (printer->windowSize.y * windowScaleY);
538 bubbleX = (temp_f24 - temp_f2 * 0.5) + 0.5;
539 bubbleY = (temp_f20 - temp_f0 * 0.5) + 0.5;
540 temp_f22_2 = (temp_f24 + temp_f2 * 0.5) - 0.5;
541 temp_f20_3 = (temp_f20 + temp_f0 * 0.5) - 0.5;
542 temp_f28 = update_lerp(EASING_LINEAR, 255.0f, 64.0f, printer->fadeOutCounter, 5);
543 sp8E = temp_f28 * 0.35;
544 spAE = temp_f28;
545 msg_drawState->clipX[0] = bubbleX + msg_drawState->textStartPos[0];
546 msg_drawState->clipY[0] = bubbleY + msg_drawState->textStartPos[1];
547 msg_drawState->clipX[1] = temp_f22_2 - msg_drawState->textStartPos[0];
548 msg_drawState->clipY[1] = temp_f20_3 - msg_drawState->textStartPos[1];
550 if (printer->fadeOutCounter >= 5) {
551 printer->stateFlags |= MSG_STATE_FLAG_1;
552 }
553 } else {
554 bubbleX = posX + printer->windowBasePos.x;
555 bubbleY = posY + printer->windowBasePos.y;
556
557 msg_draw_speech_bubble(printer, bubbleX, bubbleY, straightWidth, curveWidth, height, 1.0f, 1.0f, 255, 1);
558 if (((u32)(printer->openStartPos.x - 20) <= 280) && (printer->openStartPos.y <= 220)) {
560 }
561 }
562
563 if (printer->windowState != MSG_WINDOW_STATE_CLOSING) {
564 msg_drawState->clipX[0] = 20;
565 msg_drawState->clipY[0] = printer->windowOffsetPos.y + printer->windowBasePos.y +
566 msg_drawState->textStartPos[1];
567 msg_drawState->clipX[1] = SCREEN_WIDTH - 20;
568 msg_drawState->clipY[1] = msg_drawState->clipY[0] + printer->windowSize.y - 16;
569 }
571 msg_drawState->drawBufferPos += 2;
572 break;
573 case MSG_STYLE_CHOICE:
574 frameFading = 0;
575 windowSizeX = printer->windowSize.x;
576 windowSizeY = printer->windowSize.y;
579 msg_drawState->framePalette = 0;
580 msg_drawState->textStartPos[0] = 12;
581 msg_drawState->textStartPos[1] = 6;
582 frameAlpha = 255;
583 if (printer->windowState == MSG_WINDOW_STATE_OPENING) {
584
585 printer->fadeInCounter++;
586 if (printer->fadeInCounter == 6) {
587 printer->windowState = MSG_WINDOW_STATE_PRINTING;
588 }
589
590 temp_f10 = ((f32) printer->fadeInCounter * (2.0 / 15.0)) + 0.2;
591
592 z1 = printer->windowBasePos.x + (windowSizeX / 2);
593 z2 = printer->windowBasePos.y + (windowSizeY / 2);
594 temp1 = z1 - (windowSizeX * temp_f10 * 0.5);
595 temp2 = z2 - (windowSizeY * temp_f10 * 0.5);
596 frameX = temp1 + 0.5;
597 frameY = temp2 + 0.5;
600
601 if (frameSizeX < 24) {
602 frameSizeX = 24;
603 }
604 if (frameSizeY < 24) {
605 frameSizeY = 24;
606 }
607
608 sp8E = (u8)(temp_f10 * 255.0) * 0.6;
609 } else if (printer->windowState == MSG_WINDOW_STATE_CLOSING) {
610 printer->fadeOutCounter++;
611 if (printer->fadeOutCounter >= 5) {
612 printer->stateFlags |= MSG_STATE_FLAG_1;
613 }
614 frameAlpha = -(printer->fadeOutCounter * 46) - 1;
615 sp8E = ((u8)frameAlpha) * 0.6;
616 frameFading = 1;
617 if (sp8E >= 32) {
618 sp8E -= 32;
619 }
620 frameX = printer->windowBasePos.x;
621 frameY = printer->windowBasePos.y;
622 } else {
623 frameX = printer->windowBasePos.x;
624 frameY = printer->windowBasePos.y;
625 msg_draw_prim_rect(255, 32, 32, 0, frameX - 1, frameY - 1, windowSizeX + 2, windowSizeY + 2);
626 }
627 msg_drawState->clipX[0] = frameX + 2;
628 msg_drawState->clipY[0] = frameY + 2;
629 msg_drawState->clipX[1] = frameX + frameSizeX - 2;
630 msg_drawState->clipY[1] = frameY + frameSizeY - 2;
632 frameAlpha);
634 spAE = frameAlpha & 0xFF;
635 msg_drawState->textColor = MSG_PAL_STANDARD;
636 msg_drawState->drawBufferPos += 2;
637 msg_drawState->printModeFlags |= MSG_PRINT_FLAG_10;
638 break;
642 case MSG_STYLE_F:
643 fading = 0;
644 msg_drawState->textStartPos[0] = 16;
645 msg_drawState->textStartPos[1] = MSG_INSPECT_TEXT_Y;
646 msg_drawState->clipX[0] = printer->windowBasePos.x + 5;
647 msg_drawState->clipY[0] = printer->windowBasePos.y + 4;
648 msg_drawState->clipX[1] = printer->windowBasePos.x + printer->windowSize.x - 8;
649 msg_drawState->clipY[1] = printer->windowBasePos.y + printer->windowSize.y - 5;
650 printer->rewindArrowPos.x = msg_drawState->clipX[1] - 17;
651 printer->rewindArrowPos.y = msg_drawState->clipY[1] - 17;
652 msg_drawState->textColor = MSG_PAL_WHITE;
653 phi_s0_5 = 0xFF;
654 msg_draw_prim_rect(255, 32, 32, 0, printer->windowBasePos.x + 3, printer->windowBasePos.y - 1,
655 printer->windowSize.x - 6, 1);
656 msg_draw_prim_rect(32, 255, 32, 0, printer->windowBasePos.x + 3,
657 printer->windowBasePos.y + printer->windowSize.y, printer->windowSize.x - 6,
658 1);
659
660 if (printer->windowState == MSG_WINDOW_STATE_OPENING) {
661 phi_s0_5 = (printer->fadeInCounter * 0x30) + 0x50;
662 sp8E = (phi_s0_5 & 0xFF) - 0x30;
663 printer->fadeInCounter++;
664 fading = 1;
665 if ((s16)printer->fadeInCounter == 4) { // TODO why is this cast needed
666 printer->windowState = MSG_WINDOW_STATE_PRINTING;
667 }
668 } else if (printer->windowState == MSG_WINDOW_STATE_CLOSING) {
669 phi_s0_5 = -0x30 - (printer->fadeOutCounter * 40);
670 sp8E = (phi_s0_5 & 0xFF) - 0x30;
671 printer->fadeOutCounter++;
672 fading = 1;
673 if (printer->fadeOutCounter == 4) {
674 printer->stateFlags |= MSG_STATE_FLAG_1;
675 }
676 }
677
678 msg_draw_frame(printer->windowBasePos.x, printer->windowBasePos.y, printer->windowSize.x, printer->windowSize.y, MSG_STYLE_INSPECT,
679 msg_drawState->framePalette, fading, phi_s0_5, phi_s0_5);
681 spAE = phi_s0_5 & 0xFF;
682 msg_drawState->drawBufferPos += 2;
683 break;
684 case MSG_STYLE_SIGN:
686 msg_drawState->textStartPos[0] = 18;
687 msg_drawState->textStartPos[1] = MSG_SIGN_TEXT_Y;
688 printer->windowBasePos.x = 20 + MSG_SIGN_OFFSET_X;
689 printer->windowBasePos.y = 28;
690 printer->windowSize.x = MSG_SIGN_WIDTH;
691 msg_drawState->framePalette = 15;
692#if VERSION_IQUE
693 msg_drawState->nextPos[1] -= 2;
694#endif
695 temp_s1_5 = 0xFF;
696 if (printer->style == MSG_STYLE_SIGN) {
698 printer->windowSize.y = 72;
699 msg_drawState->textColor = MSG_PAL_18;
701 } else {
704 msg_drawState->textColor = MSG_PAL_1C;
705 }
706 msg_drawState->clipX[0] = 20 + MSG_SIGN_OFFSET_X + 14;
707 msg_drawState->clipY[0] = 40;
708 msg_drawState->clipX[1] = 283 - MSG_SIGN_OFFSET_X;
709 msg_drawState->clipY[1] = printer->windowSize.y + 17;
710 printer->rewindArrowPos.x = msg_drawState->clipX[1] - 16;
711 printer->rewindArrowPos.y = msg_drawState->clipY[1] - 9;
712
713 if (printer->windowState == MSG_WINDOW_STATE_OPENING) {
714 temp_s1_5 = (printer->fadeInCounter << 6) + 0x50;
715 sp8E = (temp_s1_5 & 0xFF) - 0x30;
716 printer->fadeInCounter++;
717 if (printer->fadeInCounter == 3) {
718 printer->windowState = MSG_WINDOW_STATE_PRINTING;
719 }
720 } else {
721 if (printer->windowState == MSG_WINDOW_STATE_CLOSING) {
722 temp_s1_5 = -0x30 - (printer->fadeOutCounter * 0x30);
723 sp8E = (temp_s1_5 & 0xFF) - 0x30;
724 printer->fadeOutCounter++;
725 if (printer->fadeOutCounter == 3) {
726 printer->stateFlags |= MSG_STATE_FLAG_1;
727 }
728 }
729 }
730 spAE = (u8)temp_s1_5;
732 28, 10, 10, 310, 230, temp_s1_5);
734 28, 10, 10, 310, 230, temp_s1_5);
736 printer->windowSize.y + 12, 10, 10, 310, 230, temp_s1_5);
738 10, 10, 310, 230, temp_s1_5);
741 gSPTextureRectangle(gMainGfxPos++, (36 + MSG_SIGN_OFFSET_X) * 4, 28 * 4, (284 - MSG_SIGN_OFFSET_X) * 4, 44 * 4, G_TX_RENDERTILE, 0, 0,
742 0x0400, 0x0400);
745 gSPTextureRectangle(gMainGfxPos++, (20 + MSG_SIGN_OFFSET_X) * 4, 44 * 4, (36 + MSG_SIGN_OFFSET_X) * 4, (printer->windowSize.y + 12) * 4,
746 G_TX_RENDERTILE, 0, 0, 0x0400, 0x0400);
749 gSPTextureRectangle(gMainGfxPos++, (284 - MSG_SIGN_OFFSET_X) * 4, 44 * 4, (300 - MSG_SIGN_OFFSET_X) * 4, (printer->windowSize.y + 12) * 4,
750 G_TX_RENDERTILE, 0, 0, 0x0400, 0x0400);
753 gSPTextureRectangle(gMainGfxPos++, (36 + MSG_SIGN_OFFSET_X) * 4, (printer->windowSize.y + 12) * 4, (284 - MSG_SIGN_OFFSET_X) * 4,
754 (printer->windowSize.y + 28) * 4, G_TX_RENDERTILE, 0, 0, 0x0400, 0x0400);
757 gSPTextureRectangle(gMainGfxPos++, (36 + MSG_SIGN_OFFSET_X) * 4, 44 * 4, (283 - MSG_SIGN_OFFSET_X + 1) * 4, (printer->windowSize.y + 12) * 4,
758 G_TX_RENDERTILE, 0, 0, 0x0400, 0x0400);
760 msg_drawState->drawBufferPos += 2;
761 break;
763 phi_s2_4 = 0;
764 msg_drawState->textStartPos[0] = 12;
765 msg_drawState->textStartPos[1] = 5;
766 printer->windowBasePos.x = 40;
767 printer->windowBasePos.y = 28;
768 msg_drawState->clipX[0] = 45;
769 msg_drawState->clipY[0] = 32;
770 msg_drawState->clipX[1] = 272;
771 msg_drawState->clipY[1] = 81;
772 printer->rewindArrowPos.x = msg_drawState->clipX[1] - 21;
773 printer->rewindArrowPos.y = msg_drawState->clipY[1] - 20;
774 msg_drawState->framePalette = 0;
775 msg_drawState->textColor = MSG_PAL_WHITE;
776 msg_draw_prim_rect(255, 32, 32, 0, 43, 27, 234, 1);
777 msg_draw_prim_rect(32, 255, 32, 0, 43, 86, 234, 1);
778 phi_s3_2 = 0xFF;
779 if (printer->windowState == MSG_WINDOW_STATE_OPENING) {
780 phi_s3_2 = (printer->fadeInCounter * 64) + 80;
781 sp8E = (phi_s3_2 & 0xFF) - 0x30;
782 printer->fadeInCounter++;
783 if (printer->fadeInCounter == 3) {
784 printer->windowState = MSG_WINDOW_STATE_PRINTING;
785 }
786 phi_s2_4 = 1;
787 } else if (printer->windowState == MSG_WINDOW_STATE_CLOSING) {
788 phi_s3_2 = -0x30 - (printer->fadeOutCounter * 0x30);
789 sp8E = (phi_s3_2 & 0xFF) - 0x30;
790 printer->fadeOutCounter++;
791 if (printer->fadeOutCounter == 3) {
792 printer->stateFlags |= MSG_STATE_FLAG_1;
793 }
794 phi_s2_4 = 1;
795 }
796 msg_draw_frame(40, 28, 240, 58, MSG_STYLE_INSPECT, msg_drawState->framePalette, phi_s2_4, phi_s3_2, phi_s3_2);
797 draw_ci_image_with_clipping(printer->letterBackgroundImg, 150, 105, G_IM_FMT_CI, G_IM_SIZ_4b,
798 printer->letterBackgroundPal, 85, 97, 10, 10, 300, 220, phi_s3_2);
800 printer->letterContentPal, 160, 102, 10, 10, 300, 220, phi_s3_2);
802 spAE = phi_s3_2 & 0xFF;
803 msg_drawState->drawBufferPos += 2;
804 break;
805 case MSG_STYLE_POPUP:
806 case MSG_STYLE_B:
807 msg_drawState->textStartPos[0] = 16;
808 msg_drawState->textStartPos[1] = MSG_POPUP_TEXT_Y;
809 msg_drawState->clipX[0] = 0;
810 msg_drawState->clipX[1] = SCREEN_WIDTH - 1;
811 msg_drawState->clipY[0] = 0;
812 msg_drawState->clipY[1] = SCREEN_HEIGHT - 1;
813 msg_drawState->textColor = MSG_PAL_WHITE;
814 msg_drawState->printModeFlags |= MSG_PRINT_FLAG_10;
815 if (printer->windowState == MSG_WINDOW_STATE_D || printer->windowState == MSG_WINDOW_STATE_E) {
816 printer->windowBasePos.x = 0;
817 printer->windowBasePos.y = 0;
818 } else {
819 printer->windowBasePos.x = 160 - printer->windowSize.x / 2;
820 printer->windowBasePos.y = 56;
821 draw_box(0, WINDOW_STYLE_0, printer->windowBasePos.x, 56, 0, printer->windowSize.x,
822 printer->windowSize.y, 255, 0, 0.0f, 0.0f, 0.0f, 0.0f, 0.0f, NULL, 0, NULL,
824 }
826 msg_drawState->drawBufferPos += 2;
827 break;
829 printer->windowBasePos.x = 60;
830 printer->windowBasePos.y = 110;
831 printer->windowSize.x = 200;
832 printer->windowSize.y = 50;
833 msg_drawState->textStartPos[0] = 0;
834 msg_drawState->textStartPos[1] = MSG_EPILOGUE_TEXT_Y;
835 msg_drawState->clipX[0] = printer->windowBasePos.x;
836 msg_drawState->clipY[0] = printer->windowBasePos.y;
837 msg_drawState->clipX[1] = printer->windowBasePos.x + printer->windowSize.x;
838 msg_drawState->clipY[1] = printer->windowBasePos.y + printer->windowSize.y;
839 printer->rewindArrowPos.x = printer->windowBasePos.x + printer->windowSize.x - 10;
840 printer->rewindArrowPos.y = printer->windowBasePos.y + printer->windowSize.y - 10;
842 msg_drawState->drawBufferPos += 2;
843 break;
844 }
845 break;
847 if (printer->windowState == MSG_WINDOW_STATE_C) {
848 if (msg_drawState->nextCounter >= printer->unkArraySize) {
849 sp80bool = TRUE;
850 }
851 } else if (printer->windowState == MSG_WINDOW_STATE_B) {
852 if (printer->curLinePos < printer->lineEndPos[printer->unkArraySize]) {
853 if (msg_drawState->nextCounter >= printer->unkArraySize) {
854 sp80bool = TRUE;
855 }
856 } else {
857 if (printer->unkArraySize < msg_drawState->nextCounter) {
858 sp80bool = TRUE;
859 } else if (msg_drawState->nextCounter >= printer->unkArraySize) {
860 phi_a0_4 = 36;
861 if (printer->maxLinesPerPage >= 2) {
862 phi_v0_3 = 48;
863 if (printer->maxLinesPerPage == 2) {
864 phi_v0_3 = 32;
865 }
866 if (printer->unk_4C8 < phi_v0_3) {
867 if (printer->unk_4C8 <= 0x10) {
868 phi_a0_4 = 56;
869 }
870 sp8E = 0xFF - (phi_a0_4 * printer->unk_4CC);
871 if (sp8E < 0) {
872 sp8E = 0;
873 }
874 }
875 }
876 }
877 }
878 }
879 msg_drawState->nextCounter++;
880 msg_drawState->drawBufferPos++;
881 break;
883 sp80bool = TRUE;
884 break;
886 msg_drawState->drawBufferPos++;
887 switch (msg_drawState->printBuffer[msg_drawState->drawBufferPos]) {
889 msg_drawState->font = msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1];
890 msg_drawState->drawBufferPos += 2;
891 msg_drawState->printModeFlags |= MSG_PRINT_FLAG_10;
892 break;
894 msg_drawState->fontVariant = msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1];
895 msg_drawState->drawBufferPos += 2;
896 break;
898 msg_drawState->textColor = msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1];
899 msg_drawState->printModeFlags |= MSG_PRINT_FLAG_10;
900 msg_drawState->drawBufferPos += 2;
901 break;
903 msg_drawState->curPosX = msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1];
904 msg_drawState->drawBufferPos += 2;
905 break;
906#if !VERSION_IQUE
908 packedScaleX = msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1];
909 msg_drawState->msgScale.x = (f32)(packedScaleX >> 4) + ((packedScaleX & 0xF) * 0.0625f);
910 packedScaleY = msg_drawState->printBuffer[msg_drawState->drawBufferPos + 2];
911 msg_drawState->msgScale.y = (f32)(packedScaleY >> 4) + ((packedScaleY & 0xF) * 0.0625f);
912 msg_drawState->drawBufferPos += 3;
913 if (msg_drawState->msgScale.x > 1.0 || msg_drawState->msgScale.y > 1.0) {
915 } else if (msg_drawState->msgScale.x < 1.0 || msg_drawState->msgScale.y < 1.0) {
917 }
918 break;
920 msg_drawState->msgScale.x = 1.0f;
921 msg_drawState->msgScale.y = 1.0f;
922 msg_drawState->drawBufferPos++;
924 break;
925#endif
927 msg_drawState->nextPos[0] = msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1] * 256 +
928 (msg_drawState->printBuffer[msg_drawState->drawBufferPos + 2]);
929 msg_drawState->drawBufferPos += 3;
930 break;
932 msg_drawState->nextPos[1] = msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1];
933 msg_drawState->drawBufferPos += 2;
934 break;
936 msg_drawState->nextPos[0] += msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1];
937 msg_drawState->drawBufferPos += 2;
938 break;
940 msg_drawState->nextPos[1] += msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1];
941 msg_drawState->drawBufferPos += 2;
942 break;
944 msg_drawState->nextPos[1] -= msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1];
945 msg_drawState->drawBufferPos += 2;
946 break;
948 msgImageData = &(*gMsgVarImages)[msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1]];
949 phi_t5 = sp8E;
950 if (sp8E < 0xFF) {
951 phi_t5 = (s32)(sp8E * 0.7);
952 }
953 imgDrawPosX = (s16)((msg_drawState->nextPos[0] + (msg_drawState->textStartPos[0] + (printer->windowBasePos.x + posX))) -
955 imgDrawPosY = (s16)((msg_drawState->nextPos[1] + (msg_drawState->textStartPos[1] + (printer->windowBasePos.y + posY))) -
957
959 msgImageData->palette, imgDrawPosX, imgDrawPosY, (s32) msg_drawState->clipX[0], (s32) msg_drawState->clipY[0],
960 msg_drawState->clipX[1] - msg_drawState->clipX[0], msg_drawState->clipY[1] - msg_drawState->clipY[0], phi_t5);
962 msg_drawState->drawBufferPos += 2;
963 break;
965 phi_s0_6 = sp8E;
966 if (sp8E < 0xFF) {
967 phi_s0_6 = (s32)(sp8E * 0.7);
968 }
969
970 if (spr_get_npc_raster_info(&sprRasterInfo, (msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1] << 8) |
971 msg_drawState->printBuffer[msg_drawState->drawBufferPos + 2],
972 msg_drawState->printBuffer[msg_drawState->drawBufferPos + 3]) != 0) {
973 imgDrawPosX = (s16)((msg_drawState->nextPos[0] + (msg_drawState->textStartPos[0] + (printer->windowBasePos.x + posX))) -
975 imgDrawPosY = (s16)((msg_drawState->nextPos[1] + (msg_drawState->textStartPos[1] + (printer->windowBasePos.y + posY))) -
977
979 msg_drawState->clipX[0], msg_drawState->clipY[0], msg_drawState->clipX[1] - msg_drawState->clipX[0],
980 msg_drawState->clipY[1] - msg_drawState->clipY[0], phi_s0_6);
981 msg_drawState->printModeFlags |= MSG_PRINT_FLAG_10;
982 }
983 msg_drawState->drawBufferPos += 4;
984 break;
986 if (D_8015131C != 0) {
987 phi_t3 = sp8E;
988 if (sp8E < 0xFF) {
989 phi_t3 = (s32)(sp8E * 0.7);
990 }
991 imgDrawPosX = (s16)((msg_drawState->nextPos[0] + (msg_drawState->textStartPos[0] + (printer->windowBasePos.x + posX))) -
993 imgDrawPosY = (s16)((msg_drawState->nextPos[1] + (msg_drawState->textStartPos[1] + (printer->windowBasePos.y + posY))) -
995
997 msg_drawState->clipY[0], msg_drawState->clipX[1] - msg_drawState->clipX[0],
998 msg_drawState->clipY[1] - msg_drawState->clipY[0], phi_t3);
999 msg_drawState->printModeFlags |= MSG_PRINT_FLAG_10;
1000 }
1001 msg_drawState->drawBufferPos++;
1002 break;
1004 animIdx = msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1];
1005 if (printer->animTimers[animIdx] == -1) {
1006 printer->animTimers[animIdx] = msg_drawState->printBuffer[msg_drawState->drawBufferPos + 3];
1007 }
1008 if (printer->animTimers[animIdx] == 0) {
1009 printer->curAnimFrame[animIdx]++;
1010 }
1011
1012 dbPos = msg_drawState->drawBufferPos;
1013 while (TRUE) {
1014 if ((msg_drawState->printBuffer[dbPos - 1] == MSG_CHAR_PRINT_FUNCTION) &&
1015 (msg_drawState->printBuffer[dbPos] == MSG_PRINT_FUNC_ANIM_DELAY) &&
1016 (msg_drawState->printBuffer[dbPos + 1] == animIdx)) {
1017 if (msg_drawState->printBuffer[dbPos + 2] != printer->curAnimFrame[animIdx]) {
1018 dbPos += 4;
1019 } else {
1020 break;
1021 }
1022 } else {
1023 if ((msg_drawState->printBuffer[dbPos] == MSG_CHAR_PRINT_FUNCTION) &&
1024 (msg_drawState->printBuffer[dbPos + 1] == MSG_PRINT_FUNC_ANIM_LOOP) &&
1025 (msg_drawState->printBuffer[dbPos + 2] == animIdx)) {
1026
1027 if (printer->animTimers[animIdx] == 0) {
1028 printer->curAnimFrame[animIdx] = msg_drawState->printBuffer[dbPos + 3];
1029 dbPos = msg_drawState->drawBufferPos;
1030 continue;
1031 } else {
1032 dbPos++;
1033 break;
1034 }
1035 } else {
1036 if (msg_drawState->printBuffer[dbPos] == MSG_CHAR_PRINT_FUNCTION &&
1037 msg_drawState->printBuffer[dbPos + 1] == MSG_PRINT_FUNC_ANIM_DONE) {
1038 if (msg_drawState->printBuffer[dbPos + 2] == animIdx) {
1039 dbPos++;
1040 break;
1041 }
1042 }
1043 }
1044 }
1045 dbPos++;
1046 }
1047 msg_drawState->drawBufferPos = dbPos;
1048
1049 switch (msg_drawState->printBuffer[msg_drawState->drawBufferPos]) {
1051 if (printer->animTimers[animIdx] == 0) {
1052 if (msg_drawState->printBuffer[msg_drawState->drawBufferPos + 3] == 0) {
1053 printer->animTimers[animIdx] = -2;
1054 } else {
1055 printer->animTimers[animIdx] = msg_drawState->printBuffer[msg_drawState->drawBufferPos + 3];
1056 }
1057 }
1058 msg_drawState->drawBufferPos += 4;
1059 break;
1061 msg_drawState->drawBufferPos += 3;
1062 break;
1064 msg_drawState->drawBufferPos += 2;
1065 break;
1066 }
1067 break;
1069 msg_drawState->drawBufferPos += 3;
1070 break;
1072 msg_drawState->drawBufferPos += 2;
1073 break;
1075 printer->cursorPosX[msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1]] = msg_drawState->textStartPos[0] +
1076 msg_drawState->nextPos[0] - additionalOffsetX - 6;
1077 printer->cursorPosY[msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1]] = msg_drawState->textStartPos[1] +
1078 msg_drawState->nextPos[1] - additionalOffsetY - 1;
1079 msg_drawState->drawBufferPos += 2;
1080 break;
1082 if (msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1] == 0xFF) {
1083 msg_drawState->printModeFlags &= ~MSG_PRINT_FLAG_20;
1084 } else {
1085 msg_drawState->unk_2D = msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1];
1086 msg_drawState->printModeFlags |= MSG_PRINT_FLAG_20;
1087 msg_drawState->nextPos[0] += 14;
1088 }
1089 msg_drawState->drawBufferPos += 2;
1090 break;
1092 msg_drawState->framePalette = msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1];
1093 msg_drawState->drawBufferPos += 2;
1094 break;
1097 msg_drawState->drawBufferPos++;
1098 break;
1100 msg_drawState->savedPos[0] = msg_drawState->nextPos[0];
1101 msg_drawState->savedPos[1] = msg_drawState->nextPos[1];
1102 msg_drawState->drawBufferPos++;
1103 break;
1105 msg_drawState->nextPos[0] = msg_drawState->savedPos[0];
1106 msg_drawState->nextPos[1] = msg_drawState->savedPos[1];
1107 msg_drawState->drawBufferPos++;
1108 break;
1110 msg_drawState->savedColor = msg_drawState->textColor;
1111 msg_drawState->drawBufferPos++;
1112 break;
1114 msg_drawState->textColor = msg_drawState->savedColor;
1115 msg_drawState->drawBufferPos++;
1116 break;
1118 switch (msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1]) {
1119 case MSG_FX_SHAKE:
1120 msg_drawState->effectFlags |= MSG_FX_FLAG_SHAKE;
1121 msg_drawState->drawBufferPos += 2;
1122 break;
1123 case MSG_FX_WAVE:
1124 msg_drawState->effectFlags |= MSG_FX_FLAG_WAVE;
1125 msg_drawState->drawBufferPos += 2;
1126 break;
1128 msg_drawState->effectFlags |= MSG_FX_FLAG_NOISE_OUTLINE;
1130 msg_drawState->drawBufferPos += 2;
1131 break;
1132 case MSG_FX_STATIC:
1133 msg_drawState->effectFlags |= MSG_FX_FLAG_STATIC;
1135 msg_drawState->printBuffer[msg_drawState->drawBufferPos + 2],
1136 msg_drawState->printBuffer[msg_drawState->drawBufferPos + 2],
1137 msg_drawState->printBuffer[msg_drawState->drawBufferPos + 2],
1138 0);
1140 msg_drawState->drawBufferPos += 3;
1141 break;
1142 case MSG_FX_BLUR:
1143 msg_drawState->effectFlags |= MSG_FX_FLAG_BLUR;
1144 spB8 = msg_drawState->printBuffer[msg_drawState->drawBufferPos + 2];
1145 msg_drawState->drawBufferPos += 3;
1146 break;
1147 case MSG_FX_RAINBOW:
1148 msg_drawState->effectFlags |= MSG_FX_FLAG_RAINBOW;
1149 msg_drawState->drawBufferPos += 2;
1150 break;
1151 case MSG_FX_DITHER_FADE:
1152 msg_drawState->effectFlags |= MSG_FX_FLAG_DITHER_FADE;
1153 spB6 = msg_drawState->printBuffer[msg_drawState->drawBufferPos + 2];
1154 msg_drawState->drawBufferPos += 3;
1155 break;
1156 case MSG_FX_GLOBAL_WAVE:
1157 msg_drawState->effectFlags |= MSG_FX_FLAG_GLOBAL_WAVE;
1158 msg_drawState->drawBufferPos += 2;
1159 break;
1161 msg_drawState->effectFlags |= MSG_FX_FLAG_GLOBAL_RAINBOW;
1162 msg_drawState->drawBufferPos += 2;
1163 break;
1164 case MSG_FX_RISE_PRINT:
1165 msg_drawState->effectFlags |= MSG_FX_FLAG_RISE_PRINT;
1166 msg_drawState->drawBufferPos += 2;
1167 break;
1168 case MSG_FX_GROW_PRINT:
1169 msg_drawState->effectFlags |= MSG_FX_FLAG_GROW_PRINT;
1170 msg_drawState->drawBufferPos += 2;
1171 break;
1172 case MSG_FX_SIZE_JITTER:
1173 msg_drawState->effectFlags |= MSG_FX_FLAG_SIZE_JITTER;
1174 msg_drawState->drawBufferPos += 2;
1175 break;
1176 case MSG_FX_SIZE_WAVE:
1177 msg_drawState->effectFlags |= MSG_FX_FLAG_SIZE_WAVE;
1178 msg_drawState->drawBufferPos += 2;
1179 break;
1180 case MSG_FX_DROP_SHADOW:
1181 msg_drawState->effectFlags |= MSG_FX_FLAG_DROP_SHADOW;
1182 msg_drawState->drawBufferPos += 2;
1183 break;
1184 }
1185 break;
1187 switch (msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1]) {
1188 case MSG_FX_SHAKE:
1189 msg_drawState->effectFlags &= ~MSG_FX_FLAG_SHAKE;
1190 break;
1191 case MSG_FX_WAVE:
1192 msg_drawState->effectFlags &= ~MSG_FX_FLAG_WAVE;
1193 break;
1195 msg_drawState->effectFlags &= ~MSG_FX_FLAG_NOISE_OUTLINE;
1196 break;
1197 case MSG_FX_STATIC:
1198 msg_drawState->effectFlags &= ~MSG_FX_FLAG_STATIC;
1199 break;
1200 case MSG_FX_BLUR:
1201 msg_drawState->effectFlags &= ~MSG_FX_FLAG_BLUR;
1202 break;
1203 case MSG_FX_RAINBOW:
1204 msg_drawState->effectFlags &= ~MSG_FX_FLAG_RAINBOW;
1205 msg_drawState->printModeFlags |= MSG_PRINT_FLAG_10;
1206 break;
1207 case MSG_FX_DITHER_FADE:
1208 msg_drawState->effectFlags &= ~MSG_FX_FLAG_DITHER_FADE;
1209 break;
1210 case MSG_FX_GLOBAL_WAVE:
1211 msg_drawState->effectFlags &= ~MSG_FX_FLAG_GLOBAL_WAVE;
1212 break;
1214 msg_drawState->effectFlags &= ~MSG_FX_FLAG_GLOBAL_RAINBOW;
1215 msg_drawState->printModeFlags |= MSG_PRINT_FLAG_10;
1216 break;
1217 case MSG_FX_RISE_PRINT:
1218 msg_drawState->effectFlags &= ~MSG_FX_FLAG_RISE_PRINT;
1219 break;
1220 case MSG_FX_GROW_PRINT:
1221 msg_drawState->effectFlags &= ~MSG_FX_FLAG_GROW_PRINT;
1222 break;
1223 case MSG_FX_SIZE_JITTER:
1224 msg_drawState->effectFlags &= ~MSG_FX_FLAG_SIZE_JITTER;
1225 break;
1226 case MSG_FX_SIZE_WAVE:
1227 msg_drawState->effectFlags &= ~MSG_FX_FLAG_SIZE_WAVE;
1228 break;
1229 case MSG_FX_DROP_SHADOW:
1230 msg_drawState->effectFlags &= ~MSG_FX_FLAG_DROP_SHADOW;
1231 break;
1232 }
1233 msg_drawState->drawBufferPos += 2;
1234 break;
1236 if (msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1] != 0) {
1237 msg_drawState->centerPos = msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1];
1238 if (msg_drawState->centerPos == 0xFF) {
1239 msg_drawState->centerPos = printer->windowSize.x / 2;
1240 }
1242 } else {
1243 msg_drawState->nextPos[0] = 0;
1244 msg_drawState->printModeFlags &= ~(MSG_PRINT_FLAG_40 | MSG_PRINT_FLAG_80);
1245 }
1246 msg_drawState->drawBufferPos += 2;
1247 break;
1248 }
1249 break;
1250 default:
1251#if VERSION_IQUE
1252 if (lastbyte >= 0x5f && lastbyte <= 0x8f) {
1253 msg_drawState->drawBufferPos++;
1254 break;
1255 }
1256#endif
1257
1258 if (msg_drawState->printModeFlags & MSG_PRINT_FLAG_2) {
1259 sp96 = 0xFF;
1262 }
1263 msg_drawState->charScale.x = msg_drawState->msgScale.x;
1264 msg_drawState->charScale.y = msg_drawState->msgScale.y;
1265 if (msg_drawState->printModeFlags & MSG_PRINT_FLAG_80) {
1266 msg_drawState->nextPos[0] += msg_drawState->centerPos - printer->msgWidth / 2;
1267 msg_drawState->printModeFlags &= ~MSG_PRINT_FLAG_80;
1268 }
1269 if (msg_drawState->printModeFlags & MSG_PRINT_FLAG_40) {
1270 charPosX = msg_drawState->nextPos[0] + (printer->windowBasePos.x + posX);
1271 } else {
1272 charPosX = msg_drawState->nextPos[0] + (msg_drawState->textStartPos[0] + (printer->windowBasePos.x +
1273 posX));
1274 }
1275
1276 baseOffsetY = msg_drawState->nextPos[1] + (msg_drawState->textStartPos[1] + (printer->windowBasePos.y + posY));
1277 msgCharset = MsgCharsets[msg_drawState->font];
1280
1281 if ((sp8E != 0) &&
1282 (charPosX < msg_drawState->clipX[1]) &&
1283 (charPosY < msg_drawState->clipY[1]) &&
1284 (msg_drawState->clipX[0] < charPosX + (s32)(msg_drawState->msgScale.x *
1285 msgCharset->rasters[msg_drawState->fontVariant].monospaceWidth)) &&
1286 (msg_drawState->clipY[0] < charPosY + (s32)(msg_drawState->msgScale.y * msgCharset->newLineY
1287#if !VERSION_JP
1289#endif
1290 ))) {
1291 palette = msg_drawState->textColor;
1292 phi_s2_5 = sp8E;
1293 if (msg_drawState->effectFlags & MSG_FX_FLAG_BLUR) {
1294 phi_s2_5 = (f32) phi_s2_5 * 0.35;
1295 }
1296 if ((printer->windowState == MSG_WINDOW_STATE_WAITING_FOR_CHOICE) && (msg_drawState->printModeFlags & MSG_PRINT_FLAG_20)) {
1297 if (msg_drawState->unk_2D == printer->curOption) {
1299 } else {
1300 msg_drawState->effectFlags &= ~MSG_FX_FLAG_GLOBAL_RAINBOW;
1301 msg_drawState->effectFlags &= ~MSG_FX_FLAG_GLOBAL_WAVE;
1302 msg_drawState->effectFlags &= ~MSG_FX_FLAG_DROP_SHADOW;
1303 palette = msg_drawState->textColor;
1304 msg_drawState->printModeFlags |= MSG_PRINT_FLAG_10;
1305 }
1306 }
1307 if (msg_drawState->effectFlags & MSG_FX_FLAG_SHAKE) {
1308 charPosX += rand_int(10000) % 2;
1309 charPosY += rand_int(10000) % 2;
1310 }
1311 if (msg_drawState->effectFlags & MSG_FX_FLAG_WAVE) {
1312 temp_f2_3 = msg_drawState->msgScale.x - 1.0;
1313 temp_s0_7 = (printer->effectFrameCounter * (s32)(20.0 - (temp_f2_3 * 5.0))) - (msg_drawState->visiblePrintedCount *
1314 (s32)(45.0 - (temp_f2_3 * 15.0)));
1315 charPosX += cosine(temp_s0_7) * ((msg_drawState->msgScale.x - 1.0) + 1.6);
1316 charPosY += cosine((temp_s0_7 + 180.0 + 90.0)) * (msg_drawState->msgScale.y - 1.0 + 1.6);
1317 }
1318 if (msg_drawState->effectFlags & MSG_FX_FLAG_GLOBAL_WAVE) {
1319 temp_s0_8 = (gMsgGlobalWaveCounter * (s32)(20.0 - ((msg_drawState->msgScale.x - 1.0) * 5.0))) -
1320 (msg_drawState->visiblePrintedCount * 45);
1321 charPosX += cosine(temp_s0_8) * ((msg_drawState->msgScale.x - 1.0) + 1.6);
1322 charPosY += cosine((temp_s0_8 + 180.0 + 90.0)) * ((msg_drawState->msgScale.y - 1.0) + 1.6);
1323 }
1324 if (msg_drawState->effectFlags & MSG_FX_FLAG_RAINBOW) {
1325 palette = abs(msg_drawState->visiblePrintedCount - (u16)(printer->effectFrameCounter / 3)) % 10;
1326 }
1327 if (msg_drawState->effectFlags & MSG_FX_FLAG_GLOBAL_RAINBOW) {
1328 palette = abs(msg_drawState->visiblePrintedCount - (u16)(gGameStatusPtr->frameCounter / 3)) % 10;
1329 }
1330 if (msg_drawState->effectFlags & MSG_FX_FLAG_DITHER_FADE) {
1333 phi_s2_5 = spB6 * (phi_s2_5 / 255.0);
1334 }
1335 if ((msg_drawState->printModeFlags & MSG_PRINT_FLAG_2) || (phi_s2_5 != sp96)) {
1336 if ((sp96 < 0xFF) && (phi_s2_5 < 0xFF)) {
1337 gDPSetPrimColor(gMainGfxPos++, 0, 0, 0, 0, 0, phi_s2_5);
1338 } else if ((sp96 == 0xFF) && (phi_s2_5 < 0xFF)) {
1340 if (printer->stateFlags & MSG_STATE_FLAG_4000) {
1343 G_BL_1MA));
1344
1345 } else {
1348 G_BL_1MA));
1349
1350 }
1352 gDPSetPrimColor(gMainGfxPos++, 0, 0, 0, 0, 0, phi_s2_5);
1353 } else if ((sp96 < 0xFF) && (phi_s2_5 == 0xFF)) {
1357 }
1358 sp96 = phi_s2_5;
1359 }
1360 if (phi_s2_5 > 0) {
1361 if (msg_drawState->effectFlags & MSG_FX_FLAG_RISE_PRINT) {
1362 if ((msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1] != MSG_CHAR_PRINT_ENDL) &&
1363 (msg_drawState->printBuffer[msg_drawState->drawBufferPos + 2] != MSG_CHAR_PRINT_ENDL) &&
1364 (msg_drawState->printBuffer[msg_drawState->drawBufferPos + 3] != MSG_CHAR_PRINT_ENDL) &&
1365 (msg_drawState->printBuffer[msg_drawState->drawBufferPos + 4] != MSG_CHAR_PRINT_ENDL)) {
1366 if ((msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1] == MSG_CHAR_PRINT_END) &&
1367 (printer->windowState == MSG_WINDOW_STATE_PRINTING)) {
1368 msg_drawState->charScale.x = msg_drawState->msgScale.x * 1.7;
1369 msg_drawState->charScale.y = msg_drawState->msgScale.y * 1.7;
1370 temp_f8 = (msg_drawState->charScale.y / 1.7) * 6.0;
1371 charPosX -= temp_f8;
1372 charPosY -= temp_f8;
1373 } else if ((msg_drawState->printBuffer[msg_drawState->drawBufferPos + 2] == MSG_CHAR_PRINT_END) &&
1374 (printer->windowState == MSG_WINDOW_STATE_PRINTING)) {
1375 msg_drawState->charScale.x = msg_drawState->msgScale.x * 1.4;
1376 msg_drawState->charScale.y = msg_drawState->msgScale.y * 1.4;
1377 temp_f8 = (msg_drawState->charScale.y / 1.4) * 3.0;
1378 charPosX -= temp_f8;
1379 charPosY -= temp_f8;
1380 } else if ((msg_drawState->printBuffer[msg_drawState->drawBufferPos + 3] == MSG_CHAR_PRINT_END) &&
1381 (printer->windowState == MSG_WINDOW_STATE_PRINTING)) {
1382 msg_drawState->charScale.x = msg_drawState->msgScale.x * 1.2;
1383 msg_drawState->charScale.y = msg_drawState->msgScale.y * 1.2;
1384 temp_f8 = (msg_drawState->charScale.y / 1.2) * 2.0;
1385 charPosX -= temp_f8;
1386 charPosY -= temp_f8;
1387 }
1388 }
1389 } else if (msg_drawState->effectFlags & MSG_FX_FLAG_GROW_PRINT) {
1390 if ((msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1] != MSG_CHAR_PRINT_ENDL) &&
1391 (msg_drawState->printBuffer[msg_drawState->drawBufferPos + 2] != MSG_CHAR_PRINT_ENDL) &&
1392 (msg_drawState->printBuffer[msg_drawState->drawBufferPos + 3] != MSG_CHAR_PRINT_ENDL) &&
1393 (msg_drawState->printBuffer[msg_drawState->drawBufferPos + 4] != MSG_CHAR_PRINT_ENDL)) {
1394 if ((msg_drawState->printBuffer[msg_drawState->drawBufferPos + 1] == MSG_CHAR_PRINT_END) &&
1395 (printer->windowState == MSG_WINDOW_STATE_PRINTING)) {
1396 msg_drawState->charScale.x = msg_drawState->msgScale.x * 0.3;
1397 msg_drawState->charScale.y = msg_drawState->msgScale.y * 0.3;
1398 charPosX += 5;
1399 charPosY += 5;
1400 } else if ((msg_drawState->printBuffer[msg_drawState->drawBufferPos + 2] == MSG_CHAR_PRINT_END) &&
1401 (printer->windowState == MSG_WINDOW_STATE_PRINTING)) {
1402 msg_drawState->charScale.x = msg_drawState->msgScale.x * 0.5;
1403 msg_drawState->charScale.y = msg_drawState->msgScale.y * 0.5;
1404 charPosX += 3;
1405 charPosY += 3;
1406 } else if ((msg_drawState->printBuffer[msg_drawState->drawBufferPos + 3] == MSG_CHAR_PRINT_END) &&
1407 (printer->windowState == MSG_WINDOW_STATE_PRINTING)) {
1408 msg_drawState->charScale.x = msg_drawState->msgScale.x * 0.75;
1409 msg_drawState->charScale.y = msg_drawState->msgScale.y * 0.75;
1410 charPosX += 2;
1411 charPosY += 2;
1412 }
1413 }
1414 } else if (msg_drawState->effectFlags & MSG_FX_FLAG_SIZE_JITTER) {
1415 temp_f8_5 = rand_int(10000) % 101;
1416 temp_f8_5 /= 100.0;
1417 temp_f8_5 = ((temp_f8_5 * 0.5) + 1.0) - 0.25;
1418
1419 if (temp_f8_5 > 1.0) {
1420 msg_drawState->charScale.x = msg_drawState->msgScale.x * temp_f8_5;
1421 msg_drawState->charScale.y = msg_drawState->msgScale.y * temp_f8_5;
1422 charPosX -= (temp_f8_5 * 8.0) - 8.5;
1423 charPosY -= (temp_f8_5 * 8.0) - 8.5;
1424 } else if (temp_f8_5 < 1.0) {
1425 msg_drawState->charScale.x = msg_drawState->msgScale.x * temp_f8_5;
1426 msg_drawState->charScale.y = msg_drawState->msgScale.y * temp_f8_5;
1427 charPosX += 8.0 - (temp_f8_5 * 16.0) * 0.5;
1428 charPosY += 8.0 - (temp_f8_5 * 16.0) * 0.5;
1429 }
1430 } else if (msg_drawState->effectFlags & MSG_FX_FLAG_SIZE_WAVE) {
1431 s32 mod360;
1432
1433 temp_a0_49 = printer->effectFrameCounter * 15;
1434 temp_a0_49 -= msg_drawState->visiblePrintedCount * 15;
1435 mod360 = temp_a0_49 % 360;
1436 temp_f8_5 = (cosine(mod360) * 0.25) + 1.0;
1437
1438 if (temp_f8_5 > 1.0) {
1439 msg_drawState->charScale.x = msg_drawState->msgScale.x * temp_f8_5;
1440 msg_drawState->charScale.y = msg_drawState->msgScale.y * temp_f8_5;
1441 charPosX -= (temp_f8_5 * 8.0) - 8.5;
1442 charPosY -= (temp_f8_5 * 8.0) - 8.5;
1443 } else if (temp_f8_5 < 1.0) {
1444 msg_drawState->charScale.x = msg_drawState->msgScale.x * temp_f8_5;
1445 msg_drawState->charScale.y = msg_drawState->msgScale.y * temp_f8_5;
1446 charPosX += 8.0 - (temp_f8_5 * 16.0) * 0.5;
1447 charPosY += 8.0 - (temp_f8_5 * 16.0) * 0.5;
1448 }
1449 }
1450
1451 if ((printer->windowState == MSG_WINDOW_STATE_B || printer->windowState == MSG_WINDOW_STATE_C) &&
1452 (printer->style == MSG_STYLE_RIGHT ||
1453 printer->style == MSG_STYLE_LEFT ||
1454 printer->style == MSG_STYLE_CENTER ||
1455 printer->style == MSG_STYLE_TATTLE))
1456 {
1457 switch (palette) {
1458 case MSG_PAL_WHITE:
1459 case MSG_PAL_RED:
1460 case MSG_PAL_10:
1461 case MSG_PAL_11:
1462 case MSG_PAL_12:
1463 case MSG_PAL_13:
1464 case MSG_PAL_14:
1465 break;
1466#if !VERSION_IQUE
1467 case MSG_PAL_STANDARD:
1468 palette = MSG_PAL_40;
1469 break;
1470#endif
1471 case MSG_PAL_20:
1472 palette = MSG_PAL_41;
1473 break;
1474 case MSG_PAL_22:
1475 palette = MSG_PAL_42;
1476 break;
1477 case MSG_PAL_23:
1478 palette = MSG_PAL_43;
1479 break;
1480 case MSG_PAL_25:
1481 palette = MSG_PAL_44;
1482 break;
1483 default:
1484 palette = MSG_PAL_40;
1485 break;
1486 }
1487 }
1488 if (palette != sp9E) {
1489 sp9E = palette;
1490 msg_drawState->printModeFlags |= MSG_PRINT_FLAG_10;
1491 }
1492 if ((msg_drawState->effectFlags & MSG_FX_FLAG_DROP_SHADOW) && (phi_s2_5 == 0xFF)) {
1496 gDPSetPrimColor(gMainGfxPos++, 0, 0, 40, 40, 40, 72);
1497#if VERSION_IQUE
1498 if (byte >= MSG_CHAR_MULTIBYTE_FIRST && byte <= MSG_CHAR_MULTIBYTE_LAST) {
1501 msg_draw_char(printer, msg_drawState, glyph_index,
1502 palette, charPosX + 2, charPosY + 2);
1503 } else {
1504 msg_draw_char(printer, msg_drawState, byte,
1505 palette, charPosX + 2, charPosY + 2);
1506 }
1507#else
1508 msg_draw_char(printer, msg_drawState,
1509 msg_drawState->printBuffer[msg_drawState->drawBufferPos],
1510 palette, charPosX + 2, charPosY + 2);
1511#endif
1513 if (phi_s2_5 < 0xFF) {
1516 } else {
1519 }
1520 }
1521
1522 if (msg_drawState->effectFlags & MSG_FX_FLAG_BLUR) {
1523 for (i = 0; i < 5; i++) {
1526 if (spB8 != 2) {
1527 phi_s0_7 += (rand_int(10000) % 3) - 1;
1528 }
1529 if (spB8 != 1) {
1530 phi_s1_8 += (rand_int(10000) % 3) - 1;
1531 }
1532#if VERSION_IQUE
1533 if (byte >= MSG_CHAR_MULTIBYTE_FIRST && byte <= MSG_CHAR_MULTIBYTE_LAST) {
1536 msg_draw_char(printer, msg_drawState, glyph_index,
1537 palette, charPosX + 2, charPosY + 2);
1538 } else {
1539 msg_draw_char(printer, msg_drawState, byte,
1540 palette, charPosX + 2, charPosY + 2);
1541 }
1542#else
1543 msg_draw_char(printer, msg_drawState,
1544 msg_drawState->printBuffer[msg_drawState->drawBufferPos], palette,
1546#endif
1547 }
1548 } else {
1549#if VERSION_IQUE
1550 if (byte >= MSG_CHAR_MULTIBYTE_FIRST && byte <= MSG_CHAR_MULTIBYTE_LAST) {
1553 msg_draw_char(printer, msg_drawState, glyph_index,
1554 palette, charPosX + 2, charPosY + 2);
1555 } else {
1556 msg_draw_char(printer, msg_drawState, byte,
1557 palette, charPosX + 2, charPosY + 2);
1558 }
1559#else
1560 msg_draw_char(printer, msg_drawState,
1561 msg_drawState->printBuffer[msg_drawState->drawBufferPos], palette, charPosX,
1562 charPosY);
1563#endif
1564 }
1565 }
1566 }
1567 if (msg_drawState->printModeFlags & MSG_PRINT_FLAG_2) {
1568 msg_drawState->printModeFlags &= ~MSG_PRINT_FLAG_2;
1569 }
1570 msg_drawState->visiblePrintedCount++;
1571 msg_drawState->nextPos[0] +=
1572#if VERSION_IQUE
1573 msg_drawState->msgScale.x * 14.0f;
1574#else
1575 msg_get_draw_char_width(msg_drawState->printBuffer[msg_drawState->drawBufferPos],
1576 msg_drawState->font, msg_drawState->fontVariant, msg_drawState->msgScale.x,
1577 msg_drawState->curPosX, msg_drawState->printModeFlags);
1578#endif
1579 msg_drawState->drawBufferPos++;
1580 break;
1581 }
1582 }
1583
1584 varImgHasBorder = FALSE;
1585 if (printer->varImageScreenPos.x != 0) {
1586 s16 varImgFinalAlpha;
1587
1588 varImgFinalAlpha = printer->varImgFinalAlpha;
1589 msgVarImage = &(*gMsgVarImages)[printer->curImageIndex];
1590
1591 switch (printer->varImgHasBorder) {
1592 case 0:
1593 case 1:
1594 if (printer->varImgHasBorder) {
1595 varImgHasBorder = TRUE;
1596 }
1597 switch (printer->varImageDisplayState) {
1598 case 0:
1599 printer->varImageFadeTimer++;
1600 varImgFinalAlpha = printer->varImageFadeTimer * printer->varImgAlphaFadeStep;
1601 if (printer->varImgFinalAlpha <= varImgFinalAlpha) {
1602 varImgFinalAlpha = printer->varImgFinalAlpha;
1603 printer->varImageFadeTimer = 0;
1604 printer->varImageDisplayState = 1;
1605 }
1606 break;
1607 case 1:
1608 varImgFinalAlpha = (u8)(((f32) spAE / 255.0) * (f32) printer->varImgFinalAlpha);
1609 break;
1610 case 2:
1611 printer->varImageFadeTimer++;
1612 varImgFinalAlpha = printer->varImgFinalAlpha - printer->varImgAlphaFadeStep * printer->varImageFadeTimer;
1613 if (varImgFinalAlpha < 1) {
1614 printer->varImageScreenPos.x = 0;
1615 }
1616 break;
1617 }
1618 break;
1619 case 2:
1620 varImgFinalAlpha = (u8)(((f32) spAE / 255.0) * (f32) printer->varImgFinalAlpha);
1621 break;
1622 }
1623
1624 if (varImgFinalAlpha > 0) {
1625 if (varImgHasBorder) {
1626 draw_box(0, WINDOW_STYLE_15, printer->varImageScreenPos.x - 7, printer->varImageScreenPos.y - 7, 0,
1627 msgVarImage->width + 15, msgVarImage->height + 14, varImgFinalAlpha, 0, 0.0f, 0.0f, 0.0f, 0.0f,
1628 0.0f, NULL, 0, NULL, SCREEN_WIDTH, SCREEN_HEIGHT, NULL);
1629 }
1631 msgVarImage->format, msgVarImage->bitDepth, msgVarImage->palette,
1632 printer->varImageScreenPos.x, printer->varImageScreenPos.y, 0, 0,
1633 SCREEN_WIDTH - 1, SCREEN_HEIGHT - 1, varImgFinalAlpha);
1634 }
1635
1636 }
1639}
MessageCharData * rasters
#define PAL_PTR
#define IMG_PTR
#define rand_int
@ WINDOW_STYLE_15
Definition enums.h:6384
@ MSG_FX_FLAG_RISE_PRINT
Definition enums.h:6186
@ MSG_FX_FLAG_DROP_SHADOW
Definition enums.h:6190
@ MSG_FX_FLAG_BLUR
Definition enums.h:6181
@ MSG_FX_FLAG_GLOBAL_WAVE
Definition enums.h:6184
@ MSG_FX_FLAG_WAVE
Definition enums.h:6179
@ MSG_FX_FLAG_GROW_PRINT
Definition enums.h:6187
@ MSG_FX_FLAG_GLOBAL_RAINBOW
Definition enums.h:6185
@ MSG_FX_FLAG_SHAKE
Definition enums.h:6178
@ MSG_FX_FLAG_SIZE_WAVE
Definition enums.h:6189
@ MSG_FX_FLAG_NOISE_OUTLINE
Definition enums.h:6180
@ MSG_FX_FLAG_STATIC
Definition enums.h:6191
@ MSG_FX_FLAG_RAINBOW
Definition enums.h:6182
@ MSG_FX_FLAG_SIZE_JITTER
Definition enums.h:6188
@ MSG_FX_FLAG_DITHER_FADE
Definition enums.h:6183
@ MSG_STATE_FLAG_4000
Definition enums.h:6249
@ MSG_PRINT_FUNC_SET_FRAME_PALETTE
Definition enums.h:6131
@ MSG_PAL_14
Definition enums.h:5424
@ MSG_PAL_13
Definition enums.h:5423
@ MSG_PAL_22
Definition enums.h:5438
@ MSG_PAL_43
Definition enums.h:5471
@ MSG_PAL_42
Definition enums.h:5470
@ MSG_PAL_WHITE
Definition enums.h:5404
@ MSG_PAL_20
Definition enums.h:5436
@ MSG_PAL_23
Definition enums.h:5439
@ MSG_PAL_1C
Definition enums.h:5432
@ MSG_PAL_STANDARD
Definition enums.h:5414
@ MSG_PAL_10
Definition enums.h:5420
@ MSG_PAL_12
Definition enums.h:5422
@ MSG_PAL_25
Definition enums.h:5441
@ MSG_PAL_44
Definition enums.h:5472
@ MSG_PAL_40
Definition enums.h:5468
@ MSG_PAL_RED
Definition enums.h:5411
@ MSG_PAL_41
Definition enums.h:5469
@ MSG_PAL_18
Definition enums.h:5428
@ MSG_PAL_11
Definition enums.h:5421
@ EASING_SIN_OUT
Definition enums.h:521
@ MSG_PRINT_FLAG_2
Definition enums.h:6229
@ MSG_PRINT_FLAG_40
Definition enums.h:6232
@ MSG_PRINT_FLAG_100
Definition enums.h:6234
@ MSG_PRINT_FLAG_1
Definition enums.h:6228
@ MSG_PRINT_FLAG_20
Definition enums.h:6231
@ MSG_PRINT_FLAG_10
Definition enums.h:6230
@ MSG_PRINT_FLAG_80
Definition enums.h:6233
@ MSG_CHAR_PRINT_VARIANT2
Definition enums.h:6064
@ MSG_CHAR_PRINT_VARIANT1
Definition enums.h:6063
@ MSG_CHAR_PRINT_VARIANT3
Definition enums.h:6065
#define MSG_SIGN_OFFSET_X
Definition msg_draw.c:205
void msg_draw_speech_bubble(MessagePrintState *printer, s16 posX, s16 posY, s16 straightWidth, s16 curveWidth, s16 height, f32 scaleX, f32 scaleY, u8 opacity, s32 arg9)
Definition msg_draw.c:1823
#define MSG_SIGN_WIDTH
Definition msg_draw.c:204
PAL_BIN D_8015C7E0[0x10]
Definition msg.c:105
IMG_BIN ui_msg_lamppost_corner_bottomright_png[]
IMG_BIN D_80159B50[0x200]
Definition msg.c:104
IMG_BIN ui_msg_sign_side_top_png[]
s16 MsgStyleVerticalLineOffsets[]
Definition msg_data.c:927
PAL_BIN ui_msg_lamppost_pal[]
void msg_draw_char(MessagePrintState *printer, MessageDrawState *drawState, s32 charIndex, s32 palette, s32 posX, s32 posY)
Definition msg_draw.c:1647
IMG_BIN ui_msg_sign_corner_topright_png[]
Gfx * D_80151338
Definition msg.c:93
#define MSG_POPUP_TEXT_Y
Definition msg_draw.c:206
#define MSG_NORMAL_WIN_WIDTH
Definition msg_draw.c:195
void msg_draw_frame(s32 posX, s32 posY, s32 sizeX, s32 sizeY, s32 style, s32 palette, s32 fading, s32 bgAlpha, s32 frameAlpha)
Definition msg_draw.c:2043
#define MSG_SIGN_TEXT_Y
Definition msg_draw.c:203
#define MSG_EPILOGUE_TEXT_Y
Definition msg_draw.c:207
#define MSG_NORMAL_X
Definition msg_draw.c:194
IMG_BIN ui_msg_sign_fill_png[]
#define MSG_NORMAL_WIDTH
Definition msg_draw.c:193
u16 gMsgGlobalWaveCounter
Definition msg.c:89
void msg_draw_prim_rect(u8 r, u8 g, u8 b, u8 a, u16 posX, u16 posY, u16 sizeX, u16 sizeY)
Definition msg_draw.c:1788
s32 msg_get_draw_char_width(s32 character, s32 charset, s32 variation, f32 msgScale, s32 overrideCharWidth, u16 flags)
Definition msg.c:1634
PAL_BIN ui_msg_sign_pal[]
#define MSG_NORMAL_TEXT_Y
Definition msg_draw.c:197
void msg_reset_gfx_state(void)
Definition msg_draw.c:1642
#define MSG_NORMAL_ARROW_X
Definition msg_draw.c:198
IMG_BIN ui_msg_sign_side_bottom_png[]
#define MSG_NORMAL_PAGE_HT
Definition msg_draw.c:201
IMG_BIN ui_msg_sign_side_right_png[]
IMG_BIN ui_msg_sign_corner_bottomleft_png[]
#define MSG_NORMAL_WIN_HEIGHT
Definition msg_draw.c:196
void msg_draw_speech_arrow(MessagePrintState *printer)
Definition msg_draw.c:1928
IMG_BIN ui_msg_sign_corner_bottomright_png[]
Gfx D_8014C500[]
Definition msg_draw.c:94
#define MSG_INSPECT_TEXT_Y
Definition msg_draw.c:202
IMG_BIN ui_msg_sign_corner_topleft_png[]
#define MSG_NORMAL_ARROW_Y
Definition msg_draw.c:199
#define MSG_NORMAL_HEIGHT_CAP
Definition msg_draw.c:200
MessageCharset * MsgCharsets[5]
Definition msg_data.c:865
IMG_BIN ui_msg_sign_side_left_png[]
u8 * D_8015131C
Definition msg.c:92
#define PM_CC_MSG_NOISE_OUTLINE
Definition macros.h:454
#define PM_CC_MSG_STATIC
Definition macros.h:455
#define PM_CC_02
Definition macros.h:281
s32 spr_get_npc_raster_info(SpriteRasterInfo *out, s32 npcSpriteID, s32 rasterIndex)
Definition sprite.c:1299

Referenced by draw_message_window(), draw_msg(), and drawbox_message_delegate().

◆ clear_character_set()

void clear_character_set ( void )

Definition at line 192 of file msg.c.

192 {
193 D_80155C98 = -1;
194}

Referenced by load_engine_data().

◆ clear_printers()

void clear_printers ( void )

Definition at line 196 of file msg.c.

196 {
197 s32 i;
198
199 for (i = 0; i < ARRAY_COUNT(gMessagePrinters); i++) {
200 initialize_printer(&gMessagePrinters[i], 0, 0);
201 }
202
205
206 for (i = 0; i < ARRAY_COUNT(gMessageMsgVars); i++) {
207 gMessageMsgVars[i][0] = 0;
208 }
209
212 load_font(0);
213}
Gfx * D_80151338
Definition msg.c:93
u16 gMsgGlobalWaveCounter
Definition msg.c:89
s32 gMsgBGScrollAmtY
Definition msg.c:91
void load_font(s32 font)
Definition msg.c:225
s32 gMsgBGScrollAmtX
Definition msg.c:88

Referenced by load_demo_battle(), load_engine_data(), load_map_by_IDs(), state_init_title_screen(), state_step_demo(), state_step_intro(), and state_step_startup().

◆ load_font_data()

void load_font_data ( Addr offset,
u16 size,
void * dest )

Definition at line 218 of file msg.c.

218 {
219#endif
220 u8* base = charset_ROM_START + (s32) offset;
221
222 dma_copy(base, base + size, dest);
223}

Referenced by filemenu_draw_char(), load_font(), and msg_draw_char().

◆ load_font()

void load_font ( s32 font)

Definition at line 225 of file msg.c.

225 {
226 if (font != D_80155C98) {
227 if (font == 0) {
228#if VERSION_JP
235#else
237#endif
239
240 // fix outline color after loading
241 for (s32 i = 0; i < 80; i++) {
242 // set the transparent color to the outline color but with alpha = 0
243 D_802F4560[i][0] = D_802F4560[i][6] & ~1;
244 }
245 } else if (font == 1) {
249 }
250 }
251}
unsigned char charset_standard_pal_OFFSET[]
unsigned char charset_standard_OFFSET[]
unsigned char charset_subtitle_pal_OFFSET[]
unsigned char charset_subtitle_OFFSET[]
unsigned char charset_title_OFFSET[]
IMG_BIN MsgCharImgSubtitle[]
Definition msg_img.c:92
IMG_BIN MsgCharImgTitle[]
Definition msg_img.c:90
void load_font_data(Addr offset, u16 size, void *dest)
Definition msg.c:218
IMG_BIN MsgCharImgNormal[]
Definition msg_img.c:91
PAL_BIN D_802F4560[80][8]
IMG_BIN MsgCharImgLatin[]
IMG_BIN MsgCharImgMenuKana[]
IMG_BIN MsgCharImgMenuLatin[]
IMG_BIN MsgCharImgKana[]

Referenced by clear_printers().

◆ update_messages()

void update_messages ( void )

Definition at line 253 of file msg.c.

253 {
254 s32 i;
255
257 if (gMsgGlobalWaveCounter >= 360) {
259 }
260
261 for (i = 0; i < ARRAY_COUNT(gMessagePrinters); i++) {
262 if (gMessagePrinters[i].stateFlags & MSG_STATE_FLAG_2) {
263 _update_message(&gMessagePrinters[i]);
264 }
265 }
266
267 gMsgBGScrollAmtX += 12;
268 gMsgBGScrollAmtY -= 12;
269 if (gMsgBGScrollAmtX >= 2048) {
270 gMsgBGScrollAmtX -= 2048;
271 }
272 if (gMsgBGScrollAmtY < 0) {
273 gMsgBGScrollAmtY += 2048;
274 }
275}
s32 _update_message(MessagePrintState *printer)
Definition msg.c:277

Referenced by step_game_loop().

◆ render_messages()

void render_messages ( void )

Definition at line 574 of file msg.c.

574 {
575 Mtx* matrix = &gMessageWindowProjMatrix[gCurrentDisplayContextIndex];
576 s32 i;
577
578 for (i = 0; i < ARRAY_COUNT(gMessagePrinters); i++) {
579 if (gMessagePrinters[i].stateFlags & MSG_STATE_FLAG_2) {
581 guOrtho(matrix, 0.0f, 319.0f, -240.0f, 0.0f, -500.0f, 500.0f, 1.0f);
588 break;
589 }
590 }
591
592 for (i = 0; i < ARRAY_COUNT(gMessagePrinters); i++) {
593 if (gMessagePrinters[i].stateFlags & MSG_STATE_FLAG_2) {
594 draw_message_window(&gMessagePrinters[i]);
595
596 if (gMessagePrinters[i].windowState == MSG_WINDOW_STATE_WAITING) {
597 if (!(gMessagePrinters[i].stateFlags & MSG_STATE_FLAG_8000) &&
598 !(gMessagePrinters[i].stateFlags & MSG_STATE_FLAG_40))
599 {
601 }
602 } else if (gMessagePrinters[i].windowState == MSG_WINDOW_STATE_C) {
604 } else if (gMessagePrinters[i].windowState == MSG_WINDOW_STATE_WAITING_FOR_CHOICE ||
605 gMessagePrinters[i].windowState == MSG_WINDOW_STATE_SCROLLING_BACK ||
606 gMessagePrinters[i].stateFlags & MSG_STATE_FLAG_10000 ||
607 gMessagePrinters[i].stateFlags & MSG_STATE_FLAG_20000)
608 {
609 msg_draw_choice_pointer(&gMessagePrinters[i]);
610 }
611 }
612 }
613}
@ MSG_STATE_FLAG_10000
Definition enums.h:6251
void msg_draw_rewind_arrow(s32)
Definition msg.c:2151
Vp D_8014C280
Definition msg.c:34
void msg_update_rewind_arrow(s32)
Definition msg.c:2067
void draw_message_window(MessagePrintState *printer)
Definition msg_draw.c:137
void msg_draw_choice_pointer(MessagePrintState *printer)
Definition msg.c:2165
s32 gCurrentDisplayContextIndex
Definition main_loop.c:46

Referenced by gfx_draw_frame().

◆ msg_play_speech_sound()

void msg_play_speech_sound ( MessagePrintState * printer,
u8 character )

Definition at line 615 of file msg.c.

615 {
616 f32 volTemp;
617 s16 volume;
618 s32 pitchShift;
619 s32 flag = 1;
620 s32 baseShift = 100;
621
622 if (printer->stateFlags & MSG_STATE_FLAG_800000 && !(printer->delayFlags & (MSG_DELAY_FLAG_2 | MSG_DELAY_FLAG_4)) && printer->volume != 0) {
623 volTemp = (f32)printer->volume / 100.0;
624 pitchShift = ((character % 20) * 10) + (printer->speechPitchShift - baseShift);
625 volume = ((rand_int(15) + 78) * volTemp);
626
627 if (volume > 255) {
628 volume = 255;
629 }
630
631 if (character & flag) {
632 sfx_play_sound_with_params(printer->speechSoundIDA, volume, printer->speechPan, pitchShift);
633 } else {
634 sfx_play_sound_with_params(printer->speechSoundIDB, volume, printer->speechPan, pitchShift);
635 }
636 }
637}

Referenced by msg_copy_to_print_buffer().

◆ dma_load_msg()

void dma_load_msg ( u32 msgID,
void * dest )

Definition at line 1402 of file msg.c.

1402 {
1403 u8* addr = (u8*) MSG_ROM_START + (msgID >> 14); // (msgID >> 16) * 4
1404 u8* offset[2]; // start, end
1405
1406 dma_copy(addr, addr + 4, &offset[0]); // Load section offset
1407
1408 addr = MSG_ROM_START + offset[0] + (msgID & 0xFFFF) * 4;
1409 dma_copy(addr, addr + 8, &offset); // Load message start and end offsets
1410
1411 // Load the msg data
1412 dma_copy(MSG_ROM_START + offset[0], MSG_ROM_START + offset[1], dest);
1413}
#define MSG_ROM_START
Definition msg.c:23

Referenced by draw_msg(), get_msg_properties(), load_message_to_buffer(), and set_message_text_var().

◆ load_message_to_buffer()

s8 * load_message_to_buffer ( s32 msgID)

Definition at line 1416 of file msg.c.

1416 {
1418
1419 dma_load_msg(msgID, &gMessageBuffers[gNextMessageBuffer]);
1420 prevBufferPos = gMessageBuffers[gNextMessageBuffer];
1421
1423 if (gNextMessageBuffer >= ARRAY_COUNT(gMessageBuffers)) {
1425 }
1426
1427 return prevBufferPos;
1428}
s16 gNextMessageBuffer
Definition msg.c:62
void dma_load_msg(u32 msgID, void *dest)
Definition msg.c:1402

Referenced by _msg_get_printer_for_msg(), and msg_printer_load_msg().

◆ msg_get_printer_for_msg()

MessagePrintState * msg_get_printer_for_msg ( s32 msgID,
s32 * donePrintingWriteback )

Definition at line 1430 of file msg.c.

1430 {
1432}
MessagePrintState * _msg_get_printer_for_msg(s32 msgID, s32 *donePrintingWriteback, s32 arg2)
Definition msg.c:1434

Referenced by _show_message(), entity_HeartBlock_show_tutorial_message(), entity_SaveBlock_show_choice_message(), entity_SaveBlock_show_tutorial_message(), popup_menu_update(), and update_item_entity_pickup().

◆ msg_printer_load_msg()

s32 msg_printer_load_msg ( s32 msgID,
MessagePrintState * printer )

Definition at line 1480 of file msg.c.

1480 {
1481 s8* buffer;
1482
1483 if (msgID >= 0) {
1484 buffer = load_message_to_buffer(msgID);
1485 } else {
1486 buffer = (s8*) msgID;
1487 }
1488
1489 printer->srcBuffer = buffer;
1490 printer->srcBufferPos = 0;
1491 printer->stateFlags &= ~MSG_STATE_FLAG_40;
1492 return 1;
1493}

Referenced by _show_message(), and entity_SaveBlock_show_result_message().

◆ msg_printer_set_origin_pos()

void msg_printer_set_origin_pos ( MessagePrintState * msgPrintState,
s32 x,
s32 y )

Definition at line 1495 of file msg.c.

1495 {
1496 msgPrintState->initOpenPos.x = x;
1497 msgPrintState->initOpenPos.y = y;
1498
1499 if (msgPrintState->initOpenPos.x < 0) {
1500 msgPrintState->initOpenPos.x = 0;
1501 }
1502 if (msgPrintState->initOpenPos.x > SCREEN_WIDTH) {
1503 msgPrintState->initOpenPos.x = SCREEN_WIDTH;
1504 }
1505 if (msgPrintState->initOpenPos.y < 0) {
1506 msgPrintState->initOpenPos.y = 0;
1507 }
1508 if (msgPrintState->initOpenPos.y > 220) {
1509 msgPrintState->initOpenPos.y = 220;
1510 }
1511}

Referenced by _show_message(), popup_menu_update(), and update_item_entity_pickup().

◆ cancel_message()

s32 cancel_message ( MessagePrintState * msgPrintState)

Definition at line 1513 of file msg.c.

1513 {
1514 if (!(msgPrintState->stateFlags & MSG_STATE_FLAG_2)) {
1515 return FALSE;
1516 }
1517
1518 msgPrintState->stateFlags |= MSG_STATE_FLAG_1;
1519 return TRUE;
1520}

Referenced by cancel_current_message().

◆ set_message_images()

void set_message_images ( MessageImageData * images)

Definition at line 1522 of file msg.c.

1522 {
1524}
MessageImageDataList gMsgVarImages
Definition msg.c:90

◆ set_message_text_var()

void set_message_text_var ( s32 msgID,
s32 index )

Definition at line 1526 of file msg.c.

1526 {
1527 u8* mallocSpace = NULL;
1528 s32 i;
1529 u8* msgVars;
1530
1531 if (msgID >= 0) {
1533 dma_load_msg(msgID, mallocSpace);
1534 msgID = (s32)mallocSpace;
1535 }
1536
1537 i = 0;
1538 msgVars = gMessageMsgVars[index];
1539 while (TRUE) {
1540 msgVars[i] = ((u8*)msgID)[i];
1541 if (((u8*)msgID)[i] == MSG_CHAR_READ_END) {
1542 break;
1543 }
1544
1545 if (++i >= 32) {
1546 msgVars[i - 1] = MSG_CHAR_READ_END;
1547 break;
1548 }
1549 }
1550
1551 if (mallocSpace != NULL) {
1553 }
1554}
#define general_heap_malloc

Referenced by btl_message_popup_draw_content(), btl_show_message_popup(), draw_content_pickup_item_header(), func_801363A0(), shop_owner_buy_dialog(), and shop_owner_continue_speech_with_quantity().

◆ set_message_int_var()

void set_message_int_var ( s32 value,
s32 index )

Definition at line 1556 of file msg.c.

1556 {
1557 s8 strBuffer[ARRAY_COUNT(gMessageMsgVars[index])];
1558 s8* bufferIt;
1559 s32 i;
1560
1561 int_to_string(value, strBuffer, 10);
1562
1563 for (i = 0, bufferIt = strBuffer; i < ARRAY_COUNT(gMessageMsgVars[index]) - 1; i++) {
1564 s8 thisChar = bufferIt[i];
1565
1566 if (thisChar == 0) {
1567 break;
1568 }
1569 gMessageMsgVars[index][i] = thisChar - '0' + MSG_CHAR_DIGIT_0;
1570 }
1571 gMessageMsgVars[index][i] = MSG_CHAR_READ_END;
1572}
@ MSG_CHAR_DIGIT_0
Definition enums.h:5871
char * int_to_string(s32, char *, s32)
Definition 43F0.c:384

Referenced by btl_message_popup_draw_content(), btl_show_message_popup(), popup_menu_draw_menu_contents(), shop_owner_buy_dialog(), and shop_owner_continue_speech_with_quantity().

◆ close_message()

void close_message ( MessagePrintState * msgPrintState)

Definition at line 1574 of file msg.c.

1574 {
1575 msgPrintState->stateFlags &= ~MSG_STATE_FLAG_40;
1576}

Referenced by _show_message(), and entity_SaveBlock_wait_for_close_choice().

◆ msg_get_print_char_width()

s32 msg_get_print_char_width ( s32 character,
s32 charset,
s32 variation,
f32 msgScale,
s32 overrideCharWidth,
u8 flags )

Definition at line 1584 of file msg.c.

1584 {
1585 f32 charWidth;
1586
1591 return 0;
1592 }
1593
1594#if VERSION_IQUE
1596 charWidth = 16.0;
1597 return charWidth * msgScale;
1598 }
1599#endif
1600
1601 if (overrideCharWidth != 0) {
1602 charWidth = overrideCharWidth;
1603 } else if (flags != 0) {
1604 u8* charWidthTable = MsgCharsets[charset]->rasters[variation].charWidthTable;
1605
1606 if (charWidthTable != NULL
1610 charWidth = charWidthTable[character];
1611 } else {
1612 charWidth = MsgCharsets[charset]->rasters[variation].monospaceWidth;
1613 }
1614 } else {
1615 charWidth = MsgCharsets[charset]->rasters[variation].monospaceWidth;
1616 }
1617
1619 return charWidth * msgScale * CHAR_SPACE_MULTIPLIER;
1620 }
1622 f64 retWidth = charWidth * msgScale;
1623 return retWidth;
1624 }
1626 return charWidth * msgScale * 0.5;
1627 }
1628 if (character >= MSG_CONTROL_CHAR) {
1629 return 0;
1630 }
1631 return charWidth * msgScale;
1632}
s8 flags
Definition demo_api.c:15
#define CHAR_SPACE_MULTIPLIER
Definition msg.c:1581

Referenced by filemenu_draw_contents_choose_name(), filemenu_draw_file_name(), and get_msg_properties().

◆ msg_get_draw_char_width()

s32 msg_get_draw_char_width ( s32 character,
s32 charset,
s32 variation,
f32 msgScale,
s32 overrideCharWidth,
u16 flags )

Definition at line 1634 of file msg.c.

1634 {
1635 f32 baseWidth;
1636
1641 return 0;
1642 }
1643
1644 if (overrideCharWidth != 0) {
1646 } else if (flags & MSG_PRINT_FLAG_100) {
1647 u8* charWidthTable = MsgCharsets[charset]->rasters[variation].charWidthTable;
1648
1649 if (charWidthTable != NULL
1653 baseWidth = charWidthTable[character];
1654 } else {
1656 }
1657 } else {
1659 }
1660
1662 return baseWidth * msgScale * CHAR_SPACE_MULTIPLIER;
1663 }
1665 f64 charWidth = baseWidth * msgScale;
1666 return charWidth;
1667 }
1669 return baseWidth * msgScale * 0.5;
1670 }
1671 if (character >= MSG_CONTROL_CHAR) {
1672 return 0;
1673 }
1674 return baseWidth * msgScale;
1675}

Referenced by appendGfx_message(), and msg_get_glyph().

◆ get_msg_properties()

void get_msg_properties ( s32 msgID,
s32 * height,
s32 * width,
s32 * maxLineChars,
s32 * numLines,
s32 * maxLinesPerPage,
s32 * numSpaces,
u16 charset )

Definition at line 1677 of file msg.c.

1677 {
1678 u8* message;
1679 s32 i;
1680 u16 pageCount;
1681 s32 linesOnPage;
1682 u8 stop;
1683 s32 lineWidth;
1684 s32 charCount;
1685 u16 lineIndex;
1686 s32 msgStyle;
1687 s32 functionCode;
1689 f32 scale;
1690 s32 temp;
1691
1692 u16 lineWidths[32];
1693 u16 lineCharNumbers[32];
1694 u16 linesPerPage[32];
1695 s32 lineCount;
1696 u16 varIndex;
1697 u16 font;
1698 u8* buffer;
1699 u16 maxLineWidth;
1700 u16 maxCharsPerLine;
1701 u16 maxLinesOnPage;
1702 u16 spaceCount;
1703 u16 endl;
1704
1705 u8 c;
1706 u8 prevChar;
1707
1708 scale = 1.0f;
1709 c = 0;
1710 lineIndex = 0;
1711 pageCount = 0;
1712 varIndex = 0;
1713 font = 0;
1714 buffer = NULL;
1715 maxLineWidth = 0;
1716 maxCharsPerLine = 0;
1717 maxLinesOnPage = 0;
1718 spaceCount = 0;
1719
1720 if (msgID == MSG_NONE) {
1721 return;
1722 }
1723
1724 if (msgID >= 0) {
1725 buffer = general_heap_malloc(0x400);
1726 dma_load_msg(msgID, buffer);
1727 message = buffer;
1728 } else {
1729 message = (u8*)msgID;
1730 }
1731
1732 if (charset & 1) {
1733 font = 1;
1734 }
1735
1736 i = 0;
1737 stop = FALSE;
1738 lineWidth = 0;
1739 linesOnPage = 0;
1740 charCount = 0;
1741 endl = TRUE;
1742 lineCount = 0;
1743
1744 do {
1745 prevChar = c;
1746 c = message[i++];
1747 switch (c) {
1752 varIndex = c - MSG_CHAR_READ_VARIANT0;
1753 break;
1755 i++;
1756 break;
1757 case MSG_CHAR_READ_WAIT:
1758 case MSG_CHAR_READ_NEXT:
1759 if (linesOnPage != 0) {
1761 pageCount++;
1762 if (pageCount >= 32) {
1763 stop = 1;
1764 }
1765 linesOnPage = 0;
1766 }
1767 break;
1768 case MSG_CHAR_READ_ENDL:
1771 lineIndex++;
1772 if (lineIndex >= 32) {
1773 stop = 1;
1774 }
1775 lineWidth = 0;
1776 charCount = 0;
1777 endl = TRUE;
1778 break;
1780 msgStyle = message[i++];
1781 switch (msgStyle) {
1782 case MSG_STYLE_CHOICE:
1783 i += 4;
1784 break;
1785 case MSG_STYLE_POSTCARD:
1786 i++;
1787 break;
1788 case MSG_STYLE_RIGHT:
1789 case MSG_STYLE_LEFT:
1790 case MSG_STYLE_CENTER:
1791 case MSG_STYLE_TATTLE:
1792 case MSG_STYLE_INSPECT:
1793 case MSG_STYLE_SIGN:
1794 case MSG_STYLE_LAMPPOST:
1795 case MSG_STYLE_POPUP:
1796 case MSG_STYLE_B:
1797 break;
1798 }
1799 break;
1800 case MSG_CHAR_READ_END:
1803 lineIndex++;
1804 stop = TRUE;
1805 break;
1807 functionCode = message[i++];
1808 switch (functionCode) {
1809 case MSG_READ_FUNC_FONT:
1810 font = message[i++];
1811 break;
1823 break;
1824 default:
1825 stop = TRUE;
1826 break;
1828 i++;
1829 // fallthrough
1830 temp = 4;
1832 i += temp;
1833 // fallthrough
1836 i++;
1837 // fallthrough
1841 i++;
1842 // fallthrough
1848 case MSG_READ_FUNC_DOWN:
1849 case MSG_READ_FUNC_UP:
1861 i++;
1862 break;
1864 if (message[i] == 0) {
1865 stop = TRUE;
1866 }
1867 i++;
1868 break;
1870 if (message[i] == MSG_CHAR_READ_END) {
1871 stop = TRUE;
1872 }
1873 break;
1874 case MSG_READ_FUNC_SIZE:
1875 packedScaleY = message[i + 1];
1876 i += 2;
1877 scale = (f32)(packedScaleY >> 4) + ((packedScaleY & 0xF) * 0.0625f);
1878 break;
1880 scale = 1.0f;
1881 break;
1883 switch (message[i++]) {
1884 case MSG_FX_STATIC:
1885 case MSG_FX_BLUR:
1886 case MSG_FX_DITHER_FADE:
1887 i++;
1888 break;
1889 case MSG_FX_SHAKE:
1890 case MSG_FX_WAVE:
1892 case MSG_FX_RAINBOW:
1893 case MSG_FX_GLOBAL_WAVE:
1895 case MSG_FX_RISE_PRINT:
1896 case MSG_FX_GROW_PRINT:
1897 case MSG_FX_SIZE_JITTER:
1898 case MSG_FX_SIZE_WAVE:
1899 case MSG_FX_DROP_SHADOW:
1900 break;
1901 }
1902 break;
1903 case MSG_READ_FUNC_VAR:
1904 lineWidth += get_msg_width((s32)gMessageMsgVars[message[i++]], 0);
1905 break;
1906 }
1907 break;
1909 break;
1913 spaceCount++;
1914 // fallthrough
1915 default:
1916 if (endl) {
1917 lineCount++;
1918 linesOnPage++;
1919 endl = FALSE;
1920 }
1921
1922#if VERSION_IQUE
1924 break;
1925 }
1926#endif
1927
1928 lineWidth += msg_get_print_char_width(c, font, varIndex, scale, 0, 1);
1929 charCount++;
1930 break;
1931 }
1932 } while (!stop);
1933
1934 if (buffer != NULL) {
1935 general_heap_free(buffer);
1936 }
1937
1938 for (i = 0; i < lineIndex; i++) {
1939 if (maxLineWidth < lineWidths[i]) {
1941 }
1944 }
1945 }
1946
1947 if (pageCount == 0) {
1949 } else {
1950 for (i = 0; i < pageCount; i++) {
1951 if (maxLinesOnPage < linesPerPage[i]) {
1953 }
1954 }
1955 }
1956
1957 if (width != NULL) {
1958 *width = maxLineWidth;
1959 }
1960 if (height != NULL) {
1961 *height = lineCount * MsgCharsets[font]->newLineY;
1962 }
1963 if (maxLineChars != NULL) {
1964 *maxLineChars = maxCharsPerLine;
1965 }
1966 if (numLines != NULL) {
1967 *numLines = lineCount;
1968 }
1969 if (maxLinesPerPage != NULL) {
1970 *maxLinesPerPage = maxLinesOnPage;
1971 }
1972 if (numSpaces != NULL) {
1974 }
1975}
#define get_msg_width
s32 msg_get_print_char_width(s32 character, s32 charset, s32 variation, f32 msgScale, s32 overrideCharWidth, u8 flags)
Definition msg.c:1584

Referenced by _msg_get_printer_for_msg(), draw_msg(), get_msg_lines(), get_msg_width(), pause_handle_input(), and pause_tutorial_draw_contents().

◆ get_msg_width()

s32 get_msg_width ( s32 msgID,
u16 charset )

Definition at line 1977 of file msg.c.

1977 {
1978 s32 width;
1979
1980 get_msg_properties(msgID, NULL, &width, NULL, NULL, NULL, NULL, charset);
1981 return width;
1982}

◆ get_msg_lines()

s32 get_msg_lines ( s32 msgID)

◆ draw_msg()

void draw_msg ( s32 msgID,
s32 posX,
s32 posY,
s32 opacity,
s32 palette,
u8 style )

Definition at line 1993 of file msg.c.

1993 {
1996 u16 bufferPos;
1997 s8* mallocSpace;
1998 s32 charset;
1999 u16 flags;
2000 s32 width;
2001
2002 flags = 0;
2003 bufferPos = 0;
2004 mallocSpace = NULL;
2005 charset = 0;
2006
2007 if (msgID != 0) {
2008 if (style & DRAW_MSG_STYLE_MENU) {
2009 flags = 2;
2010 charset = 1;
2011 }
2012
2013 if (opacity < 0xFF) {
2014 flags |= 1;
2015 }
2016
2019
2020 if (msgID < 0) {
2021 printer->srcBuffer = (u8*)msgID;
2022 } else {
2024 dma_load_msg(msgID, mallocSpace);
2025 printer->srcBuffer = mallocSpace;
2026 get_msg_properties((s32) printer->srcBuffer, 0, &width, 0, 0, 0, 0, charset);
2027 printer->msgWidth = width;
2028 }
2029
2030 if (palette >= 0) {
2031 printer->printBuffer[bufferPos++] = MSG_CHAR_PRINT_FUNCTION;
2032 printer->printBuffer[bufferPos++] = MSG_PRINT_FUNC_COLOR;
2033 printer->printBuffer[bufferPos++] = palette;
2034 printer->printBufferPos += 3;
2035 }
2036
2037 if (style & DRAW_MSG_STYLE_WAVY) {
2038 printer->printBuffer[bufferPos++] = MSG_CHAR_PRINT_FUNCTION;
2039 printer->printBuffer[bufferPos++] = MSG_PRINT_FUNC_START_FX;
2040 printer->printBuffer[bufferPos++] = MSG_FX_GLOBAL_WAVE;
2041 printer->printBufferPos += 3;
2042 }
2043
2044 if (style & DRAW_MSG_STYLE_RAINBOW) {
2045 printer->printBuffer[bufferPos++] = MSG_CHAR_PRINT_FUNCTION;
2046 printer->printBuffer[bufferPos++] = MSG_PRINT_FUNC_START_FX;
2047 printer->printBuffer[bufferPos++] = MSG_FX_GLOBAL_RAINBOW;
2048 printer->printBufferPos += 3;
2049 }
2050
2051 if (style & DRAW_MSG_STYLE_DROP_SHADOW) {
2052 printer->printBuffer[bufferPos++] = MSG_CHAR_PRINT_FUNCTION;
2053 printer->printBuffer[bufferPos++] = MSG_PRINT_FUNC_START_FX;
2054 printer->printBuffer[bufferPos++] = MSG_FX_DROP_SHADOW;
2055 printer->printBufferPos += 3;
2056 }
2057
2059 appendGfx_message(printer, (s16)posX, (s16)posY, 0, 0, flags, opacity & 0xFF);
2060
2061 if (mallocSpace != NULL) {
2063 }
2064 }
2065}
@ DRAW_MSG_STYLE_DROP_SHADOW
Definition enums.h:5387
@ DRAW_MSG_STYLE_MENU
Definition enums.h:5384
@ DRAW_MSG_STYLE_RAINBOW
Definition enums.h:5386
@ DRAW_MSG_STYLE_WAVY
Definition enums.h:5385
void appendGfx_message(MessagePrintState *, s16, s16, u16, u16, u16, u8)
Definition msg_draw.c:213

◆ draw_digit()

void draw_digit ( IMG_PTR img,
s32 charset,
s32 posX,
s32 posY )

Definition at line 2209 of file msg.c.

2209 {
2211
2214 num->texWidth , num->texHeight,
2215 0, 0,
2216 num->texWidth - 1, num->texHeight - 1,
2217 0,
2222 4 * posX, 4 * posY,
2223 4 * (posX + num->texWidth), 4 * (posY + num->texHeight),
2225 0, 0,
2226 1 << 10, 1 << 10);
2227}
MessageNumber gMsgNumbers[]
Definition msg.c:129

Referenced by draw_number().

◆ draw_number()

void draw_number ( s32 value,
s32 x,
s32 y,
s32 charset,
s32 palette,
s32 opacity,
u16 style )

Definition at line 2229 of file msg.c.

2229 {
2230 u8 valueStr[24];
2231 s8 digits[24];
2232 s32 digitPosX[24];
2233 s32 i;
2234 s32 count;
2235 s32 posX;
2237 s32 texSize = gMsgNumbers[charset].texSize;
2238
2239#if !VERSION_JP
2240 y -= 2;
2241#endif
2242 if (y < 0 || y > 240) {
2243 return;
2244 }
2245
2246 int_to_string(value, valueStr, 10);
2247
2248 for (i = 0; i < 10; i++) {
2249 u8 digit;
2250 if (valueStr[i] == '\0') {
2251 break;
2252 }
2253
2254 // handle negative numbers
2255 if (valueStr[i] == '-') {
2257 continue;
2258 }
2259
2260 digit = valueStr[i] - '0';
2261 if (digit < 10){
2262 digits[i] = digit;
2263 }
2264 }
2265 posX = x;
2266 count = i;
2267
2269
2270 if (style & DRAW_NUMBER_STYLE_ALIGN_RIGHT) {
2271 for (i = count - 1; i >= 0; i--) {
2272 if ((style & DRAW_NUMBER_STYLE_MONOSPACE) || digits[i] < 0) {
2274 } else {
2275 posX -= gMsgNumbers[charset].digitWidth[digits[i]];
2276 }
2277 digitPosX[i] = posX;
2278 }
2279 } else {
2280 for (i = 0; i < count; i++) {
2281 digitPosX[i] = posX;
2282 if ((style & DRAW_NUMBER_STYLE_MONOSPACE) || digits[i] < 0) {
2284 } else {
2285 posX += gMsgNumbers[charset].digitWidth[digits[i]];
2286 }
2287 }
2288 }
2289
2290 if (style & DRAW_NUMBER_STYLE_DROP_SHADOW) {
2291 for (i = 0; i < count; i++) {
2295 gDPSetPrimColor(gMainGfxPos++, 0, 0, 40, 40, 40, 72);
2296 draw_digit(raster + digits[i] * texSize, charset, digitPosX[i] + 2, y + 2);
2298 }
2299 }
2300
2301 if (opacity == 255) {
2304 } else {
2307 gDPSetPrimColor(gMainGfxPos++, 0, 0, 255, 255, 255, opacity);
2308 }
2309
2311 for (i = 0; i < count; i++) {
2312 posX = digitPosX[i];
2313 if (posX > 0 && posX < 320) {
2314 draw_digit(raster + digits[i] * texSize, charset, posX, y);
2315 }
2316 }
2318}
@ DRAW_NUMBER_STYLE_ALIGN_RIGHT
drawn to the left of posX
Definition enums.h:5392
@ DRAW_NUMBER_STYLE_DROP_SHADOW
Definition enums.h:5395
@ DRAW_NUMBER_STYLE_MONOSPACE
Definition enums.h:5393
@ MSG_CHAR_MINUS
Definition enums.h:5868
void draw_digit(IMG_PTR img, s32 charset, s32 posX, s32 posY)
Definition msg.c:2209
Gfx gMsgDlistInitDrawNumber[]
Definition msg.c:165
#define PM_CC_01
Definition macros.h:280

Referenced by btl_menu_moves_draw_content(), coin_counter_draw_content(), draw_shop_items(), filemenu_draw_contents_file_info(), filemenu_draw_contents_file_title(), filemenu_info_draw_message_contents(), filemenu_yesno_draw_prompt_contents(), func_800F4D28(), pause_badges_draw_contents(), pause_partners_draw_movelist(), pause_stats_draw_contents(), popup_menu_draw_menu_contents(), and popup_menu_draw_title_contents().

Variable Documentation

◆ D_8014C280

Vp D_8014C280
Initial value:
= {
.vp = {
.vscale = {640, 480, 511, 0},
.vtrans = {640, 480, 511, 0},
}
}

Definition at line 34 of file msg.c.

34 {
35 .vp = {
36 .vscale = {640, 480, 511, 0},
37 .vtrans = {640, 480, 511, 0},
38 }
39};

Referenced by render_messages().

◆ MessagePlural

u8 MessagePlural[] = { MSG_CHAR_LOWER_S, MSG_CHAR_READ_END }

Definition at line 42 of file msg.c.

@ MSG_CHAR_LOWER_S
Definition enums.h:5938

Referenced by shop_owner_buy_dialog(), and shop_owner_continue_speech_with_quantity().

◆ MessageSingular

◆ gNextMessageBuffer

s16 gNextMessageBuffer = 0

Definition at line 62 of file msg.c.

Referenced by load_message_to_buffer().

◆ gRewindArrowQuad

Vtx gRewindArrowQuad[]
Initial value:
= {
{{{ -16, 9, 0 }, 0, { 0x000, 0x000 }, { 255, 255, 255, 255 }}},
{{{ 16, 9, 0 }, 0, { 0x400, 0x000 }, { 255, 255, 255, 255 }}},
{{{ -16, -9, 0 }, 0, { 0x000, 0x240 }, { 255, 255, 255, 255 }}},
{{{ 16, -9, 0 }, 0, { 0x400, 0x240 }, { 255, 255, 255, 255 }}},
}

Definition at line 64 of file msg.c.

64 {
65 {{{ -16, 9, 0 }, 0, { 0x000, 0x000 }, { 255, 255, 255, 255 }}},
66 {{{ 16, 9, 0 }, 0, { 0x400, 0x000 }, { 255, 255, 255, 255 }}},
67 {{{ -16, -9, 0 }, 0, { 0x000, 0x240 }, { 255, 255, 255, 255 }}},
68 {{{ 16, -9, 0 }, 0, { 0x400, 0x240 }, { 255, 255, 255, 255 }}},
69};

Referenced by msg_update_rewind_arrow().

◆ D_8014C2D8

◆ gMsgBGScrollAmtX

s32 gMsgBGScrollAmtX

Definition at line 88 of file msg.c.

Referenced by clear_printers(), msg_draw_frame(), and update_messages().

◆ gMsgGlobalWaveCounter

u16 gMsgGlobalWaveCounter

Definition at line 89 of file msg.c.

Referenced by appendGfx_message(), clear_printers(), and update_messages().

◆ gMsgVarImages

MessageImageDataList gMsgVarImages

Definition at line 90 of file msg.c.

Referenced by set_message_images().

◆ gMsgBGScrollAmtY

s32 gMsgBGScrollAmtY

Definition at line 91 of file msg.c.

Referenced by clear_printers(), msg_draw_frame(), and update_messages().

◆ D_8015131C

u8* D_8015131C

Definition at line 92 of file msg.c.

Referenced by appendGfx_message(), and msg_copy_to_print_buffer().

◆ D_80151338

Gfx* D_80151338

Definition at line 93 of file msg.c.

Referenced by appendGfx_message(), and clear_printers().

◆ D_80159B50

IMG_BIN D_80159B50[0x200]

Definition at line 104 of file msg.c.

Referenced by appendGfx_message(), and msg_copy_to_print_buffer().

◆ D_8015C7E0

PAL_BIN D_8015C7E0[0x10]

Definition at line 105 of file msg.c.

Referenced by appendGfx_message(), and msg_copy_to_print_buffer().

◆ MsgStyleVerticalLineOffsets

s16 MsgStyleVerticalLineOffsets[]
extern

Definition at line 927 of file msg_data.c.

927 {
928 [MSG_STYLE_NONE] 0,
929 [MSG_STYLE_RIGHT] -4,
930 [MSG_STYLE_LEFT] -4,
931 [MSG_STYLE_CENTER] -4,
932 [MSG_STYLE_TATTLE] -4,
935 [MSG_STYLE_SIGN] -4,
938 [MSG_STYLE_POPUP] 0,
939 [MSG_STYLE_B] 0,
943 [MSG_STYLE_F] 0,
944};
@ MSG_STYLE_NONE
Definition enums.h:6195

Referenced by msg_copy_to_print_buffer().

◆ ui_msg_rewind_arrow_png

IMG_BIN ui_msg_rewind_arrow_png[]
extern

Referenced by msg_draw_rewind_arrow().

◆ ui_msg_rewind_arrow_pal

PAL_BIN ui_msg_rewind_arrow_pal[]
extern

Referenced by msg_draw_rewind_arrow().

◆ ui_msg_star_png

IMG_BIN ui_msg_star_png[]
extern

Referenced by msg_update_rewind_arrow().

◆ ui_msg_star_silhouette_png

IMG_BIN ui_msg_star_silhouette_png[]
extern

Referenced by msg_update_rewind_arrow().

◆ MsgCharImgTitle

IMG_BIN MsgCharImgTitle[]
extern

Definition at line 90 of file msg_img.c.

Referenced by load_font().

◆ MsgCharImgNormal

IMG_BIN MsgCharImgNormal[]
extern

Definition at line 91 of file msg_img.c.

Referenced by load_font().

◆ MsgCharsets

MessageCharset* MsgCharsets[5]
extern

Definition at line 865 of file msg_data.c.

865 {
868#if VERSION_JP
870#else
872#endif
875 NULL
876};
@ MSG_FONT_MENU
Definition enums.h:6215
@ MSG_FONT_TITLE
Definition enums.h:6217
@ MSG_FONT_2
Definition enums.h:6216
@ MSG_FONT_NORMAL
Definition enums.h:6214
@ MSG_FONT_SUBTITLE
Definition enums.h:6218
MessageCharset MsgCharsetTitle
Definition msg_data.c:849
MessageCharset MsgCharsetNormal
Definition msg_data.c:794
MessageCharset MsgCharsetSubtitle
Definition msg_data.c:857
MessageCharset MsgCharsetMenu
Definition msg_data.c:802

Referenced by get_msg_properties(), msg_copy_to_print_buffer(), msg_get_draw_char_width(), and msg_get_print_char_width().

◆ MsgCharImgSubtitle

IMG_BIN MsgCharImgSubtitle[]
extern

Definition at line 92 of file msg_img.c.

Referenced by load_font().

◆ D_802F4560

PAL_BIN D_802F4560[80][8]
extern

Referenced by draw_number(), and load_font().

◆ ui_point_right_png

IMG_BIN ui_point_right_png[]
extern

Referenced by msg_draw_choice_pointer().

◆ ui_point_right_pal

PAL_BIN ui_point_right_pal[]
extern

Referenced by msg_draw_choice_pointer().

◆ gMsgNumbers

MessageNumber gMsgNumbers[]

Definition at line 129 of file msg.c.

129 {
130#if VERSION_JP
131 {
132 .rasters = &MsgCharImgKana[0x4910],
133 .texSize = 112,
134 .texWidth = 16,
135 .texHeight = 14,
136 .digitWidth = {11, 8, 11, 11, 11, 11, 11, 11, 11, 11},
137 .fixedWidth = 11
138 }, {
139 .rasters = &MsgCharImgMenuKana[0x2EF8],
140 .texSize = 72,
141 .texWidth = 12,
142 .texHeight = 12,
143 .digitWidth = {9, 8, 9, 9, 9, 9, 9, 9, 9, 9},
144 .fixedWidth = 9
145 }
146#else
147 {
148 .rasters = &MsgCharImgNormal[0x800],
149 .texSize = 128,
150 .texWidth = 16,
151 .texHeight = 16,
152 .digitWidth = {11, 8, 11, 11, 11, 11, 11, 11, 11, 11},
153 .fixedWidth = 11
154 }, {
155 .rasters = &MsgCharImgNormal[0x800],
156 .texSize = 128,
157 .texWidth = 16,
158 .texHeight = 16,
159 .digitWidth = {9, 8, 9, 9, 9, 9, 9, 9, 9, 9},
160 .fixedWidth = 9
161 }
162#endif
163};

Referenced by draw_digit(), and draw_number().

◆ gMsgDlistInitDrawNumber

◆ gItemIconRasterOffsets

s32 gItemIconRasterOffsets[]
extern

◆ gItemIconPaletteOffsets

s32 gItemIconPaletteOffsets[]
extern

◆ MsgLetterRasterOffsets

IMG_PTR MsgLetterRasterOffsets[]
extern

Definition at line 878 of file msg_data.c.

878 {
891};
unsigned char charset_letter_content_3_OFFSET[]
unsigned char charset_letter_content_9_OFFSET[]
unsigned char charset_letter_content_8_OFFSET[]
unsigned char charset_letter_content_7_OFFSET[]
unsigned char charset_letter_content_4_OFFSET[]
unsigned char charset_letter_content_6_OFFSET[]
unsigned char charset_letter_content_11_OFFSET[]
unsigned char charset_letter_content_5_OFFSET[]
unsigned char charset_letter_content_10_OFFSET[]
unsigned char charset_letter_content_2_OFFSET[]
unsigned char charset_letter_content_1_OFFSET[]
unsigned char charset_letter_content_12_OFFSET[]

Referenced by msg_copy_to_print_buffer().

◆ MsgLetterPaletteOffsets

PAL_PTR MsgLetterPaletteOffsets[]
extern

Definition at line 893 of file msg_data.c.

893 {
906};
unsigned short charset_letter_content_2_pal_OFFSET[]
unsigned short charset_letter_content_12_pal_OFFSET[]
unsigned short charset_letter_content_5_pal_OFFSET[]
unsigned short charset_letter_content_10_pal_OFFSET[]
unsigned short charset_letter_content_4_pal_OFFSET[]
unsigned short charset_letter_content_11_pal_OFFSET[]
unsigned short charset_letter_content_7_pal_OFFSET[]
unsigned short charset_letter_content_1_pal_OFFSET[]
unsigned short charset_letter_content_6_pal_OFFSET[]
unsigned short charset_letter_content_3_pal_OFFSET[]
unsigned short charset_letter_content_8_pal_OFFSET[]
unsigned short charset_letter_content_9_pal_OFFSET[]

Referenced by msg_copy_to_print_buffer().

◆ MsgVoices

MsgVoice MsgVoices[]
extern

Definition at line 908 of file msg_data.c.

908 {
910 .voiceA = SOUND_MSG_VOICE_1A,
911 .voiceB = SOUND_MSG_VOICE_1B,
912 .pitchShift = 0
913 },
915 .voiceA = SOUND_MSG_VOICE_4A,
916 .voiceB = SOUND_MSG_VOICE_4B,
917 .pitchShift = -50
918 },
920 .voiceA = SOUND_MSG_VOICE_STAR,
921 .voiceB = SOUND_MSG_VOICE_STAR,
922 .pitchShift = 0
923 },
924};
@ MSG_VOICE_STAR
Definition enums.h:6224
@ MSG_VOICE_NORMAL
Definition enums.h:6222
@ MSG_VOICE_BOWSER
Definition enums.h:6223
@ SOUND_MSG_VOICE_4A
Definition enums.h:568
@ SOUND_MSG_VOICE_4B
Definition enums.h:569
@ SOUND_MSG_VOICE_STAR
Definition enums.h:572