Home » Personal collection » Acorn DFS disks » dfs_box04_disk09_rgs_robotics_1.scp » GRPANEL
GRPANEL
This website contains an archive of files for the Acorn Electron, BBC Micro, Acorn Archimedes, Commodore 16 and Commodore 64 computers, which Dominic Ford has rescued from his private collection of floppy disks and cassettes.
Some of these files were originally commercial releases in the 1980s and 1990s, but they are now widely available online. I assume that copyright over them is no longer being asserted. If you own the copyright and would like files to be removed, please contact me.
Tape/disk: | Home » Personal collection » Acorn DFS disks » dfs_box04_disk09_rgs_robotics_1.scp |
Filename: | GRPANEL |
Read OK: | ✔ |
File size: | 1E07 bytes |
Load address: | FF1900 |
Exec address: | FF8023 |
File contents
10 REM INTERFACE DRIVER 15 REM FISCHER COMPUTING <--> ACORN BBC COMPUTER 20 REM COPYRIGHT (C) ARTUR FISCHER FORSCHUNG 1984 30 REM Use the following commands to control your FISCHERTECHNIK model with your Acorn Model B 35 REM 40 REM * * COMMANDS * * 45 REM 50 REM - CALL M1,CW% 55 REM Rotates Motor #1 clockwise 60 REM - CALL M1,CCW% 65 REM Rotates Motor #1 counter-clockwise 70 REM - CALL M1,GO% 75 REM Switches device connected to M1 on 80 REM - CALL M1,HALT% 85 REM Switches device connected to M1 off 90 REM Instead of "M1" you may also use M2, M3 or M4 95 REM - FNUSR (E1) 100 REM Returns a '0' or a '1' depending on the current state of the switch 105 REM Instead of 'E1' you may also use any of the keys 'E2' to 'E8' 110 REM - FNUSR (EX) 115 REM Returns a value depending on the current position of the potentiometer 120 REM Instead of 'EX' you can also use 'EY' to obtain a value from potentiometer Y 125 LET drr=&62 130 LET up=&60 135 LET til=&68 140 LET tih=&69 145 LET tic=&6B 150 LET avar=&80 155 LET mask=&81 160 LET buff=&82 165 LET asave=&84 170 LET xsave=&85 175 LET ysave=&86 180 DIM M% 500 185 FOR Z=0 TO 2 STEP 2 190 P%=M% 195[ 200 OPT Z 205 \ * * OUTPUT DRIVER * * 210 .init:lda #0:beq stvar:lda #3 :bne bout:lda #12:bne bout:lda #&30:bne bout:lda #&C0 215 .bout :sta mask:lda avar:ora mask:sta avar:jsr check:jmp ok2 220 .check :lda &0600:cmp #1:beq ok 225 .err1:brk:]:PROCequb (&FF):PROCequs ("Use exactly one parameter"):PROCequb (0):[OPT Z 230 .ok:lda&603: cmp #4:beq ok1 235 .err2:brk:]:PROCequb(&FF):PROCequs("Use integer parameters only"):PROCequb(0):[OPT Z 240 .ok1:lda &601:sta buff:lda &602:sta buff+1:ldy #0:lda (buff),Y 245 .back:rts 250 .ok2:and mask:sta mask: lda avar:eor mask 255 .stvar:sta avar: tay 260 .shout:jsr save:ldy #&3F:ldx #drr:jsr write:jsr load:ldx #8 265 .loop: lda #&30:asl avar: bcc null:ora #4 270 .null:jsr save:tay:ldx #up:jsr write:jsr load:ora #8:jsr save:tay:ldx #up 275 jsr write:jsr load:dex:bne loop:jsr save:ldy #&31:ldx #up:jsr write:jsr load:sty avar:rts 280 .E1:ldx #1:jmp test 285 .E2:ldx #2:jmp test 290 .E3:ldx #4:jmp test 295 .E4:ldx #8:jmp test 300 .E5:ldx #16:jmp test 305 .E6:ldx #32:jmp test 310 .E7:ldx #64:jmp test 315 .E8:ldx #128 320 .test:stx mask:lda #&32:jsr save:ldy asave:ldx #up:jsr write:jsr load:ora #8:jsr save:ldy asave:ldx #up:jsr write:jsr load:ldx #8 325 .loop2:asl A:jsr save:ldx #up:jsr read:tya:and #&80:beq nul2:jsr load:ora #1:jmp nul3 330 .nul2:jsr load 335 .nul3:jsr save:ldy #&30:ldx #up:jsr write:jsr load:ldy #&38:ldx #up:jsr write:jsr load:dex:bne loop2:and mask:beq back1:lda #1 340 .back1 345 rts 350 .EX:ldx #&A0:jmp poti 355 .EY:ldx #&90 360 .poti:sei:jsr save:ldy #&20:ldx #tic:jsr write:ldy #&FF:ldx #til:jsr write:ldy #&FF:ldx #tih:jsr write:ldy xsave 365 ldx #up:jsr write:ldy #&38:ldx #up:jsr write:jsr load 370 .tst:jsr save:ldx #til:jsr read:sty ysave:jsr load:tya:ldx #200 375 .delay:dex:bne delay:jsr save:ldx #til:jsr read:sty ysave:jsr load:sec:sbc ysave:bne tst:jsr save:ldx #til:jsr read:sty ysave:jsr load:sec:lda #&FF:sbc ysave:cli:rts 380 .write:lda #&97:jsr &FFF4:clc:rts 385 .read:lda #&96:jsr &FFF4:clc:rts 390 .save:sta asave:stx xsave:sty ysave:rts 395 .load:lda asave:ldx xsave:ldy ysave:rts 400] 405 NEXT Z 410 LET M1=init+4 415 LET M2=init+8 420 LET M3=init+12 425 LET M4=init+16 430 LET INIT=init 435 LET CW%=85 440 LET CCW%=170 445 LET GO%=85 450 LET HALT%=255 455 REM * * * END OF DRIVER * * * 460 DEF FNUSR(A)=USR(A) AND &FF 470 DEFPROCequb(num):?P%=num:P%=P%+1:ENDPROC 480 DEFPROCequs(text$):$P%=text$:P%=P%+LEN text$:ENDPROC 500 CALL INIT 510 REM FISCHERTECHNIK COMPUTING 520 REM 530 REM GRAPHIC PANEL 540 REM 550 REM COPYRIGHT (C) 1984 560 REM BY ARTUR FISCHER FORSCHUNG 600 REM 610 REM INPUT 620 REM E1=READ IN ANGULAR VALUES 630 REM E2=SHIFT-KEY 640 REM E3=PLOT A PIXEL / PRINT CHARACTER 650 REM E4=DRAW A LINE (FIXED COORDINATES) / DRAW OFFHAND LINE - END-POINT IS FIXED BY PRESSING E1. 660 REM E5=TRIANGLE / FILL IT 670 REM E6=RECTANGLE / FILL IT 680 REM E7=CIRCLE /FILL IT 690 REM E8=CLEAR SCREEN 700 REM EX=BETA 710 REM EY=ALPHA 720 REM 730 REM OUTPUT 740 REM M1=GRAPHIC IS ACTIVE 750 REM M2=READY FOR INPUT 760 REM 770 REM FUNCTION DESCRIPTION 780 REM TRANSFER A PICTURE ONTO 790 REM THE GRAPHIC SCREEN OF THE 800 REM COMPUTER. 810 REM 820 REM GEOMETRIC DATA 830 LET WA=-0.68068 : REM ANGLE ALPHA TOP LEFT 840 LET WB=0.93724 : REM ANGLE BETA TOP LEFT 850 LET A=166 : REM LENGTH OF ARM 860 LET X0=137 : REM ORIGIN OF CO_ORDINATE SYSTEM 870 LET Y0=247 880 LET SX=4*1.2364 : REM SCALE FACTOR X-AXIS (PIXELS/MM) 890 LET SY=4*1.1963 : REM SCALE FACTOR Y-AXIS (PIXELS/MM) 900 MODE6 910 PRINT "FISCHERTECHNIK" 920 PRINT "COMPUTING" 930 PRINT 940 PRINT "GRAPHIC PANEL" 950 PRINT 960 970 PRINT "PLEASE CALIBRATE" 980 PRINT 990 PRINT "POSTION PEN" 1000 PRINT "IN THE UPPER LEFT CORNER" 1010 PRINT "DEPRESS READ_IN KEY" 1020 IF FNUSR(E1)=0 THEN GOTO 1020:REM WAIT FOR ACCEPT KEY 1030 LET A1=FNUSR(EY) 1040 LET B1=FNUSR(EX) 1050 IF FNUSR(E1)=1 THEN GOTO 1050:REM WAIT UNTIL KEY IS NO LONGER DEPRESSED 1060 PRINT 1070 PRINT "POSITION PEN" 1080 PRINT "IN THE LOWER RIGHT CORNER" 1090 PRINT "DEPRESS READ_IN KEY" 1100 IF FNUSR(E1)=0 THEN GOTO 1100:REM WAIT FOR READ_IN KEY 1110 LET A2=FNUSR(EY) 1120 LET B2=FNUSR(EX) 1130 IF FNUSR(E1)=1 THEN GOTO 1130:REM WAIT UNTIL KEY IS NO LONGER DEPRESSED 1140 LET AF=2.12058/(A2-A1): REM 2.12058 RAD=ALPHA2-ALPHA1 1150 LET BF=1.02102/(B2-B1): REM 1.02102 RAD=BETA2-BETA1 1160 MODE4:VDU 5:REM RESOLUTION 320x256, 2 COLOURS ; GRAPHIC CURSOR ENABLED 1170 CALL M1,HALT%:REM 'ACTIVE'-INDICATOR OFF 1180 CALL M2,GO% :REM 'READY'-INDICATOR ON 1190 S=FNUSR(E2)*7 1200 S=S+FNUSR(E3) 1210 S=S+FNUSR(E4)*2 1220 S=S+FNUSR(E5)*3 1230 S=S+FNUSR(E6)*4 1240 S=S+FNUSR(E7)*5 1250 S=S+FNUSR(E8)*6 1260 IF S=0 OR S=7 GOTO 1190 1270 CALL M2,HALT%: REM 'READY'-INDICATOR OFF 1280 CALL M1,GO%:REM 'ACTIVE'-INDICATOR ON 1290 ON S GOTO 1300,1330,1390,1410,1480,1160,1170,1510,1560,1620,1650,1710,1170 1300 GOSUB 1740:REM COORDINATES 1310 PLOT 69,X,Y:REM PLOT PIXEL 1320 GOTO 1170 1330 GOSUB 1740:REM COORDINATES 1340 LET X1=X 1350 LET Y1=Y:REM SAVE COORDINATES 1360 GOSUB 1740 1370 MOVE X1,Y1:DRAW X,Y: REM DRAW LINE 1380 GOTO 1170 1390 GOSUB 2050:REM DRAW TRIANGLE 1400 GOTO 1170 1410 GOSUB 1740:REM COORDINATES 1420 LET X1=X 1430 LET Y1=Y 1440 GOSUB 1740:REM COORDINATES 1450 MOVE X1,Y1:DRAW X,Y1:DRAW X,Y:DRAW X1,Y:DRAW X1,Y1 1460 REM RECTANGLE 1470 GOTO 1170 1480 K=65 1490 GOSUB 2170:REM DRAW CIRCLE 1500 GOTO 1170 1510 GOSUB 1740:REM COORDINATES 1520 C=GET 1530 C$=CHR$(C) 1540 MOVE X,Y:PRINT C$:REM DISPLAY CHARACTER 1550 GOTO 1170 1560 GOSUB 1740:REM START SIGNAL 1570 IF FNUSR(E1)=1 THEN GOTO 1170 1580 GOSUB 1900: REM COORDINATES 1590 IF X<>X1 OR Y<>Y1 THEN MOVE X,Y:DRAW X1,Y1 1600 X=X1:Y=Y1 1610 GOTO 1570 1620 GOSUB 2050 1630 MOVE X1,Y1:MOVE X2,Y2:PLOT 85,X,Y: REM FILL TRIANGLE 1640 GOTO 1170 1650 GOSUB 1740:REM COORDINATES 1660 LET X1=X 1670 LET Y1=Y:REM SAVE COORDINATES 1680 GOSUB 1740:REM COORDINATES 1690 MOVE X1,Y1:MOVE X1,Y:PLOT 85,X,Y:MOVE X1,Y1:MOVE X,Y1:PLOT 85,X,Y 1700 GOTO 1170 1710 K=81 1720 GOSUB 2170:REM PAINT CIRCLE 1730 GOTO 1170 1740 REM READ COORDINATES 1750 IF FNUSR(E1)=0 THEN GOTO 1750 1760 LET ALPHA=(FNUSR(EY)-A1)*AF+WA 1770 LET BETA=(FNUSR(EX)-B1)*BF+WB 1780 REM READ ANGLE 1790 LET X=INT(SX*(X0-A*COS(ALPHA)+A*COS(BETA-ALPHA))) 1800 LET Y=INT(SY*(Y0-A*SIN(ALPHA)-A*SIN(BETA-ALPHA))) 1810 IF X<0 THEN LET X=0 1820 IF X>1279 THEN LET X=1279 1830 IF Y<0 THEN LET Y=0 1840 IF Y>1023 THEN LET Y=1023 1850 IF FNUSR(E1)=1 THEN GOTO 1850 1890 RETURN 1900 REM READ COORDINATES WITHOUT WAITING FOR READ_IN-KEY 1910 LET ALPHA=(FNUSR(EY)-A1)*AF+WA 1920 LET BETA=(FNUSR(EX)-B1)*BF+WB 1930 REM READ ANGLES 1940 LET X1=INT(SX*(X0-A*COS(ALPHA)+A*COS(BETA-ALPHA))) 1950 LET Y1=INT(SY*(Y0-A*SIN(ALPHA)-A*SIN(BETA-ALPHA))) 1960 IF X1<0 THEN LET X1=0 1970 IF X1>1279 THEN LET X1=1279 1980 IF Y1<0 THEN LET Y1=0 1990 IF Y1>1023 THEN LET Y1=1023 2030 RETURN 2040 REM SUBROUTINE 'TRIANGLE' 2050 GOSUB 1740:REM COORDINATES 2060 LET X1=X 2070 LET Y1=Y:REM SAVE COORDINATES 2080 GOSUB 1740:REM COORDINATES 2090 LET X2=X 2100 LET Y2=Y :REM SAVE COORDINATES 2110 GOSUB 1740:REM COORDINATES 2120 MOVE X1,Y1:DRAW X2,Y2 2130 MOVE X2,Y2:DRAW X,Y 2140 MOVE X,Y:DRAW X1,Y1 2150 RETURN 2160 REM SUBROUTINE 'CIRCLE' 2170 GOSUB 1740:REM COORDINATES 2180 LET X1=X 2190 LET Y1=Y 2200 GOSUB 1740:REM COORDINATES 2210 LET R=SQR((X1-X)^2+(Y1-Y)^2) 2220 FOR PHI=0 TO PI*2 STEP (PI/128) 2230 LET XC=COS(PHI)*R 2240 LET YC=SIN(PHI)*R 2250 IF K=81 AND PHI=0 THEN MOVE X1,Y1 2260 MOVE X1,Y1:REM CENTRE OF CIRLE 2270 PLOT K,XC,YC 2280 NEXT PHI 2290 RETURN
� INTERFACE DRIVER 1 � FISCHER COMPUTING <--> ACORN BBC COMPUTER 1 � COPYRIGHT (C) ARTUR FISCHER FORSCHUNG 1984 ^ � Use the following commands to control your FISCHERTECHNIK model with your Acorn Model B # � ( � * * COMMANDS * * - � 2 � - CALL M1,CW% 7# � Rotates Motor #1 clockwise < � - CALL M1,CCW% A+ � Rotates Motor #1 counter-clockwise F � - CALL M1,GO% K+ � Switches device connected to M1 on P � - CALL M1,HALT% U, � Switches device connected to M1 off Z4 � Instead of "M1" you may also use M2, M3 or M4 _ � - FNUSR (E1) dL � Returns a '0' or a '1' depending on the current state of the switch iD � Instead of 'E1' you may also use any of the keys 'E2' to 'E8' n � - FNUSR (EX) sO � Returns a value depending on the current position of the potentiometer xS � Instead of 'EX' you can also use 'EY' to obtain a value from potentiometer Y } � drr=&62 � � up=&60 � � til=&68 � � tih=&69 � � tic=&6B � � avar=&80 � � mask=&81 � � buff=&82 � � asave=&84 � � xsave=&85 � � ysave=&86 � � M% 500 � � Z=0 � 2 � 2 � P%=M% �[ � OPT Z � \ * * OUTPUT DRIVER * * �X .init:lda #0:beq stvar:lda #3 :bne bout:lda #12:bne bout:lda #&30:bne bout:lda #&C0 �A .bout :sta mask:lda avar:ora mask:sta avar:jsr check:jmp ok2 �$ .check :lda &0600:cmp #1:beq ok �Q .err1:brk:]:�equb (&FF):�equs ("Use exactly one parameter"):�equb (0):[OPT Z �" .ok:lda&603: cmp #4:beq ok1 �P .err2:brk:]:�equb(&FF):�equs("Use integer parameters only"):�equb(0):[OPT Z �C .ok1:lda &601:sta buff:lda &602:sta buff+1:ldy #0:lda (buff),Y � .back:rts �/ .ok2:and mask:sta mask: lda avar:eor mask � .stvar:sta avar: tay @ .shout:jsr save:ldy #&3F:ldx #drr:jsr write:jsr load:ldx #8 . .loop: lda #&30:asl avar: bcc null:ora #4 N .null:jsr save:tay:ldx #up:jsr write:jsr load:ora #8:jsr save:tay:ldx #up ^ jsr write:jsr load:dex:bne loop:jsr save:ldy #&31:ldx #up:jsr write:jsr load:sty avar:rts .E1:ldx #1:jmp test .E2:ldx #2:jmp test " .E3:ldx #4:jmp test ' .E4:ldx #8:jmp test , .E5:ldx #16:jmp test 1 .E6:ldx #32:jmp test 6 .E7:ldx #64:jmp test ; .E8:ldx #128 @� .test:stx mask:lda #&32:jsr save:ldy asave:ldx #up:jsr write:jsr load:ora #8:jsr save:ldy asave:ldx #up:jsr write:jsr load:ldx #8 EZ .loop2:asl A:jsr save:ldx #up:jsr read:tya:and #&80:beq nul2:jsr load:ora #1:jmp nul3 J .nul2:jsr load O� .nul3:jsr save:ldy #&30:ldx #up:jsr write:jsr load:ldy #&38:ldx #up:jsr write:jsr load:dex:bne loop2:and mask:beq back1:lda #1 T .back1 Y rts ^ .EX:ldx #&A0:jmp poti c .EY:ldx #&90 hu .poti:sei:jsr save:ldy #&20:ldx #tic:jsr write:ldy #&FF:ldx #til:jsr write:ldy #&FF:ldx #tih:jsr write:ldy xsave m: ldx #up:jsr write:ldy #&38:ldx #up:jsr write:jsr load rD .tst:jsr save:ldx #til:jsr read:sty ysave:jsr load:tya:ldx #200 w� .delay:dex:bne delay:jsr save:ldx #til:jsr read:sty ysave:jsr load:sec:sbc ysave:bne tst:jsr save:ldx #til:jsr read:sty ysave:jsr load:sec:lda #&FF:sbc ysave:cli:rts |& .write:lda #&97:jsr &FFF4:clc:rts �% .read:lda #&96:jsr &FFF4:clc:rts �- .save:sta asave:stx xsave:sty ysave:rts �, .load:lda asave:ldx xsave:ldy ysave:rts �] � � Z � � M1=init+4 � � M2=init+8 � � M3=init+12 � � M4=init+16 � � INIT=init � � CW%=85 � � CCW%=170 � � GO%=85 � � HALT%=255 � � * * * END OF DRIVER * * * � � �USR(A)=�(A) � &FF �" ��equb(num):?P%=num:P%=P%+1:� �, ��equs(text$):$P%=text$:P%=P%+� text$:� � � INIT � � FISCHERTECHNIK COMPUTING � � GRAPHIC PANEL � & � COPYRIGHT (C) 1984 0! � BY ARTUR FISCHER FORSCHUNG X � b � INPUT l � E1=READ IN ANGULAR VALUES v � E2=SHIFT-KEY �( � E3=PLOT A PIXEL / PRINT CHARACTER �b � E4=DRAW A LINE (FIXED COORDINATES) / DRAW OFFHAND LINE - END-POINT IS FIXED BY PRESSING E1. � � E5=TRIANGLE / FILL IT � � E6=RECTANGLE / FILL IT � � E7=CIRCLE /FILL IT � � E8=CLEAR SCREEN � � EX=BETA � � EY=ALPHA � � � � OUTPUT � � M1=GRAPHIC IS ACTIVE � � M2=READY FOR INPUT � � � FUNCTION DESCRIPTION � TRANSFER A PICTURE ONTO � THE GRAPHIC SCREEN OF THE � COMPUTER. * � 4 � GEOMETRIC DATA >+ � WA=-0.68068 : � ANGLE ALPHA TOP LEFT H) � WB=0.93724 : � ANGLE BETA TOP LEFT R � A=166 : � LENGTH OF ARM \. � X0=137 : � ORIGIN OF CO_ORDINATE SYSTEM f � Y0=247 p6 � SX=4*1.2364 : � SCALE FACTOR X-AXIS (PIXELS/MM) z6 � SY=4*1.1963 : � SCALE FACTOR Y-AXIS (PIXELS/MM) � �6 � � "FISCHERTECHNIK" � � "COMPUTING" � � � � "GRAPHIC PANEL" � � � � � "PLEASE CALIBRATE" � � � � "POSTION PEN" �! � "IN THE UPPER LEFT CORNER" � � "DEPRESS READ_IN KEY" �0 � �USR(E1)=0 � � �d|C:� WAIT FOR ACCEPT KEY � A1=�USR(EY) � B1=�USR(EX) B � �USR(E1)=1 � � �TZD:� WAIT UNTIL KEY IS NO LONGER DEPRESSED $ � . � "POSITION PEN" 8" � "IN THE LOWER RIGHT CORNER" B � "DEPRESS READ_IN KEY" L3 � �USR(E1)=0 � � �DLD:� WAIT FOR READ_IN KEY V � A2=�USR(EY) ` � B2=�USR(EX) jB � �USR(E1)=1 � � �DjD:� WAIT UNTIL KEY IS NO LONGER DEPRESSED t6 � AF=2.12058/(A2-A1): � 2.12058 RAD=ALPHA2-ALPHA1 ~4 � BF=1.02102/(B2-B1): � 1.02102 RAD=BETA2-BETA1 �D �4:� 5:� RESOLUTION 320x256, 2 COLOURS ; GRAPHIC CURSOR ENABLED �( � M1,HALT%:� 'ACTIVE'-INDICATOR OFF �& � M2,GO% :� 'READY'-INDICATOR ON � S=�USR(E2)*7 � S=S+�USR(E3) � S=S+�USR(E4)*2 � S=S+�USR(E5)*3 � S=S+�USR(E6)*4 � S=S+�USR(E7)*5 � S=S+�USR(E8)*6 � � S=0 � S=7 � �tfD �( � M2,HALT%: � 'READY'-INDICATOR OFF % � M1,GO%:� 'ACTIVE'-INDICATOR ON K � S � �TTE,�TrE,�DnE,�tBE,�dHE,�tHD,�tRD,�dfE,�TXF,�DTF,�DrF,�tnF,�tRD � �dLF:� COORDINATES � 69,X,Y:� PLOT PIXEL ( � �tRD 2 � �dLF:� COORDINATES < � X1=X F � Y1=Y:� SAVE COORDINATES P � �dLF Z � X1,Y1:� X,Y: � DRAW LINE d � �tRD n � �TBH:� DRAW TRIANGLE x � �tRD � � �dLF:� COORDINATES � � X1=X � � Y1=Y � � �dLF:� COORDINATES �( � X1,Y1:� X,Y1:� X,Y:� X1,Y:� X1,Y1 � � RECTANGLE � � �tRD � K=65 � � �DzH:� DRAW CIRCLE � � �tRD � � �dLF:� COORDINATES � C=� � C$=�(C) # � X,Y:� C$:� DISPLAY CHARACTER � �tRD � �dLF:� START SIGNAL " � �USR(E1)=1 � � �tRD , � �DlG: � COORDINATES 6$ � X<>X1 � Y<>Y1 � � X,Y:� X1,Y1 @ X=X1:Y=Y1 J � �TbF T � �TBH ^. � X1,Y1:� X2,Y2:� 85,X,Y: � FILL TRIANGLE h � �tRD r � �dLF:� COORDINATES | � X1=X � � Y1=Y:� SAVE COORDINATES � � �dLF:� COORDINATES �4 � X1,Y1:� X1,Y:� 85,X,Y:� X1,Y1:� X,Y1:� 85,X,Y � � �tRD � K=81 � � �DzH:� PAINT CIRCLE � � �tRD � � READ COORDINATES � � �USR(E1)=0 � � �dVF � � ALPHA=(�USR(EY)-A1)*AF+WA � � BETA=(�USR(EX)-B1)*BF+WB � � READ ANGLE �. � X=�(SX*(X0-A*�(ALPHA)+A*�(BETA-ALPHA))) . � Y=�(SY*(Y0-A*�(ALPHA)-A*�(BETA-ALPHA))) � X<0 � � X=0 � X>1279 � � X=1279 & � Y<0 � � Y=0 0 � Y>1023 � � Y=1023 : � �USR(E1)=1 � � �TzG b � l: � READ COORDINATES WITHOUT WAITING FOR READ_IN-KEY v � ALPHA=(�USR(EY)-A1)*AF+WA � � BETA=(�USR(EX)-B1)*BF+WB � � READ ANGLES �/ � X1=�(SX*(X0-A*�(ALPHA)+A*�(BETA-ALPHA))) �/ � Y1=�(SY*(Y0-A*�(ALPHA)-A*�(BETA-ALPHA))) � � X1<0 � � X1=0 � � X1>1279 � � X1=1279 � � Y1<0 � � Y1=0 � � Y1>1023 � � Y1=1023 � � � � SUBROUTINE 'TRIANGLE' � �dLF:� COORDINATES � X1=X � Y1=Y:� SAVE COORDINATES � �dLF:� COORDINATES * � X2=X 4 � Y2=Y :� SAVE COORDINATES > � �dLF:� COORDINATES H � X1,Y1:� X2,Y2 R � X2,Y2:� X,Y \ � X,Y:� X1,Y1 f � p � SUBROUTINE 'CIRCLE' z � �dLF:� COORDINATES � � X1=X � � Y1=Y � � �dLF:� COORDINATES � � R=�((X1-X)^2+(Y1-Y)^2) � � PHI=0 � �*2 � (�/128) � � XC=�(PHI)*R � � YC=�(PHI)*R � � K=81 � PHI=0 � � X1,Y1 � � X1,Y1:� CENTRE OF CIRLE � � K,XC,YC � � PHI � � �
00000000 0d 00 0a 17 20 f4 20 49 4e 54 45 52 46 41 43 45 |.... . INTERFACE| 00000010 20 44 52 49 56 45 52 0d 00 0f 31 20 f4 20 46 49 | DRIVER...1 . FI| 00000020 53 43 48 45 52 20 43 4f 4d 50 55 54 49 4e 47 20 |SCHER COMPUTING | 00000030 3c 2d 2d 3e 20 41 43 4f 52 4e 20 20 42 42 43 20 |<--> ACORN BBC | 00000040 43 4f 4d 50 55 54 45 52 0d 00 14 31 20 f4 20 43 |COMPUTER...1 . C| 00000050 4f 50 59 52 49 47 48 54 20 28 43 29 20 41 52 54 |OPYRIGHT (C) ART| 00000060 55 52 20 46 49 53 43 48 45 52 20 46 4f 52 53 43 |UR FISCHER FORSC| 00000070 48 55 4e 47 20 31 39 38 34 0d 00 1e 5e 20 f4 20 |HUNG 1984...^ . | 00000080 55 73 65 20 74 68 65 20 66 6f 6c 6c 6f 77 69 6e |Use the followin| 00000090 67 20 63 6f 6d 6d 61 6e 64 73 20 74 6f 20 63 6f |g commands to co| 000000a0 6e 74 72 6f 6c 20 79 6f 75 72 20 46 49 53 43 48 |ntrol your FISCH| 000000b0 45 52 54 45 43 48 4e 49 4b 20 6d 6f 64 65 6c 20 |ERTECHNIK model | 000000c0 77 69 74 68 20 79 6f 75 72 20 41 63 6f 72 6e 20 |with your Acorn | 000000d0 4d 6f 64 65 6c 20 42 0d 00 23 07 20 f4 20 0d 00 |Model B..#. . ..| 000000e0 28 1b 20 f4 20 20 20 20 20 2a 20 2a 20 43 4f 4d |(. . * * COM| 000000f0 4d 41 4e 44 53 20 2a 20 2a 0d 00 2d 07 20 f4 20 |MANDS * *..-. . | 00000100 0d 00 32 14 20 f4 20 2d 20 43 41 4c 4c 20 4d 31 |..2. . - CALL M1| 00000110 2c 43 57 25 0d 00 37 23 20 f4 20 20 20 52 6f 74 |,CW%..7# . Rot| 00000120 61 74 65 73 20 4d 6f 74 6f 72 20 23 31 20 63 6c |ates Motor #1 cl| 00000130 6f 63 6b 77 69 73 65 0d 00 3c 15 20 f4 20 2d 20 |ockwise..<. . - | 00000140 43 41 4c 4c 20 4d 31 2c 43 43 57 25 0d 00 41 2b |CALL M1,CCW%..A+| 00000150 20 f4 20 20 20 52 6f 74 61 74 65 73 20 4d 6f 74 | . Rotates Mot| 00000160 6f 72 20 23 31 20 63 6f 75 6e 74 65 72 2d 63 6c |or #1 counter-cl| 00000170 6f 63 6b 77 69 73 65 0d 00 46 14 20 f4 20 2d 20 |ockwise..F. . - | 00000180 43 41 4c 4c 20 4d 31 2c 47 4f 25 0d 00 4b 2b 20 |CALL M1,GO%..K+ | 00000190 f4 20 20 20 53 77 69 74 63 68 65 73 20 64 65 76 |. Switches dev| 000001a0 69 63 65 20 63 6f 6e 6e 65 63 74 65 64 20 74 6f |ice connected to| 000001b0 20 4d 31 20 6f 6e 0d 00 50 16 20 f4 20 2d 20 43 | M1 on..P. . - C| 000001c0 41 4c 4c 20 4d 31 2c 48 41 4c 54 25 0d 00 55 2c |ALL M1,HALT%..U,| 000001d0 20 f4 20 20 20 53 77 69 74 63 68 65 73 20 64 65 | . Switches de| 000001e0 76 69 63 65 20 63 6f 6e 6e 65 63 74 65 64 20 74 |vice connected t| 000001f0 6f 20 4d 31 20 6f 66 66 0d 00 5a 34 20 f4 20 49 |o M1 off..Z4 . I| 00000200 6e 73 74 65 61 64 20 6f 66 20 22 4d 31 22 20 79 |nstead of "M1" y| 00000210 6f 75 20 6d 61 79 20 61 6c 73 6f 20 75 73 65 20 |ou may also use | 00000220 4d 32 2c 20 4d 33 20 6f 72 20 4d 34 0d 00 5f 14 |M2, M3 or M4.._.| 00000230 20 f4 20 2d 20 46 4e 55 53 52 20 28 45 31 29 20 | . - FNUSR (E1) | 00000240 0d 00 64 4c 20 f4 20 20 20 52 65 74 75 72 6e 73 |..dL . Returns| 00000250 20 61 20 27 30 27 20 6f 72 20 61 20 27 31 27 20 | a '0' or a '1' | 00000260 64 65 70 65 6e 64 69 6e 67 20 6f 6e 20 74 68 65 |depending on the| 00000270 20 63 75 72 72 65 6e 74 20 73 74 61 74 65 20 6f | current state o| 00000280 66 20 74 68 65 20 73 77 69 74 63 68 0d 00 69 44 |f the switch..iD| 00000290 20 f4 20 49 6e 73 74 65 61 64 20 6f 66 20 27 45 | . Instead of 'E| 000002a0 31 27 20 79 6f 75 20 6d 61 79 20 61 6c 73 6f 20 |1' you may also | 000002b0 75 73 65 20 61 6e 79 20 6f 66 20 74 68 65 20 6b |use any of the k| 000002c0 65 79 73 20 27 45 32 27 20 74 6f 20 27 45 38 27 |eys 'E2' to 'E8'| 000002d0 0d 00 6e 13 20 f4 20 2d 20 46 4e 55 53 52 20 28 |..n. . - FNUSR (| 000002e0 45 58 29 0d 00 73 4f 20 f4 20 20 20 52 65 74 75 |EX)..sO . Retu| 000002f0 72 6e 73 20 61 20 76 61 6c 75 65 20 64 65 70 65 |rns a value depe| 00000300 6e 64 69 6e 67 20 6f 6e 20 74 68 65 20 63 75 72 |nding on the cur| 00000310 72 65 6e 74 20 70 6f 73 69 74 69 6f 6e 20 6f 66 |rent position of| 00000320 20 74 68 65 20 70 6f 74 65 6e 74 69 6f 6d 65 74 | the potentiomet| 00000330 65 72 0d 00 78 53 20 f4 20 49 6e 73 74 65 61 64 |er..xS . Instead| 00000340 20 6f 66 20 27 45 58 27 20 79 6f 75 20 63 61 6e | of 'EX' you can| 00000350 20 61 6c 73 6f 20 75 73 65 20 27 45 59 27 20 74 | also use 'EY' t| 00000360 6f 20 6f 62 74 61 69 6e 20 61 20 76 61 6c 75 65 |o obtain a value| 00000370 20 66 72 6f 6d 20 70 6f 74 65 6e 74 69 6f 6d 65 | from potentiome| 00000380 74 65 72 20 59 0d 00 7d 0e 20 e9 20 64 72 72 3d |ter Y..}. . drr=| 00000390 26 36 32 0d 00 82 0d 20 e9 20 75 70 3d 26 36 30 |&62.... . up=&60| 000003a0 0d 00 87 0e 20 e9 20 74 69 6c 3d 26 36 38 0d 00 |.... . til=&68..| 000003b0 8c 0e 20 e9 20 74 69 68 3d 26 36 39 0d 00 91 0e |.. . tih=&69....| 000003c0 20 e9 20 74 69 63 3d 26 36 42 0d 00 96 0f 20 e9 | . tic=&6B.... .| 000003d0 20 61 76 61 72 3d 26 38 30 0d 00 9b 0f 20 e9 20 | avar=&80.... . | 000003e0 6d 61 73 6b 3d 26 38 31 0d 00 a0 10 20 e9 20 62 |mask=&81.... . b| 000003f0 75 66 66 3d 26 38 32 20 0d 00 a5 10 20 e9 20 61 |uff=&82 .... . a| 00000400 73 61 76 65 3d 26 38 34 0d 00 aa 10 20 e9 20 78 |save=&84.... . x| 00000410 73 61 76 65 3d 26 38 35 0d 00 af 10 20 e9 20 79 |save=&85.... . y| 00000420 73 61 76 65 3d 26 38 36 0d 00 b4 0d 20 de 20 4d |save=&86.... . M| 00000430 25 20 35 30 30 0d 00 b9 12 20 e3 20 5a 3d 30 20 |% 500.... . Z=0 | 00000440 b8 20 32 20 88 20 32 0d 00 be 0a 20 50 25 3d 4d |. 2 . 2.... P%=M| 00000450 25 0d 00 c3 05 5b 0d 00 c8 0a 20 4f 50 54 20 5a |%....[.... OPT Z| 00000460 0d 00 cd 1c 20 5c 20 2a 20 2a 20 4f 55 54 50 55 |.... \ * * OUTPU| 00000470 54 20 44 52 49 56 45 52 20 2a 20 2a 0d 00 d2 58 |T DRIVER * *...X| 00000480 20 2e 69 6e 69 74 3a 6c 64 61 20 23 30 3a 62 65 | .init:lda #0:be| 00000490 71 20 73 74 76 61 72 3a 6c 64 61 20 23 33 20 3a |q stvar:lda #3 :| 000004a0 62 6e 65 20 62 6f 75 74 3a 6c 64 61 20 23 31 32 |bne bout:lda #12| 000004b0 3a 62 6e 65 20 62 6f 75 74 3a 6c 64 61 20 23 26 |:bne bout:lda #&| 000004c0 33 30 3a 62 6e 65 20 62 6f 75 74 3a 6c 64 61 20 |30:bne bout:lda | 000004d0 23 26 43 30 0d 00 d7 41 20 2e 62 6f 75 74 20 3a |#&C0...A .bout :| 000004e0 73 74 61 20 6d 61 73 6b 3a 6c 64 61 20 61 76 61 |sta mask:lda ava| 000004f0 72 3a 6f 72 61 20 6d 61 73 6b 3a 73 74 61 20 61 |r:ora mask:sta a| 00000500 76 61 72 3a 6a 73 72 20 63 68 65 63 6b 3a 6a 6d |var:jsr check:jm| 00000510 70 20 6f 6b 32 0d 00 dc 24 20 2e 63 68 65 63 6b |p ok2...$ .check| 00000520 20 3a 6c 64 61 20 26 30 36 30 30 3a 63 6d 70 20 | :lda &0600:cmp | 00000530 23 31 3a 62 65 71 20 6f 6b 0d 00 e1 51 20 2e 65 |#1:beq ok...Q .e| 00000540 72 72 31 3a 62 72 6b 3a 5d 3a f2 65 71 75 62 20 |rr1:brk:]:.equb | 00000550 28 26 46 46 29 3a f2 65 71 75 73 20 28 22 55 73 |(&FF):.equs ("Us| 00000560 65 20 65 78 61 63 74 6c 79 20 6f 6e 65 20 70 61 |e exactly one pa| 00000570 72 61 6d 65 74 65 72 22 29 3a f2 65 71 75 62 20 |rameter"):.equb | 00000580 28 30 29 3a 5b 4f 50 54 20 5a 0d 00 e6 22 20 2e |(0):[OPT Z..." .| 00000590 6f 6b 3a 6c 64 61 26 36 30 33 3a 20 63 6d 70 20 |ok:lda&603: cmp | 000005a0 23 34 3a 62 65 71 20 6f 6b 31 20 20 0d 00 eb 50 |#4:beq ok1 ...P| 000005b0 20 2e 65 72 72 32 3a 62 72 6b 3a 5d 3a f2 65 71 | .err2:brk:]:.eq| 000005c0 75 62 28 26 46 46 29 3a f2 65 71 75 73 28 22 55 |ub(&FF):.equs("U| 000005d0 73 65 20 69 6e 74 65 67 65 72 20 70 61 72 61 6d |se integer param| 000005e0 65 74 65 72 73 20 6f 6e 6c 79 22 29 3a f2 65 71 |eters only"):.eq| 000005f0 75 62 28 30 29 3a 5b 4f 50 54 20 5a 0d 00 f0 43 |ub(0):[OPT Z...C| 00000600 20 2e 6f 6b 31 3a 6c 64 61 20 26 36 30 31 3a 73 | .ok1:lda &601:s| 00000610 74 61 20 62 75 66 66 3a 6c 64 61 20 26 36 30 32 |ta buff:lda &602| 00000620 3a 73 74 61 20 62 75 66 66 2b 31 3a 6c 64 79 20 |:sta buff+1:ldy | 00000630 23 30 3a 6c 64 61 20 28 62 75 66 66 29 2c 59 0d |#0:lda (buff),Y.| 00000640 00 f5 0f 20 2e 62 61 63 6b 3a 72 74 73 20 0d 00 |... .back:rts ..| 00000650 fa 2f 20 2e 6f 6b 32 3a 61 6e 64 20 6d 61 73 6b |./ .ok2:and mask| 00000660 3a 73 74 61 20 6d 61 73 6b 3a 20 6c 64 61 20 61 |:sta mask: lda a| 00000670 76 61 72 3a 65 6f 72 20 6d 61 73 6b 20 0d 00 ff |var:eor mask ...| 00000680 19 20 2e 73 74 76 61 72 3a 73 74 61 20 61 76 61 |. .stvar:sta ava| 00000690 72 3a 20 74 61 79 0d 01 04 40 20 2e 73 68 6f 75 |r: tay...@ .shou| 000006a0 74 3a 6a 73 72 20 73 61 76 65 3a 6c 64 79 20 23 |t:jsr save:ldy #| 000006b0 26 33 46 3a 6c 64 78 20 23 64 72 72 3a 6a 73 72 |&3F:ldx #drr:jsr| 000006c0 20 77 72 69 74 65 3a 6a 73 72 20 6c 6f 61 64 3a | write:jsr load:| 000006d0 6c 64 78 20 23 38 0d 01 09 2e 20 2e 6c 6f 6f 70 |ldx #8.... .loop| 000006e0 3a 20 6c 64 61 20 23 26 33 30 3a 61 73 6c 20 61 |: lda #&30:asl a| 000006f0 76 61 72 3a 20 62 63 63 20 6e 75 6c 6c 3a 6f 72 |var: bcc null:or| 00000700 61 20 23 34 0d 01 0e 4e 20 2e 6e 75 6c 6c 3a 6a |a #4...N .null:j| 00000710 73 72 20 73 61 76 65 3a 74 61 79 3a 6c 64 78 20 |sr save:tay:ldx | 00000720 23 75 70 3a 6a 73 72 20 77 72 69 74 65 3a 6a 73 |#up:jsr write:js| 00000730 72 20 6c 6f 61 64 3a 6f 72 61 20 23 38 3a 6a 73 |r load:ora #8:js| 00000740 72 20 73 61 76 65 3a 74 61 79 3a 6c 64 78 20 23 |r save:tay:ldx #| 00000750 75 70 0d 01 13 5e 20 6a 73 72 20 77 72 69 74 65 |up...^ jsr write| 00000760 3a 6a 73 72 20 6c 6f 61 64 3a 64 65 78 3a 62 6e |:jsr load:dex:bn| 00000770 65 20 6c 6f 6f 70 3a 6a 73 72 20 73 61 76 65 3a |e loop:jsr save:| 00000780 6c 64 79 20 23 26 33 31 3a 6c 64 78 20 23 75 70 |ldy #&31:ldx #up| 00000790 3a 6a 73 72 20 77 72 69 74 65 3a 6a 73 72 20 6c |:jsr write:jsr l| 000007a0 6f 61 64 3a 73 74 79 20 61 76 61 72 3a 72 74 73 |oad:sty avar:rts| 000007b0 0d 01 18 18 20 2e 45 31 3a 6c 64 78 20 23 31 3a |.... .E1:ldx #1:| 000007c0 6a 6d 70 20 74 65 73 74 0d 01 1d 18 20 2e 45 32 |jmp test.... .E2| 000007d0 3a 6c 64 78 20 23 32 3a 6a 6d 70 20 74 65 73 74 |:ldx #2:jmp test| 000007e0 0d 01 22 18 20 2e 45 33 3a 6c 64 78 20 23 34 3a |..". .E3:ldx #4:| 000007f0 6a 6d 70 20 74 65 73 74 0d 01 27 18 20 2e 45 34 |jmp test..'. .E4| 00000800 3a 6c 64 78 20 23 38 3a 6a 6d 70 20 74 65 73 74 |:ldx #8:jmp test| 00000810 0d 01 2c 19 20 2e 45 35 3a 6c 64 78 20 23 31 36 |..,. .E5:ldx #16| 00000820 3a 6a 6d 70 20 74 65 73 74 0d 01 31 19 20 2e 45 |:jmp test..1. .E| 00000830 36 3a 6c 64 78 20 23 33 32 3a 6a 6d 70 20 74 65 |6:ldx #32:jmp te| 00000840 73 74 0d 01 36 19 20 2e 45 37 3a 6c 64 78 20 23 |st..6. .E7:ldx #| 00000850 36 34 3a 6a 6d 70 20 74 65 73 74 0d 01 3b 11 20 |64:jmp test..;. | 00000860 2e 45 38 3a 6c 64 78 20 23 31 32 38 0d 01 40 86 |.E8:ldx #128..@.| 00000870 20 2e 74 65 73 74 3a 73 74 78 20 6d 61 73 6b 3a | .test:stx mask:| 00000880 6c 64 61 20 23 26 33 32 3a 6a 73 72 20 73 61 76 |lda #&32:jsr sav| 00000890 65 3a 6c 64 79 20 61 73 61 76 65 3a 6c 64 78 20 |e:ldy asave:ldx | 000008a0 23 75 70 3a 6a 73 72 20 77 72 69 74 65 3a 6a 73 |#up:jsr write:js| 000008b0 72 20 6c 6f 61 64 3a 6f 72 61 20 23 38 3a 6a 73 |r load:ora #8:js| 000008c0 72 20 73 61 76 65 3a 6c 64 79 20 61 73 61 76 65 |r save:ldy asave| 000008d0 3a 6c 64 78 20 23 75 70 3a 6a 73 72 20 77 72 69 |:ldx #up:jsr wri| 000008e0 74 65 3a 6a 73 72 20 6c 6f 61 64 3a 6c 64 78 20 |te:jsr load:ldx | 000008f0 23 38 0d 01 45 5a 20 2e 6c 6f 6f 70 32 3a 61 73 |#8..EZ .loop2:as| 00000900 6c 20 41 3a 6a 73 72 20 73 61 76 65 3a 6c 64 78 |l A:jsr save:ldx| 00000910 20 23 75 70 3a 6a 73 72 20 72 65 61 64 3a 74 79 | #up:jsr read:ty| 00000920 61 3a 61 6e 64 20 23 26 38 30 3a 62 65 71 20 6e |a:and #&80:beq n| 00000930 75 6c 32 3a 6a 73 72 20 6c 6f 61 64 3a 6f 72 61 |ul2:jsr load:ora| 00000940 20 23 31 3a 6a 6d 70 20 6e 75 6c 33 0d 01 4a 13 | #1:jmp nul3..J.| 00000950 20 2e 6e 75 6c 32 3a 6a 73 72 20 6c 6f 61 64 0d | .nul2:jsr load.| 00000960 01 4f 84 20 2e 6e 75 6c 33 3a 6a 73 72 20 73 61 |.O. .nul3:jsr sa| 00000970 76 65 3a 6c 64 79 20 23 26 33 30 3a 6c 64 78 20 |ve:ldy #&30:ldx | 00000980 23 75 70 3a 6a 73 72 20 77 72 69 74 65 3a 6a 73 |#up:jsr write:js| 00000990 72 20 6c 6f 61 64 3a 6c 64 79 20 23 26 33 38 3a |r load:ldy #&38:| 000009a0 6c 64 78 20 23 75 70 3a 6a 73 72 20 77 72 69 74 |ldx #up:jsr writ| 000009b0 65 3a 6a 73 72 20 6c 6f 61 64 3a 64 65 78 3a 62 |e:jsr load:dex:b| 000009c0 6e 65 20 6c 6f 6f 70 32 3a 61 6e 64 20 6d 61 73 |ne loop2:and mas| 000009d0 6b 3a 62 65 71 20 62 61 63 6b 31 3a 6c 64 61 20 |k:beq back1:lda | 000009e0 23 31 20 0d 01 54 0b 20 2e 62 61 63 6b 31 0d 01 |#1 ..T. .back1..| 000009f0 59 08 20 72 74 73 0d 01 5e 1a 20 2e 45 58 3a 6c |Y. rts..^. .EX:l| 00000a00 64 78 20 23 26 41 30 3a 6a 6d 70 20 70 6f 74 69 |dx #&A0:jmp poti| 00000a10 0d 01 63 11 20 2e 45 59 3a 6c 64 78 20 23 26 39 |..c. .EY:ldx #&9| 00000a20 30 0d 01 68 75 20 2e 70 6f 74 69 3a 73 65 69 3a |0..hu .poti:sei:| 00000a30 6a 73 72 20 73 61 76 65 3a 6c 64 79 20 23 26 32 |jsr save:ldy #&2| 00000a40 30 3a 6c 64 78 20 23 74 69 63 3a 6a 73 72 20 77 |0:ldx #tic:jsr w| 00000a50 72 69 74 65 3a 6c 64 79 20 23 26 46 46 3a 6c 64 |rite:ldy #&FF:ld| 00000a60 78 20 23 74 69 6c 3a 6a 73 72 20 77 72 69 74 65 |x #til:jsr write| 00000a70 3a 6c 64 79 20 23 26 46 46 3a 6c 64 78 20 23 74 |:ldy #&FF:ldx #t| 00000a80 69 68 3a 6a 73 72 20 77 72 69 74 65 3a 6c 64 79 |ih:jsr write:ldy| 00000a90 20 78 73 61 76 65 0d 01 6d 3a 20 6c 64 78 20 23 | xsave..m: ldx #| 00000aa0 75 70 3a 6a 73 72 20 77 72 69 74 65 3a 6c 64 79 |up:jsr write:ldy| 00000ab0 20 23 26 33 38 3a 6c 64 78 20 23 75 70 3a 6a 73 | #&38:ldx #up:js| 00000ac0 72 20 77 72 69 74 65 3a 6a 73 72 20 6c 6f 61 64 |r write:jsr load| 00000ad0 0d 01 72 44 20 2e 74 73 74 3a 6a 73 72 20 73 61 |..rD .tst:jsr sa| 00000ae0 76 65 3a 6c 64 78 20 23 74 69 6c 3a 6a 73 72 20 |ve:ldx #til:jsr | 00000af0 72 65 61 64 3a 73 74 79 20 79 73 61 76 65 3a 6a |read:sty ysave:j| 00000b00 73 72 20 6c 6f 61 64 3a 74 79 61 3a 6c 64 78 20 |sr load:tya:ldx | 00000b10 23 32 30 30 0d 01 77 aa 20 2e 64 65 6c 61 79 3a |#200..w. .delay:| 00000b20 64 65 78 3a 62 6e 65 20 64 65 6c 61 79 3a 6a 73 |dex:bne delay:js| 00000b30 72 20 73 61 76 65 3a 6c 64 78 20 23 74 69 6c 3a |r save:ldx #til:| 00000b40 6a 73 72 20 72 65 61 64 3a 73 74 79 20 79 73 61 |jsr read:sty ysa| 00000b50 76 65 3a 6a 73 72 20 6c 6f 61 64 3a 73 65 63 3a |ve:jsr load:sec:| 00000b60 73 62 63 20 79 73 61 76 65 3a 62 6e 65 20 74 73 |sbc ysave:bne ts| 00000b70 74 3a 6a 73 72 20 73 61 76 65 3a 6c 64 78 20 23 |t:jsr save:ldx #| 00000b80 74 69 6c 3a 6a 73 72 20 72 65 61 64 3a 73 74 79 |til:jsr read:sty| 00000b90 20 79 73 61 76 65 3a 6a 73 72 20 6c 6f 61 64 3a | ysave:jsr load:| 00000ba0 73 65 63 3a 6c 64 61 20 23 26 46 46 3a 73 62 63 |sec:lda #&FF:sbc| 00000bb0 20 79 73 61 76 65 3a 63 6c 69 3a 72 74 73 0d 01 | ysave:cli:rts..| 00000bc0 7c 26 20 2e 77 72 69 74 65 3a 6c 64 61 20 23 26 ||& .write:lda #&| 00000bd0 39 37 3a 6a 73 72 20 26 46 46 46 34 3a 63 6c 63 |97:jsr &FFF4:clc| 00000be0 3a 72 74 73 0d 01 81 25 20 2e 72 65 61 64 3a 6c |:rts...% .read:l| 00000bf0 64 61 20 23 26 39 36 3a 6a 73 72 20 26 46 46 46 |da #&96:jsr &FFF| 00000c00 34 3a 63 6c 63 3a 72 74 73 0d 01 86 2d 20 2e 73 |4:clc:rts...- .s| 00000c10 61 76 65 3a 73 74 61 20 61 73 61 76 65 3a 73 74 |ave:sta asave:st| 00000c20 78 20 78 73 61 76 65 3a 73 74 79 20 79 73 61 76 |x xsave:sty ysav| 00000c30 65 3a 72 74 73 20 0d 01 8b 2c 20 2e 6c 6f 61 64 |e:rts ..., .load| 00000c40 3a 6c 64 61 20 61 73 61 76 65 3a 6c 64 78 20 78 |:lda asave:ldx x| 00000c50 73 61 76 65 3a 6c 64 79 20 79 73 61 76 65 3a 72 |save:ldy ysave:r| 00000c60 74 73 0d 01 90 05 5d 0d 01 95 08 20 ed 20 5a 0d |ts....].... . Z.| 00000c70 01 9a 10 20 e9 20 4d 31 3d 69 6e 69 74 2b 34 0d |... . M1=init+4.| 00000c80 01 9f 10 20 e9 20 4d 32 3d 69 6e 69 74 2b 38 0d |... . M2=init+8.| 00000c90 01 a4 11 20 e9 20 4d 33 3d 69 6e 69 74 2b 31 32 |... . M3=init+12| 00000ca0 0d 01 a9 11 20 e9 20 4d 34 3d 69 6e 69 74 2b 31 |.... . M4=init+1| 00000cb0 36 0d 01 ae 10 20 e9 20 49 4e 49 54 3d 69 6e 69 |6.... . INIT=ini| 00000cc0 74 0d 01 b3 0d 20 e9 20 43 57 25 3d 38 35 0d 01 |t.... . CW%=85..| 00000cd0 b8 0f 20 e9 20 43 43 57 25 3d 31 37 30 0d 01 bd |.. . CCW%=170...| 00000ce0 0d 20 e9 20 47 4f 25 3d 38 35 0d 01 c2 10 20 e9 |. . GO%=85.... .| 00000cf0 20 48 41 4c 54 25 3d 32 35 35 0d 01 c7 20 20 f4 | HALT%=255... .| 00000d00 20 2a 20 2a 20 2a 20 45 4e 44 20 4f 46 20 44 52 | * * * END OF DR| 00000d10 49 56 45 52 20 2a 20 2a 20 2a 0d 01 cc 1b 20 dd |IVER * * *.... .| 00000d20 20 a4 55 53 52 28 41 29 3d ba 28 41 29 20 80 20 | .USR(A)=.(A) . | 00000d30 26 46 46 20 20 0d 01 d6 22 20 dd f2 65 71 75 62 |&FF ..." ..equb| 00000d40 28 6e 75 6d 29 3a 3f 50 25 3d 6e 75 6d 3a 50 25 |(num):?P%=num:P%| 00000d50 3d 50 25 2b 31 3a e1 0d 01 e0 2c 20 dd f2 65 71 |=P%+1:...., ..eq| 00000d60 75 73 28 74 65 78 74 24 29 3a 24 50 25 3d 74 65 |us(text$):$P%=te| 00000d70 78 74 24 3a 50 25 3d 50 25 2b a9 20 74 65 78 74 |xt$:P%=P%+. text| 00000d80 24 3a e1 0d 01 f4 0b 20 d6 20 49 4e 49 54 0d 01 |$:..... . INIT..| 00000d90 fe 1f 20 f4 20 46 49 53 43 48 45 52 54 45 43 48 |.. . FISCHERTECH| 00000da0 4e 49 4b 20 43 4f 4d 50 55 54 49 4e 47 0d 02 08 |NIK COMPUTING...| 00000db0 07 20 f4 20 0d 02 12 14 20 f4 20 47 52 41 50 48 |. . .... . GRAPH| 00000dc0 49 43 20 50 41 4e 45 4c 0d 02 1c 07 20 f4 20 0d |IC PANEL.... . .| 00000dd0 02 26 1a 20 f4 20 43 4f 50 59 52 49 47 48 54 20 |.&. . COPYRIGHT | 00000de0 28 43 29 20 31 39 38 34 20 0d 02 30 21 20 f4 20 |(C) 1984 ..0! . | 00000df0 42 59 20 41 52 54 55 52 20 46 49 53 43 48 45 52 |BY ARTUR FISCHER| 00000e00 20 46 4f 52 53 43 48 55 4e 47 0d 02 58 07 20 f4 | FORSCHUNG..X. .| 00000e10 20 0d 02 62 0c 20 f4 20 49 4e 50 55 54 0d 02 6c | ..b. . INPUT..l| 00000e20 20 20 f4 20 45 31 3d 52 45 41 44 20 49 4e 20 41 | . E1=READ IN A| 00000e30 4e 47 55 4c 41 52 20 56 41 4c 55 45 53 0d 02 76 |NGULAR VALUES..v| 00000e40 13 20 f4 20 45 32 3d 53 48 49 46 54 2d 4b 45 59 |. . E2=SHIFT-KEY| 00000e50 0d 02 80 28 20 f4 20 45 33 3d 50 4c 4f 54 20 41 |...( . E3=PLOT A| 00000e60 20 50 49 58 45 4c 20 2f 20 50 52 49 4e 54 20 43 | PIXEL / PRINT C| 00000e70 48 41 52 41 43 54 45 52 0d 02 8a 62 20 f4 20 45 |HARACTER...b . E| 00000e80 34 3d 44 52 41 57 20 41 20 4c 49 4e 45 20 28 46 |4=DRAW A LINE (F| 00000e90 49 58 45 44 20 43 4f 4f 52 44 49 4e 41 54 45 53 |IXED COORDINATES| 00000ea0 29 20 2f 20 44 52 41 57 20 4f 46 46 48 41 4e 44 |) / DRAW OFFHAND| 00000eb0 20 4c 49 4e 45 20 2d 20 45 4e 44 2d 50 4f 49 4e | LINE - END-POIN| 00000ec0 54 20 49 53 20 46 49 58 45 44 20 42 59 20 50 52 |T IS FIXED BY PR| 00000ed0 45 53 53 49 4e 47 20 45 31 2e 0d 02 94 1c 20 f4 |ESSING E1..... .| 00000ee0 20 45 35 3d 54 52 49 41 4e 47 4c 45 20 2f 20 46 | E5=TRIANGLE / F| 00000ef0 49 4c 4c 20 49 54 0d 02 9e 1d 20 f4 20 45 36 3d |ILL IT.... . E6=| 00000f00 52 45 43 54 41 4e 47 4c 45 20 2f 20 46 49 4c 4c |RECTANGLE / FILL| 00000f10 20 49 54 0d 02 a8 19 20 f4 20 45 37 3d 43 49 52 | IT.... . E7=CIR| 00000f20 43 4c 45 20 2f 46 49 4c 4c 20 49 54 0d 02 b2 16 |CLE /FILL IT....| 00000f30 20 f4 20 45 38 3d 43 4c 45 41 52 20 53 43 52 45 | . E8=CLEAR SCRE| 00000f40 45 4e 0d 02 bc 0e 20 f4 20 45 58 3d 42 45 54 41 |EN.... . EX=BETA| 00000f50 0d 02 c6 0f 20 f4 20 45 59 3d 41 4c 50 48 41 0d |.... . EY=ALPHA.| 00000f60 02 d0 07 20 f4 20 0d 02 da 0d 20 f4 20 4f 55 54 |... . .... . OUT| 00000f70 50 55 54 0d 02 e4 1b 20 f4 20 4d 31 3d 47 52 41 |PUT.... . M1=GRA| 00000f80 50 48 49 43 20 49 53 20 41 43 54 49 56 45 0d 02 |PHIC IS ACTIVE..| 00000f90 ee 19 20 f4 20 4d 32 3d 52 45 41 44 59 20 46 4f |.. . M2=READY FO| 00000fa0 52 20 49 4e 50 55 54 0d 02 f8 07 20 f4 20 0d 03 |R INPUT.... . ..| 00000fb0 02 1b 20 f4 20 46 55 4e 43 54 49 4f 4e 20 44 45 |.. . FUNCTION DE| 00000fc0 53 43 52 49 50 54 49 4f 4e 0d 03 0c 1e 20 f4 20 |SCRIPTION.... . | 00000fd0 54 52 41 4e 53 46 45 52 20 41 20 50 49 43 54 55 |TRANSFER A PICTU| 00000fe0 52 45 20 4f 4e 54 4f 0d 03 16 20 20 f4 20 54 48 |RE ONTO... . TH| 00000ff0 45 20 47 52 41 50 48 49 43 20 53 43 52 45 45 4e |E GRAPHIC SCREEN| 00001000 20 4f 46 20 54 48 45 0d 03 20 10 20 f4 20 43 4f | OF THE.. . . CO| 00001010 4d 50 55 54 45 52 2e 0d 03 2a 07 20 f4 20 0d 03 |MPUTER...*. . ..| 00001020 34 15 20 f4 20 47 45 4f 4d 45 54 52 49 43 20 44 |4. . GEOMETRIC D| 00001030 41 54 41 0d 03 3e 2b 20 e9 20 57 41 3d 2d 30 2e |ATA..>+ . WA=-0.| 00001040 36 38 30 36 38 20 3a 20 f4 20 41 4e 47 4c 45 20 |68068 : . ANGLE | 00001050 41 4c 50 48 41 20 54 4f 50 20 4c 45 46 54 0d 03 |ALPHA TOP LEFT..| 00001060 48 29 20 e9 20 57 42 3d 30 2e 39 33 37 32 34 20 |H) . WB=0.93724 | 00001070 3a 20 f4 20 41 4e 47 4c 45 20 42 45 54 41 20 54 |: . ANGLE BETA T| 00001080 4f 50 20 4c 45 46 54 0d 03 52 1e 20 e9 20 41 3d |OP LEFT..R. . A=| 00001090 31 36 36 20 3a 20 f4 20 4c 45 4e 47 54 48 20 4f |166 : . LENGTH O| 000010a0 46 20 41 52 4d 0d 03 5c 2e 20 e9 20 58 30 3d 31 |F ARM..\. . X0=1| 000010b0 33 37 20 3a 20 f4 20 4f 52 49 47 49 4e 20 4f 46 |37 : . ORIGIN OF| 000010c0 20 43 4f 5f 4f 52 44 49 4e 41 54 45 20 53 59 53 | CO_ORDINATE SYS| 000010d0 54 45 4d 0d 03 66 0d 20 e9 20 59 30 3d 32 34 37 |TEM..f. . Y0=247| 000010e0 0d 03 70 36 20 e9 20 53 58 3d 34 2a 31 2e 32 33 |..p6 . SX=4*1.23| 000010f0 36 34 20 3a 20 f4 20 53 43 41 4c 45 20 46 41 43 |64 : . SCALE FAC| 00001100 54 4f 52 20 58 2d 41 58 49 53 20 28 50 49 58 45 |TOR X-AXIS (PIXE| 00001110 4c 53 2f 4d 4d 29 0d 03 7a 36 20 e9 20 53 59 3d |LS/MM)..z6 . SY=| 00001120 34 2a 31 2e 31 39 36 33 20 3a 20 f4 20 53 43 41 |4*1.1963 : . SCA| 00001130 4c 45 20 46 41 43 54 4f 52 20 59 2d 41 58 49 53 |LE FACTOR Y-AXIS| 00001140 20 28 50 49 58 45 4c 53 2f 4d 4d 29 0d 03 84 07 | (PIXELS/MM)....| 00001150 20 eb 36 0d 03 8e 17 20 f1 20 22 46 49 53 43 48 | .6.... . "FISCH| 00001160 45 52 54 45 43 48 4e 49 4b 22 0d 03 98 12 20 f1 |ERTECHNIK".... .| 00001170 20 22 43 4f 4d 50 55 54 49 4e 47 22 0d 03 a2 07 | "COMPUTING"....| 00001180 20 f1 20 0d 03 ac 16 20 f1 20 22 47 52 41 50 48 | . .... . "GRAPH| 00001190 49 43 20 50 41 4e 45 4c 22 0d 03 b6 07 20 f1 20 |IC PANEL".... . | 000011a0 0d 03 c0 05 20 0d 03 ca 19 20 f1 20 22 50 4c 45 |.... .... . "PLE| 000011b0 41 53 45 20 43 41 4c 49 42 52 41 54 45 22 0d 03 |ASE CALIBRATE"..| 000011c0 d4 06 20 f1 0d 03 de 14 20 f1 20 22 50 4f 53 54 |.. ..... . "POST| 000011d0 49 4f 4e 20 50 45 4e 22 0d 03 e8 21 20 f1 20 22 |ION PEN"...! . "| 000011e0 49 4e 20 54 48 45 20 55 50 50 45 52 20 4c 45 46 |IN THE UPPER LEF| 000011f0 54 20 43 4f 52 4e 45 52 22 0d 03 f2 1c 20 f1 20 |T CORNER".... . | 00001200 22 44 45 50 52 45 53 53 20 52 45 41 44 5f 49 4e |"DEPRESS READ_IN| 00001210 20 4b 45 59 22 0d 03 fc 30 20 e7 20 a4 55 53 52 | KEY"...0 . .USR| 00001220 28 45 31 29 3d 30 20 8c 20 e5 20 8d 64 7c 43 3a |(E1)=0 . . .d|C:| 00001230 f4 20 57 41 49 54 20 46 4f 52 20 41 43 43 45 50 |. WAIT FOR ACCEP| 00001240 54 20 4b 45 59 0d 04 06 12 20 e9 20 41 31 3d a4 |T KEY.... . A1=.| 00001250 55 53 52 28 45 59 29 0d 04 10 12 20 e9 20 42 31 |USR(EY).... . B1| 00001260 3d a4 55 53 52 28 45 58 29 0d 04 1a 42 20 e7 20 |=.USR(EX)...B . | 00001270 a4 55 53 52 28 45 31 29 3d 31 20 8c 20 e5 20 8d |.USR(E1)=1 . . .| 00001280 54 5a 44 3a f4 20 57 41 49 54 20 55 4e 54 49 4c |TZD:. WAIT UNTIL| 00001290 20 4b 45 59 20 49 53 20 4e 4f 20 4c 4f 4e 47 45 | KEY IS NO LONGE| 000012a0 52 20 44 45 50 52 45 53 53 45 44 0d 04 24 07 20 |R DEPRESSED..$. | 000012b0 f1 20 0d 04 2e 15 20 f1 20 22 50 4f 53 49 54 49 |. .... . "POSITI| 000012c0 4f 4e 20 50 45 4e 22 0d 04 38 22 20 f1 20 22 49 |ON PEN"..8" . "I| 000012d0 4e 20 54 48 45 20 4c 4f 57 45 52 20 52 49 47 48 |N THE LOWER RIGH| 000012e0 54 20 43 4f 52 4e 45 52 22 0d 04 42 1e 20 f1 20 |T CORNER"..B. . | 000012f0 22 44 45 50 52 45 53 53 20 52 45 41 44 5f 49 4e |"DEPRESS READ_IN| 00001300 20 4b 45 59 22 20 20 0d 04 4c 33 20 e7 20 a4 55 | KEY" ..L3 . .U| 00001310 53 52 28 45 31 29 3d 30 20 8c 20 e5 20 8d 44 4c |SR(E1)=0 . . .DL| 00001320 44 3a f4 20 57 41 49 54 20 46 4f 52 20 52 45 41 |D:. WAIT FOR REA| 00001330 44 5f 49 4e 20 4b 45 59 20 20 0d 04 56 12 20 e9 |D_IN KEY ..V. .| 00001340 20 41 32 3d a4 55 53 52 28 45 59 29 0d 04 60 12 | A2=.USR(EY)..`.| 00001350 20 e9 20 42 32 3d a4 55 53 52 28 45 58 29 0d 04 | . B2=.USR(EX)..| 00001360 6a 42 20 e7 20 a4 55 53 52 28 45 31 29 3d 31 20 |jB . .USR(E1)=1 | 00001370 8c 20 e5 20 8d 44 6a 44 3a f4 20 57 41 49 54 20 |. . .DjD:. WAIT | 00001380 55 4e 54 49 4c 20 4b 45 59 20 49 53 20 4e 4f 20 |UNTIL KEY IS NO | 00001390 4c 4f 4e 47 45 52 20 44 45 50 52 45 53 53 45 44 |LONGER DEPRESSED| 000013a0 0d 04 74 36 20 e9 20 41 46 3d 32 2e 31 32 30 35 |..t6 . AF=2.1205| 000013b0 38 2f 28 41 32 2d 41 31 29 3a 20 f4 20 32 2e 31 |8/(A2-A1): . 2.1| 000013c0 32 30 35 38 20 52 41 44 3d 41 4c 50 48 41 32 2d |2058 RAD=ALPHA2-| 000013d0 41 4c 50 48 41 31 0d 04 7e 34 20 e9 20 42 46 3d |ALPHA1..~4 . BF=| 000013e0 31 2e 30 32 31 30 32 2f 28 42 32 2d 42 31 29 3a |1.02102/(B2-B1):| 000013f0 20 f4 20 31 2e 30 32 31 30 32 20 52 41 44 3d 42 | . 1.02102 RAD=B| 00001400 45 54 41 32 2d 42 45 54 41 31 0d 04 88 44 20 eb |ETA2-BETA1...D .| 00001410 34 3a ef 20 35 3a f4 20 52 45 53 4f 4c 55 54 49 |4:. 5:. RESOLUTI| 00001420 4f 4e 20 33 32 30 78 32 35 36 2c 20 32 20 43 4f |ON 320x256, 2 CO| 00001430 4c 4f 55 52 53 20 3b 20 47 52 41 50 48 49 43 20 |LOURS ; GRAPHIC | 00001440 43 55 52 53 4f 52 20 45 4e 41 42 4c 45 44 0d 04 |CURSOR ENABLED..| 00001450 92 28 20 d6 20 4d 31 2c 48 41 4c 54 25 3a f4 20 |.( . M1,HALT%:. | 00001460 27 41 43 54 49 56 45 27 2d 49 4e 44 49 43 41 54 |'ACTIVE'-INDICAT| 00001470 4f 52 20 4f 46 46 0d 04 9c 26 20 d6 20 4d 32 2c |OR OFF...& . M2,| 00001480 47 4f 25 20 20 3a f4 20 27 52 45 41 44 59 27 2d |GO% :. 'READY'-| 00001490 49 4e 44 49 43 41 54 4f 52 20 4f 4e 0d 04 a6 11 |INDICATOR ON....| 000014a0 20 53 3d a4 55 53 52 28 45 32 29 2a 37 0d 04 b0 | S=.USR(E2)*7...| 000014b0 11 20 53 3d 53 2b a4 55 53 52 28 45 33 29 0d 04 |. S=S+.USR(E3)..| 000014c0 ba 13 20 53 3d 53 2b a4 55 53 52 28 45 34 29 2a |.. S=S+.USR(E4)*| 000014d0 32 0d 04 c4 13 20 53 3d 53 2b a4 55 53 52 28 45 |2.... S=S+.USR(E| 000014e0 35 29 2a 33 0d 04 ce 14 20 53 3d 53 2b a4 55 53 |5)*3.... S=S+.US| 000014f0 52 28 45 36 29 2a 34 20 0d 04 d8 13 20 53 3d 53 |R(E6)*4 .... S=S| 00001500 2b a4 55 53 52 28 45 37 29 2a 35 0d 04 e2 13 20 |+.USR(E7)*5.... | 00001510 53 3d 53 2b a4 55 53 52 28 45 38 29 2a 36 0d 04 |S=S+.USR(E8)*6..| 00001520 ec 17 20 e7 20 53 3d 30 20 84 20 53 3d 37 20 e5 |.. . S=0 . S=7 .| 00001530 20 8d 74 66 44 0d 04 f6 28 20 d6 20 4d 32 2c 48 | .tfD...( . M2,H| 00001540 41 4c 54 25 3a 20 f4 20 27 52 45 41 44 59 27 2d |ALT%: . 'READY'-| 00001550 49 4e 44 49 43 41 54 4f 52 20 4f 46 46 0d 05 00 |INDICATOR OFF...| 00001560 25 20 d6 20 4d 31 2c 47 4f 25 3a f4 20 27 41 43 |% . M1,GO%:. 'AC| 00001570 54 49 56 45 27 2d 49 4e 44 49 43 41 54 4f 52 20 |TIVE'-INDICATOR | 00001580 4f 4e 0d 05 0a 4b 20 ee 20 53 20 e5 20 8d 54 54 |ON...K . S . .TT| 00001590 45 2c 8d 54 72 45 2c 8d 44 6e 45 2c 8d 74 42 45 |E,.TrE,.DnE,.tBE| 000015a0 2c 8d 64 48 45 2c 8d 74 48 44 2c 8d 74 52 44 2c |,.dHE,.tHD,.tRD,| 000015b0 8d 64 66 45 2c 8d 54 58 46 2c 8d 44 54 46 2c 8d |.dfE,.TXF,.DTF,.| 000015c0 44 72 46 2c 8d 74 6e 46 2c 8d 74 52 44 0d 05 14 |DrF,.tnF,.tRD...| 000015d0 19 20 e4 20 8d 64 4c 46 3a f4 20 43 4f 4f 52 44 |. . .dLF:. COORD| 000015e0 49 4e 41 54 45 53 0d 05 1e 1a 20 f0 20 36 39 2c |INATES.... . 69,| 000015f0 58 2c 59 3a f4 20 50 4c 4f 54 20 50 49 58 45 4c |X,Y:. PLOT PIXEL| 00001600 0d 05 28 0b 20 e5 20 8d 74 52 44 0d 05 32 19 20 |..(. . .tRD..2. | 00001610 e4 20 8d 64 4c 46 3a f4 20 43 4f 4f 52 44 49 4e |. .dLF:. COORDIN| 00001620 41 54 45 53 0d 05 3c 0b 20 e9 20 58 31 3d 58 0d |ATES..<. . X1=X.| 00001630 05 46 1e 20 e9 20 59 31 3d 59 3a f4 20 53 41 56 |.F. . Y1=Y:. SAV| 00001640 45 20 43 4f 4f 52 44 49 4e 41 54 45 53 0d 05 50 |E COORDINATES..P| 00001650 0b 20 e4 20 8d 64 4c 46 0d 05 5a 1f 20 ec 20 58 |. . .dLF..Z. . X| 00001660 31 2c 59 31 3a df 20 58 2c 59 3a 20 f4 20 44 52 |1,Y1:. X,Y: . DR| 00001670 41 57 20 4c 49 4e 45 0d 05 64 0b 20 e5 20 8d 74 |AW LINE..d. . .t| 00001680 52 44 0d 05 6e 1b 20 e4 20 8d 54 42 48 3a f4 20 |RD..n. . .TBH:. | 00001690 44 52 41 57 20 54 52 49 41 4e 47 4c 45 0d 05 78 |DRAW TRIANGLE..x| 000016a0 0b 20 e5 20 8d 74 52 44 0d 05 82 19 20 e4 20 8d |. . .tRD.... . .| 000016b0 64 4c 46 3a f4 20 43 4f 4f 52 44 49 4e 41 54 45 |dLF:. COORDINATE| 000016c0 53 0d 05 8c 0b 20 e9 20 58 31 3d 58 0d 05 96 0b |S.... . X1=X....| 000016d0 20 e9 20 59 31 3d 59 0d 05 a0 19 20 e4 20 8d 64 | . Y1=Y.... . .d| 000016e0 4c 46 3a f4 20 43 4f 4f 52 44 49 4e 41 54 45 53 |LF:. COORDINATES| 000016f0 0d 05 aa 28 20 ec 20 58 31 2c 59 31 3a df 20 58 |...( . X1,Y1:. X| 00001700 2c 59 31 3a df 20 58 2c 59 3a df 20 58 31 2c 59 |,Y1:. X,Y:. X1,Y| 00001710 3a df 20 58 31 2c 59 31 0d 05 b4 10 20 f4 20 52 |:. X1,Y1.... . R| 00001720 45 43 54 41 4e 47 4c 45 0d 05 be 0b 20 e5 20 8d |ECTANGLE.... . .| 00001730 74 52 44 0d 05 c8 09 20 4b 3d 36 35 0d 05 d2 19 |tRD.... K=65....| 00001740 20 e4 20 8d 44 7a 48 3a f4 20 44 52 41 57 20 43 | . .DzH:. DRAW C| 00001750 49 52 43 4c 45 0d 05 dc 0b 20 e5 20 8d 74 52 44 |IRCLE.... . .tRD| 00001760 0d 05 e6 19 20 e4 20 8d 64 4c 46 3a f4 20 43 4f |.... . .dLF:. CO| 00001770 4f 52 44 49 4e 41 54 45 53 0d 05 f0 08 20 43 3d |ORDINATES.... C=| 00001780 a5 0d 05 fa 0c 20 43 24 3d bd 28 43 29 0d 06 04 |..... C$=.(C)...| 00001790 23 20 ec 20 58 2c 59 3a f1 20 43 24 3a f4 20 44 |# . X,Y:. C$:. D| 000017a0 49 53 50 4c 41 59 20 43 48 41 52 41 43 54 45 52 |ISPLAY CHARACTER| 000017b0 0d 06 0e 0b 20 e5 20 8d 74 52 44 0d 06 18 1a 20 |.... . .tRD.... | 000017c0 e4 20 8d 64 4c 46 3a f4 20 53 54 41 52 54 20 53 |. .dLF:. START S| 000017d0 49 47 4e 41 4c 0d 06 22 1a 20 e7 20 a4 55 53 52 |IGNAL..". . .USR| 000017e0 28 45 31 29 3d 31 20 8c 20 e5 20 8d 74 52 44 0d |(E1)=1 . . .tRD.| 000017f0 06 2c 1a 20 e4 20 8d 44 6c 47 3a 20 f4 20 43 4f |.,. . .DlG: . CO| 00001800 4f 52 44 49 4e 41 54 45 53 0d 06 36 24 20 e7 20 |ORDINATES..6$ . | 00001810 58 3c 3e 58 31 20 84 20 59 3c 3e 59 31 20 8c 20 |X<>X1 . Y<>Y1 . | 00001820 ec 20 58 2c 59 3a df 20 58 31 2c 59 31 0d 06 40 |. X,Y:. X1,Y1..@| 00001830 0f 20 58 3d 58 31 3a 59 3d 59 31 20 0d 06 4a 0b |. X=X1:Y=Y1 ..J.| 00001840 20 e5 20 8d 54 62 46 0d 06 54 0b 20 e4 20 8d 54 | . .TbF..T. . .T| 00001850 42 48 0d 06 5e 2e 20 ec 20 58 31 2c 59 31 3a ec |BH..^. . X1,Y1:.| 00001860 20 58 32 2c 59 32 3a f0 20 38 35 2c 58 2c 59 3a | X2,Y2:. 85,X,Y:| 00001870 20 f4 20 46 49 4c 4c 20 54 52 49 41 4e 47 4c 45 | . FILL TRIANGLE| 00001880 0d 06 68 0b 20 e5 20 8d 74 52 44 0d 06 72 19 20 |..h. . .tRD..r. | 00001890 e4 20 8d 64 4c 46 3a f4 20 43 4f 4f 52 44 49 4e |. .dLF:. COORDIN| 000018a0 41 54 45 53 0d 06 7c 0b 20 e9 20 58 31 3d 58 0d |ATES..|. . X1=X.| 000018b0 06 86 1e 20 e9 20 59 31 3d 59 3a f4 20 53 41 56 |... . Y1=Y:. SAV| 000018c0 45 20 43 4f 4f 52 44 49 4e 41 54 45 53 0d 06 90 |E COORDINATES...| 000018d0 19 20 e4 20 8d 64 4c 46 3a f4 20 43 4f 4f 52 44 |. . .dLF:. COORD| 000018e0 49 4e 41 54 45 53 0d 06 9a 34 20 ec 20 58 31 2c |INATES...4 . X1,| 000018f0 59 31 3a ec 20 58 31 2c 59 3a f0 20 38 35 2c 58 |Y1:. X1,Y:. 85,X| 00001900 2c 59 3a ec 20 58 31 2c 59 31 3a ec 20 58 2c 59 |,Y:. X1,Y1:. X,Y| 00001910 31 3a f0 20 38 35 2c 58 2c 59 0d 06 a4 0b 20 e5 |1:. 85,X,Y.... .| 00001920 20 8d 74 52 44 0d 06 ae 09 20 4b 3d 38 31 0d 06 | .tRD.... K=81..| 00001930 b8 1a 20 e4 20 8d 44 7a 48 3a f4 20 50 41 49 4e |.. . .DzH:. PAIN| 00001940 54 20 43 49 52 43 4c 45 0d 06 c2 0b 20 e5 20 8d |T CIRCLE.... . .| 00001950 74 52 44 0d 06 cc 17 20 f4 20 52 45 41 44 20 43 |tRD.... . READ C| 00001960 4f 4f 52 44 49 4e 41 54 45 53 0d 06 d6 1b 20 e7 |OORDINATES.... .| 00001970 20 a4 55 53 52 28 45 31 29 3d 30 20 8c 20 e5 20 | .USR(E1)=0 . . | 00001980 8d 64 56 46 20 0d 06 e0 20 20 e9 20 41 4c 50 48 |.dVF ... . ALPH| 00001990 41 3d 28 a4 55 53 52 28 45 59 29 2d 41 31 29 2a |A=(.USR(EY)-A1)*| 000019a0 41 46 2b 57 41 0d 06 ea 1f 20 e9 20 42 45 54 41 |AF+WA.... . BETA| 000019b0 3d 28 a4 55 53 52 28 45 58 29 2d 42 31 29 2a 42 |=(.USR(EX)-B1)*B| 000019c0 46 2b 57 42 0d 06 f4 11 20 f4 20 52 45 41 44 20 |F+WB.... . READ | 000019d0 41 4e 47 4c 45 0d 06 fe 2e 20 e9 20 58 3d a8 28 |ANGLE.... . X=.(| 000019e0 53 58 2a 28 58 30 2d 41 2a 9b 28 41 4c 50 48 41 |SX*(X0-A*.(ALPHA| 000019f0 29 2b 41 2a 9b 28 42 45 54 41 2d 41 4c 50 48 41 |)+A*.(BETA-ALPHA| 00001a00 29 29 29 0d 07 08 2e 20 e9 20 59 3d a8 28 53 59 |))).... . Y=.(SY| 00001a10 2a 28 59 30 2d 41 2a b5 28 41 4c 50 48 41 29 2d |*(Y0-A*.(ALPHA)-| 00001a20 41 2a b5 28 42 45 54 41 2d 41 4c 50 48 41 29 29 |A*.(BETA-ALPHA))| 00001a30 29 0d 07 12 12 20 e7 20 58 3c 30 20 8c 20 e9 20 |).... . X<0 . . | 00001a40 58 3d 30 0d 07 1c 18 20 e7 20 58 3e 31 32 37 39 |X=0.... . X>1279| 00001a50 20 8c 20 e9 20 58 3d 31 32 37 39 0d 07 26 12 20 | . . X=1279..&. | 00001a60 e7 20 59 3c 30 20 8c 20 e9 20 59 3d 30 0d 07 30 |. Y<0 . . Y=0..0| 00001a70 18 20 e7 20 59 3e 31 30 32 33 20 8c 20 e9 20 59 |. . Y>1023 . . Y| 00001a80 3d 31 30 32 33 0d 07 3a 1b 20 e7 20 a4 55 53 52 |=1023..:. . .USR| 00001a90 28 45 31 29 3d 31 20 8c 20 e5 20 8d 54 7a 47 20 |(E1)=1 . . .TzG | 00001aa0 0d 07 62 06 20 f8 0d 07 6c 3a 20 f4 20 52 45 41 |..b. ...l: . REA| 00001ab0 44 20 43 4f 4f 52 44 49 4e 41 54 45 53 20 57 49 |D COORDINATES WI| 00001ac0 54 48 4f 55 54 20 57 41 49 54 49 4e 47 20 46 4f |THOUT WAITING FO| 00001ad0 52 20 52 45 41 44 5f 49 4e 2d 4b 45 59 20 20 20 |R READ_IN-KEY | 00001ae0 0d 07 76 20 20 e9 20 41 4c 50 48 41 3d 28 a4 55 |..v . ALPHA=(.U| 00001af0 53 52 28 45 59 29 2d 41 31 29 2a 41 46 2b 57 41 |SR(EY)-A1)*AF+WA| 00001b00 0d 07 80 1f 20 e9 20 42 45 54 41 3d 28 a4 55 53 |.... . BETA=(.US| 00001b10 52 28 45 58 29 2d 42 31 29 2a 42 46 2b 57 42 0d |R(EX)-B1)*BF+WB.| 00001b20 07 8a 12 20 f4 20 52 45 41 44 20 41 4e 47 4c 45 |... . READ ANGLE| 00001b30 53 0d 07 94 2f 20 e9 20 58 31 3d a8 28 53 58 2a |S.../ . X1=.(SX*| 00001b40 28 58 30 2d 41 2a 9b 28 41 4c 50 48 41 29 2b 41 |(X0-A*.(ALPHA)+A| 00001b50 2a 9b 28 42 45 54 41 2d 41 4c 50 48 41 29 29 29 |*.(BETA-ALPHA)))| 00001b60 0d 07 9e 2f 20 e9 20 59 31 3d a8 28 53 59 2a 28 |.../ . Y1=.(SY*(| 00001b70 59 30 2d 41 2a b5 28 41 4c 50 48 41 29 2d 41 2a |Y0-A*.(ALPHA)-A*| 00001b80 b5 28 42 45 54 41 2d 41 4c 50 48 41 29 29 29 0d |.(BETA-ALPHA))).| 00001b90 07 a8 14 20 e7 20 58 31 3c 30 20 8c 20 e9 20 58 |... . X1<0 . . X| 00001ba0 31 3d 30 0d 07 b2 1b 20 e7 20 58 31 3e 31 32 37 |1=0.... . X1>127| 00001bb0 39 20 8c 20 e9 20 58 31 3d 31 32 37 39 20 0d 07 |9 . . X1=1279 ..| 00001bc0 bc 14 20 e7 20 59 31 3c 30 20 8c 20 e9 20 59 31 |.. . Y1<0 . . Y1| 00001bd0 3d 30 0d 07 c6 1b 20 e7 20 59 31 3e 31 30 32 33 |=0.... . Y1>1023| 00001be0 20 8c 20 e9 20 59 31 3d 31 30 32 33 20 0d 07 ee | . . Y1=1023 ...| 00001bf0 06 20 f8 0d 07 f8 1c 20 f4 20 53 55 42 52 4f 55 |. ..... . SUBROU| 00001c00 54 49 4e 45 20 27 54 52 49 41 4e 47 4c 45 27 0d |TINE 'TRIANGLE'.| 00001c10 08 02 19 20 e4 20 8d 64 4c 46 3a f4 20 43 4f 4f |... . .dLF:. COO| 00001c20 52 44 49 4e 41 54 45 53 0d 08 0c 0c 20 e9 20 58 |RDINATES.... . X| 00001c30 31 3d 58 20 0d 08 16 1e 20 e9 20 59 31 3d 59 3a |1=X .... . Y1=Y:| 00001c40 f4 20 53 41 56 45 20 43 4f 4f 52 44 49 4e 41 54 |. SAVE COORDINAT| 00001c50 45 53 0d 08 20 19 20 e4 20 8d 64 4c 46 3a f4 20 |ES.. . . .dLF:. | 00001c60 43 4f 4f 52 44 49 4e 41 54 45 53 0d 08 2a 0b 20 |COORDINATES..*. | 00001c70 e9 20 58 32 3d 58 0d 08 34 20 20 e9 20 59 32 3d |. X2=X..4 . Y2=| 00001c80 59 20 3a f4 20 53 41 56 45 20 43 4f 4f 52 44 49 |Y :. SAVE COORDI| 00001c90 4e 41 54 45 53 20 0d 08 3e 19 20 e4 20 8d 64 4c |NATES ..>. . .dL| 00001ca0 46 3a f4 20 43 4f 4f 52 44 49 4e 41 54 45 53 0d |F:. COORDINATES.| 00001cb0 08 48 14 20 ec 20 58 31 2c 59 31 3a df 20 58 32 |.H. . X1,Y1:. X2| 00001cc0 2c 59 32 0d 08 52 12 20 ec 20 58 32 2c 59 32 3a |,Y2..R. . X2,Y2:| 00001cd0 df 20 58 2c 59 0d 08 5c 12 20 ec 20 58 2c 59 3a |. X,Y..\. . X,Y:| 00001ce0 df 20 58 31 2c 59 31 0d 08 66 06 20 f8 0d 08 70 |. X1,Y1..f. ...p| 00001cf0 1a 20 f4 20 53 55 42 52 4f 55 54 49 4e 45 20 27 |. . SUBROUTINE '| 00001d00 43 49 52 43 4c 45 27 0d 08 7a 19 20 e4 20 8d 64 |CIRCLE'..z. . .d| 00001d10 4c 46 3a f4 20 43 4f 4f 52 44 49 4e 41 54 45 53 |LF:. COORDINATES| 00001d20 0d 08 84 0b 20 e9 20 58 31 3d 58 0d 08 8e 0b 20 |.... . X1=X.... | 00001d30 e9 20 59 31 3d 59 0d 08 98 19 20 e4 20 8d 64 4c |. Y1=Y.... . .dL| 00001d40 46 3a f4 20 43 4f 4f 52 44 49 4e 41 54 45 53 0d |F:. COORDINATES.| 00001d50 08 a2 1d 20 e9 20 52 3d b6 28 28 58 31 2d 58 29 |... . R=.((X1-X)| 00001d60 5e 32 2b 28 59 31 2d 59 29 5e 32 29 0d 08 ac 1c |^2+(Y1-Y)^2)....| 00001d70 20 e3 20 50 48 49 3d 30 20 b8 20 af 2a 32 20 88 | . PHI=0 . .*2 .| 00001d80 20 28 af 2f 31 32 38 29 0d 08 b6 12 20 e9 20 58 | (./128).... . X| 00001d90 43 3d 9b 28 50 48 49 29 2a 52 0d 08 c0 12 20 e9 |C=.(PHI)*R.... .| 00001da0 20 59 43 3d b5 28 50 48 49 29 2a 52 0d 08 ca 1d | YC=.(PHI)*R....| 00001db0 20 e7 20 4b 3d 38 31 20 80 20 50 48 49 3d 30 20 | . K=81 . PHI=0 | 00001dc0 8c 20 ec 20 58 31 2c 59 31 0d 08 d4 1e 20 ec 20 |. . X1,Y1.... . | 00001dd0 58 31 2c 59 31 3a f4 20 43 45 4e 54 52 45 20 4f |X1,Y1:. CENTRE O| 00001de0 46 20 43 49 52 4c 45 0d 08 de 0e 20 f0 20 4b 2c |F CIRLE.... . K,| 00001df0 58 43 2c 59 43 0d 08 e8 0a 20 ed 20 50 48 49 0d |XC,YC.... . PHI.| 00001e00 08 f2 06 20 f8 0d ff |... ...| 00001e07