summaryrefslogtreecommitdiff
path: root/src/video
diff options
context:
space:
mode:
authoralekseiplusplus <alekseijeaves@protonmail.com>2023-11-29 19:28:04 +1100
committeralekseiplusplus <alekseijeaves@protonmail.com>2023-11-29 19:28:04 +1100
commit9dc65f84b480d5869265428c1957c50bdee3a1f5 (patch)
tree5ca229ef8f07a7e134e8b57188e183dde7dc3ed0 /src/video
parent44a1ea6542c812b173fb9685837c0b2fdc6a7c61 (diff)
Display progress, still wip
Diffstat (limited to 'src/video')
-rw-r--r--src/video/interface.h4
-rw-r--r--src/video/ncurses.c90
2 files changed, 65 insertions, 29 deletions
diff --git a/src/video/interface.h b/src/video/interface.h
index e3244b0..048aa25 100644
--- a/src/video/interface.h
+++ b/src/video/interface.h
@@ -7,7 +7,7 @@
#include <stdlib.h>
// Common procedure for taking in user input.
-char UserInput();
+byte UserInput();
// Initialization procedure for the terminal
void TerminalInit();
@@ -16,4 +16,4 @@ void TerminalInit();
void TerminalClose();
// Deliver an Apple ASCII character to the terminal.
-void TerminalInput(char n); \ No newline at end of file
+void TerminalInput(byte n);
diff --git a/src/video/ncurses.c b/src/video/ncurses.c
index 2e3e519..d584088 100644
--- a/src/video/ncurses.c
+++ b/src/video/ncurses.c
@@ -14,24 +14,43 @@ int TermY = 0;
WINDOW *AppleWindow;
-char UserInput()
+byte UserInput()
{
- return getch();
+ int c = getch();
+
+ switch(c)
+ {
+ // Convert special characters
+ case KEY_BACKSPACE:
+ return 0xDF;
+ case KEY_ENTER:
+ return 0x8D;
+ case KEY_EXIT: //TODO: Figure out if this is Esc or not.
+ return 0x9B;
+ // Convert regular characters
+ default:
+ if (c < 0x20 || c >= 0x60)
+ return -1;
+ if (c >= 0x40)
+ c -= 0x40;
+ break;
+ }
+
+ return c;
}
void TerminalInit()
{
+ // ncurses initialization functions.
initscr();
cbreak();
noecho();
curs_set(0);
keypad(stdscr, TRUE);
- AppleWindow = newwin(24, 40, 1, 1);
-
- // Draw the border.
+ // Draw decorative border.
attron(A_REVERSE);
move(0, 0);
printw(" ");
@@ -45,9 +64,13 @@ void TerminalInit()
mvprintw(27, 0, " ");
attroff(A_REVERSE);
-
+ // Create seperate Apple screen window.
+ AppleWindow = newwin(24, 40, 1, 1);
+
+ // @ prompt.
mvwaddch(AppleWindow, TermY, TermX, '@' | A_BLINK);
+ // Initialize the terminal shift register variables.
TerminalShiftRegister = (byte*)malloc(960);
TerminalShiftRegisterPosition = TerminalShiftRegister;
TerminalShiftRegisterOffset = 0;
@@ -60,60 +83,73 @@ void TerminalInit()
void TerminalClose()
{
free(TerminalShiftRegister);
- curs_set(1);
+ curs_set(1);
endwin();
}
-// Takes an an Apple I ASCII character.
-void TerminalInput(char n)
+void TerminalInput(byte n)
{
+ // Handle special characters and conversion.
+ switch (n)
+ {
+ case 0xDF: // Backslash
+ case 0x8D: // Enter
+ case 0x9B: // Escape
+ return;
+ default:
+ // Convert to ASCII
+ if (n < 0x20) n += 0x40;
+ }
+
+ // Place character
mvwaddch(AppleWindow, TermY, TermX, ' ');
mvwaddch(AppleWindow, TermY, TermX, n);
-
+
+ // Add character to register
*TerminalShiftRegisterPosition = n;
TerminalShiftRegisterPosition++;
if (TerminalShiftRegisterPosition >= (TerminalShiftRegister + 960))
TerminalShiftRegisterPosition = TerminalShiftRegister;
-
TermX++;
-
- //if (n == KEY_ENTER) {
- // TermY++;
- //}
-
+ // If X is past width..
if (TermX >= 40) {
+ //.. move to start of next line.
TermX = 0;
TermY++;
}
+ // If Y is past height..
if (TermY >= 24) {
- TerminalShiftRegisterOffset += 40; // Discard first line
- if (TerminalShiftRegisterOffset >= 960)
+ //.. discard the first line..
+ TerminalShiftRegisterOffset += 40;
+
+ //.. verify the register offset..
+ if (TerminalShiftRegisterOffset >= 960)
TerminalShiftRegisterOffset = TerminalShiftRegister;
+ //.. and create an offset variable to cycle through memory with.
byte *offset = TerminalShiftRegister + TerminalShiftRegisterOffset;
- // For every position, fill with contents of the terminal shift register
+ // Then, for every cell of the screen, fill with the contents of the video memory.
for (int i = 0; i < 23; i++) {
for (int j = 0; j < 40; j++) {
-
if (offset >= (TerminalShiftRegister + 960))
- offset -= 960;
-
- mvwaddch(AppleWindow, i, j, ToAscii(*(offset)));
+ offset -= TerminalShiftRegister;
+ mvwaddch(AppleWindow, i, j, (*offset < 0x20) ? *offset + 0x40 : *offset );
offset++;
}}
-
+
+ // Set to start of final line, and clear line.
TermY = 23;
TermX = 0;
-
- // Clear bottom line.
- mvwprintw(AppleWindow, TermY, TermX, " ");
+ mvwprintw(AppleWindow, TermY, TermX,
+ " ");
}
+ // @ prompt.
mvwaddch(AppleWindow, TermY, TermX, '@' | A_BLINK);
wrefresh(AppleWindow);
}