

|
Volume Number: | 2 | |
Issue Number: | 2 | |
Column Tag: | Basic School |
Asm Utility Speeds Screen Blanking
By Dave Kelly, Engineer, General Dynamics, MacTutor Editorial Board
For those that remember Professor Mac's Screen Pokes presented in the April 1985 issue of MacTutor, we discussed the Macintosh screen and how to poke the screen to all blank. The method presented there was very slow. Until such time as someone comes out with a MS BASIC compiler most routines will be slow. MacTutor now has a call out to anyone that has a complier for MS BASIC to step forward and become famous. Please contact us if you have any information to give us about compiled BASIC.
This month we will provide the alternative screen poke method using a library written in 68000 code. These routines were designed to work with the 512K or 128K versions of the Macintosh, however, the code may be modified to be used with other memory sizes.
If you are unfamiliar with BASIC libraries then we recommend that you refer to the BASIC School article in the November 1985 MacTutor on Building a Machine Language Library routine. (Back issues are available). The listings that follow are assembled in the same manner as discussed in that column.
There are three code routines that you need to be concerned with. The LIBinit.asm (Listing 1) routine may be found on page 44 of the Nov. 85 MacTutor. The second routine stores $FFFFFFFF in all screen locations, thus blacking out the entire screen. The third routine inverts all of the screen locations. We thank Serge Rostan of Pontoise, France for contributing the main code for the invert routine.[If you have some good ideas on Basic, please write Dave care of MacTutor and see them in print. -Ed]
The BlankScreen routine (Listing 2) is accessed by the statement: CALL BlankScreen (memory%) where memory% is the memory of your particular system (i. e. use memory%=512 or memory%=128). This routine works fine for 512K or 128K Macs, but you will have to change the equates for Screen512 and/or Screen128 (see listing 2) in order to accomodate other memory sizes. The equates 'GetNextLibArg', 'IntegerArg' and 'BasicError' are BASIC routines defined in BMLL (Microsoft's Building Machine Language Libraries) which library routines may call. The BlankScreen routine reads the memory% parameter and determines the screen location. Then each location is loaded with $FFFFFFFF and the screen is blank. The routine then returns back to the calling program.
The InvertScreen routine (Listing 3) works much the same as the BlankScreen routine. You may call the routine with the statement: CALL InvertScreen (memory%). The passed integer variable memory% is the same as in the BlankScreen routine. The only difference in this routine is that each memory location is exclusive-ored with the value $FFFFFFFF.
Listing 4 and 5 are the Linker and Resource complier files needed by the MDS system to create the library resource file. See Nov 1985 MacTutor for details on how to us these files.
The Screen Demo program in listing 6 demonstrates the use of the BlankScreen and InvertScreen routines. It is advisable but not mandatory that you hide the cursor using HIDECURSOR before blanking or inverting the screen. The cursor may be turned on again with the SHOWCURSOR statement. If the cursor is not disabled then the 16 X 16 cursor location will not be blanked or inverted properly. These libraries may be used to create special effects in your program such as flashing the screen.
Expanding BASIC using library routines greatly improves the capabilities of your programs. If you have a favorite library routine, please send it to us. We would like to share more libraries with other useful purposes.
LISTING 1 ;LIBinit routine (See MacTutor Nov. 1985 pg. 44 for comments) ;save as LIBinit.asm LIBVER_Result EQU 6 LIBinit: CLR.W LIBVER_Result(a0) LIBinitExit: MOVEQ #0,d0 RTS LISTING 2 ; BASIC BlankScreen Library Source Code ; By Dave Kelly ; MacTutor 1985 ;Synopsis: ;CALL BlankScreen (memory%) ;Output: GetNextLibArg EQU $2A IntegerArgEQU $32 BasicErrorEQU $42 Screen512 EQU ((512-128)*1024)+108288 Screen128 EQU 108288 JSR GetNextLibArg(a5) ;Get the next argument JSR IntegerArg(a5) ;[d3:w] = integer error if arg ;can't be forced into an ;integer. CMP.W #128,d3 BEQ Do128 ;branch if 128K memory CMP.W #512,d3 BEQ Do512 ;branch if 512K memory Device_Unavailable: MOVEQ #68,d2 ;Device Unavailable error JSR BasicError(a5) Do512: LEA Screen512,A0 BRA Blank Do128: LEA Screen128,A0 Blank: MOVE.W #5472-1,d1 ;setup high screen address MOVE.L #$FFFFFFFF,d0;move to d0 Loop: MOVE.L d0,(A0)+ ;set screen address to d0 DBRA d1,Loop RTS GetIntegerVar: JSR GetNextLibArg(a5) ;Get the next argument JSR IntegerArg(a5) ;[d3:w] = integer error if arg ;can't be forced into an ;integer RTS LISTING 3 ; BASIC InvertScreen Library Source Code ; By Dave Kelly ; MacTutor 1985 ;save InvertScreen.asm ;Synopsis: ;CALL InvertScreen ( memory%) ;Output: GetNextLibArg EQU $2A IntegerArgEQU $32 BasicErrorEQU $42 Screen512 EQU ((512-128)*1024)+108288 Screen128 EQU 108288 BSR GetIntegerVar;integer arg in [d3:w] CMP.W #128,d3 BEQ Do128 ;branch if 128K memory CMP.W #512,d3 BEQ Do512 ;branch if 512K memory Device_Unavailable: MOVEQ #68,d2 ;Device Unavailable error JSR BasicError(a5) Do512: LEA Screen512,A0 BRA Invert Do128: LEA Screen128,A0 Invert: MOVE.W #5472-1,D1 MOVE.L #$FFFFFFFF,D0 Loop: EOR.L D0,(A0)+ DBRA D1,Loop RTS GetIntegerVar: JSR GetNextLibArg(a5) ;Get the next argument JSR IntegerArg(a5) ;[d3:w] = integer (error if arg ;can't be forced into an ;integer RTS LISTING 4 ;Screen Library Link ;MacTutor 1986 /OUTPUT ScreenLib LIBinit.Rel < InvertScreen.Rel < BlankScreen.Rel $ LISTING 5 ScreenLib.Rsrc BLIB TYPE CODE = GNRL LIBinit,1 .R ScreenLib CODE 1 TYPE CODE = GNRL InvertScreen,2 .R ScreenLib CODE 2 TYPE CODE = GNRL BlankScreen,3 .R ScreenLib CODE 3 LISTING 6 'Screen Demo 'By Dave Kelly '©MacTutor 1986 LIBRARY "Screen Demo" mem%=128:IF FRE(0)>75000! THEN mem%=512 GOSUB Setmenubar MENU ON ON MENU GOSUB menucheck loop: GOTO loop menucheck: menunumber=MENU(0):IF menunumber<>6 THEN RETURN menuitem=MENU(1):MENU ON menuitem GOSUB Blank,invert,Flash,Demo,Quit Setmenubar: MENU RESET ' Re-do menu bar MENU 6,0,1,"Program Menu" MENU 6,1,1,"Blank Screen" MENU 6,2,1,"Invert Screen" MENU 6,3,1,"Flash Screen" MENU 6,4,1,"Demo" MENU 6,5,1,"Quit" RETURN Blank: HIDECURSOR CALL BlankScreen(mem%) SHOWCURSOR RETURN invert: HIDECURSOR CALL invertScreen(mem%) SHOWCURSOR RETURN Flash: HIDECURSOR FOR i=0 TO 100 CALL invertScreen(mem%) NEXT SHOWCURSOR RETURN Demo: WINDOW CLOSE 1 GOSUB Blank WINDOW 1,"",(42,90)-(475,300),3 PRINT "Click here" WHILE MOUSE(0)<>1:WEND GOSUB invert WHILE MOUSE(0)<>1:WEND GOSUB invert:CLS:GOSUB invert WINDOW 2,"",(102,140)-(410,240),3 PRINT "Click here" WHILE MOUSE(0)<>1:WEND GOSUB invert WHILE MOUSE(0)<>1:WEND GOSUB invert:CLS:GOSUB invert WINDOW 3,"",(152,165)-(360,215),3 PRINT "Click here" WHILE MOUSE(0)<>1:WEND GOSUB invert WHILE MOUSE(0)<>1:WEND GOSUB invert:CLS:GOSUB invert GOSUB invert PRINT SPC(4);"Please make selection":PRINT SPC(5);"from menus above!" RETURN Quit: FOR i=1 TO 4 WINDOW CLOSE i NEXT i MENU RESET:LIBRARY CLOSE CLS:END

- SPREAD THE WORD:
- Slashdot
- Digg
- Del.icio.us
- Newsvine