1
0
mirror of https://github.com/cc65/cc65.git synced 2025-01-12 02:30:44 +00:00

Added support for switching between 40/80 columns. As the Apple //e 80 column firmware features converting the current screen content on switching if was already active before the idea is to keep the 80 column firmware active and initialize it (which clears the screen) only if necessary.

git-svn-id: svn://svn.cc65.org/cc65/trunk@4140 b7a2c559-68d2-44c3-8de9-860c34a00d81
This commit is contained in:
ol.sc 2009-09-10 09:04:05 +00:00
parent 079358c3c1
commit 648a1b5427
4 changed files with 84 additions and 5 deletions

View File

@ -77,6 +77,7 @@ function.
<item>_textframe <item>_textframe
<item>_textframexy <item>_textframexy
<item><ref id="get_ostype" name="get_ostype"> <item><ref id="get_ostype" name="get_ostype">
<item><ref id="videomode" name="videomode">
</itemize> </itemize>
@ -5031,19 +5032,20 @@ used in presence of a prototype.
<quote> <quote>
<descrip> <descrip>
<tag/Function/Switch to either 40 or 80 column mode. <tag/Function/Switch to either 40 or 80 column mode.
<tag/Header/<tt/<ref id="c128.h" name="c128.h">/ <tag/Header/<tt/<ref id="apple2enh.h" name="apple2enh.h">,
<ref id="c128.h" name="c128.h">/
<tag/Declaration/<tt/unsigned __fastcall__ videomode (unsigned Mode);/ <tag/Declaration/<tt/unsigned __fastcall__ videomode (unsigned Mode);/
<tag/Description/Switch to 40 or 80 column mode depending on the argument. If <tag/Description/Switch to 40 or 80 column mode depending on the argument. If
the requested mode is already active, nothing happens. The old mode is returned the requested mode is already active, nothing happens. The old mode is returned
from the call. from the call.
<tag/Limits/<itemize> <tag/Limits/<itemize>
<item>The function is specific to the C128. <item>The function is specific to the C128 and enhanced Apple //e.
<item>This function is replaces <ref id="toggle_videomode" <item>This function replaces <ref id="toggle_videomode"
name="toggle_videomode">. name="toggle_videomode">.
<item>The function is only available as fastcall function, so it may only be <item>The function is only available as fastcall function, so it may only be
used in presence of a prototype. used in presence of a prototype.
</itemize> </itemize>
<tag/Availability/C128 <tag/Availability/C128 and enhanced Apple //e
<tag/See also/ <tag/See also/
<ref id="fast" name="fast">, <ref id="fast" name="fast">,
<ref id="slow" name="slow">, <ref id="slow" name="slow">,

View File

@ -76,6 +76,12 @@
#define _TEXTFRAME_WIDE 0x00 #define _TEXTFRAME_WIDE 0x00
#define _TEXTFRAME_TALL 0x04 #define _TEXTFRAME_TALL 0x04
/* Video modes */
#define VIDEOMODE_40x24 0x0011
#define VIDEOMODE_80x24 0x0012
#define VIDEOMODE_40COL VIDEOMODE_40x24
#define VIDEOMODE_80COL VIDEOMODE_80x24
/*****************************************************************************/ /*****************************************************************************/
@ -87,7 +93,7 @@
void __fastcall__ _textframe (unsigned char width, unsigned char height, void __fastcall__ _textframe (unsigned char width, unsigned char height,
unsigned char style); unsigned char style);
/* Output a frame on the text screen with the given width and height /* Output a frame on the text screen with the given width and height
* starting at the current cursor position and using the given style * starting at the current cursor position and using the given style.
*/ */
void __fastcall__ _textframexy (unsigned char x, unsigned char y, void __fastcall__ _textframexy (unsigned char x, unsigned char y,
@ -95,6 +101,11 @@ void __fastcall__ _textframexy (unsigned char x, unsigned char y,
unsigned char style); unsigned char style);
/* Same as "gotoxy (x, y); _textframe (width, height, style);" */ /* Same as "gotoxy (x, y); _textframe (width, height, style);" */
unsigned __fastcall__ videomode (unsigned mode);
/* Set the video mode, return the old mode. Call with one of the VIDEOMODE_xx
* constants.
*/
/* End of apple2enh.h */ /* End of apple2enh.h */

65
libsrc/apple2/videomode.s Normal file
View File

@ -0,0 +1,65 @@
;
; Oliver Schmidt, 07.09.2009
;
; unsigned __fastcall__ videomode (unsigned mode);
;
.export _videomode
.import COUT
.include "apple2.inc"
.segment "LOWCODE"
_videomode:
; Get and save current videomode flag
bit RD80VID
php
; If we are in 80 column mode then the 80 column firmware is
; known to be active so we can just print the ctrl-char code
; (even if this only means staying in the current videomode)
bpl :+
jsr COUT
bra done
; If we are in 40 column mode and want to set 40 column mode
; then we explicitly do nothing as we neither know about the
; current state of the 80 column firmware nor want to fix it
: cmp #$11 ; Ctrl-char code for 40 cols
beq done
; If we are in 40 column mode and want to set 80 column mode
; then we first presume the 80 column firmware being already
; active and print the ctrl-char code (this causes a garbage
: char to be printed on the screen if isn't already active)
jsr COUT
; If we successfully switched to 80 column mode then the 80
; column firmware was in fact already active and we're done
bit RD80VID
bmi done
; The 80 column firmware isn't already active so we need to
; initialize it - causing the screen to be cleared and thus
; the garbage char printed above to be erased (but for some
; reason the cursor horizontal position not not be zeroed)
stz CH
; Initializing the 80 column firmware needs the ROM switched
; in, otherwise it would copy the F8 ROM to the LC (@ $CEF4)
bit $C082
; Initialize 80 column firmware
jsr $C300 ; PR#3
; Switch in LC bank 2 for R/O
bit $C080
; Return ctrl-char code for setting previous
; videomode using the saved videomode flag
done: lda #$11 ; Ctrl-char code for 40 cols
plp
bpl :+
lda #$12 ; Ctrl-char code for 80 cols
: rts ; X was preserved all the way

View File

@ -100,6 +100,7 @@ S_OBJS= _scrsize.o \
sysuname.o \ sysuname.o \
textframe.o \ textframe.o \
tgi_mode_table.o\ tgi_mode_table.o\
videomode.o \
vtabz.o \ vtabz.o \
wherex.o \ wherex.o \
wherey.o \ wherey.o \