Home » Archimedes archive » Acorn User » AU 1997-05 B.adf » Regulars » StarInfo/Boham/full/Plasma2Col
StarInfo/Boham/full/Plasma2Col
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 » Archimedes archive » Acorn User » AU 1997-05 B.adf » Regulars |
Filename: | StarInfo/Boham/full/Plasma2Col |
Read OK: | ✔ |
File size: | 079D bytes |
Load address: | 0000 |
Exec address: | 0000 |
File contents
1ON ERROR: ON ERROR OFF: PRINT REPORT$;" at line ";ERL:END 2MODE 15 3MODE 13:OFF 4colour%=TRUE 5PROCass:OFF 6S1=1:S2=2 7TIME=0 8REPEAT 9WAIT:SYS 6,112,S1:SYS 6,113,S2:CLS:SWAP S1,S2 10CALL plot_grid 11UNTIL 0=1 12MODE 13 13END 14: 15DEF PROCass 16DIM code% 2048,array% 320*256,col_table 90 17FOR pass=0 TO 2 STEP 2 18P%=code% 19[OPT pass 20.plot_grid 21ADR R0,s1:ADR R1,s2:SWI &31 22LDR R12,s2 ;r12 - scr, r11 - grid, r10 - col_table 23LDR R11,grid_addr 24LDR R10,col_addr 25LDR R0,scr_adder 26ADD R12,R12,R0 27MOV R9,#0 28.yloop 29MOV R8,#0 ;r9 =y, r8 = x 30.xloop 31LDRB R0,[R11] 32LDRB R1,[R11,#-320] 33LDRB R2,[R11,#1] 34LDRB R3,[R11,#320] 35 36CMP R0,#45:ADDLT R0,R0,#1:SUBGT R0,R0,#1 37CMP R1,#25:ADDLT R1,R1,#2:SUBGT R1,R1,#2 38CMP R2,#65:ADDLT R2,R2,#2:SUBGT R2,R2,#2 39CMP R3,#80:ADDLT R3,R3,#2:SUBGT R3,R3,#2 40 41 42ADD R0,R0,R1 43ADD R0,R0,R2 44ADD R0,R0,R3 45MOV R0,R0,LSR #2 46 47ADD R0,R0,#5 48CMP R0,#90 49MOVGE R0,#0 50 51 52STRB R0,[R11] 53 54LDRB R1,[R10,R0] 55STRB R1,[R12] 56 57ADD R11,R11,#1 58ADD R12,R12,#1 59 60 61 62ADD R8,R8,#1 63CMP R8,#320 64BLE xloop 65 66;ADD R12,R12,#320 67 68ADD R9,R9,#1 69CMP R9,#255 70BLT yloop 71 72 73MOV PC,R14 74.s1 EQUD 148 75 EQUD -1 76.s2 EQUD 0 77.grid_addr EQUD array% 78.col_addr EQUD col_table 79.scr_adder EQUD 0 80] 81NEXT pass 82 83REM ********* Setup colour table 84loc=col_table 85SYS &31,s1,s2:base=!s2 86 87IF colour% THEN 88FOR h=0 TO 359 STEP 4 89SYS "ColourTrans_ConvertHSVToRGB",h*65000*2,130*256,255 TO r,g,b 90SYS "ColourTrans_SetGCOL",(r<<8)+(g<<16)+(b<<24) 91POINT 0,1023 92?loc=?base 93loc+=1 94NEXT h 95ELSE 96FOR r=0 TO 89 97 98IF r<45 THEN g=(45-r)*2.83333+128 ELSE g=(r-45)*2.83333+128 99 100SYS "ColourTrans_SetGCOL",(g<<8)+(g<<16)+(g<<24) 101POINT 0,1023 102?loc=?base 103loc+=1 104NEXT r 105ENDIF 106 107?base=0 108 109 110REM ********* Setup grid 111FOR loc=array% TO array%+320*256-1 STEP 4 112!loc=RND(1<<30) 113NEXT 114CLS 115ENDPROC
$� �: � � �: � �$;" at line ";�:� � 15 � 13:� colour%=� �ass:� S1=1:S2=2 �=0 � )Ȗ:ș 6,112,S1:ș 6,113,S2:�:Ȕ S1,S2 � plot_grid � 0=1 � 13 � : � �ass ,� code% 2048,array% 320*256,col_table 90 � pass=0 � 2 � 2 P%=code% [OPT pass .plot_grid ADR R0,s1:ADR R1,s2:SWI &31 MLDR R12,s2 ;r12 - scr, r11 - grid, r10 - col_table LDR R11,grid_addr LDR R10,col_addr LDR R0,scr_adder ADD R12,R12,R0 MOV R9,#0 .yloop .MOV R8,#0 ;r9 =y, r8 = x .xloop LDRB R0,[R11] LDRB R1,[R11,#-320] !LDRB R2,[R11,#1] "LDRB R3,[R11,#320] # $,CMP R0,#45:ADDLT R0,R0,#1:SUBGT R0,R0,#1 %,CMP R1,#25:ADDLT R1,R1,#2:SUBGT R1,R1,#2 &,CMP R2,#65:ADDLT R2,R2,#2:SUBGT R2,R2,#2 ',CMP R3,#80:ADDLT R3,R3,#2:SUBGT R3,R3,#2 ( ) *ADD R0,R0,R1 +ADD R0,R0,R2 ,ADD R0,R0,R3 -MOV R0,R0,LSR #2 . /ADD R0,R0,#5 0CMP R0,#90 1MOVGE R0,#0 2 3 4STRB R0,[R11] 5 6LDRB R1,[R10,R0] 7STRB R1,[R12] 8 9ADD R11,R11,#1 :ADD R12,R12,#1 ; < = >ADD R8,R8,#1 ?CMP R8,#320 @ BLE xloop A B;ADD R12,R12,#320 C DADD R9,R9,#1 ECMP R9,#255 F BLT yloop G H IMOV PC,R14 J.s1 EQUD 148 K EQUD -1 L.s2 EQUD 0 M.grid_addr EQUD array% N.col_addr EQUD col_table O.scr_adder EQUD 0 P] Q � pass R S"� ********* Setup colour table Tloc=col_table Uș &31,s1,s2:base=!s2 V W� colour% � X� h=0 � 359 � 4 YBș "ColourTrans_ConvertHSVToRGB",h*65000*2,130*256,255 � r,g,b Z3ș "ColourTrans_SetGCOL",(r<<8)+(g<<16)+(b<<24) [ Ȓ 0,1023 \?loc=?base ] loc+=1 ^� h _� `� r=0 � 89 a b8� r<45 � g=(45-r)*2.83333+128 � g=(r-45)*2.83333+128 c d3ș "ColourTrans_SetGCOL",(g<<8)+(g<<16)+(g<<24) e Ȓ 0,1023 f?loc=?base g loc+=1 h� r i� j k?base=0 l m n� ********* Setup grid o'� loc=array% � array%+320*256-1 � 4 p!loc=�(1<<30) q� r� s� �
00000000 0d 00 01 24 ee 20 85 3a 20 ee 20 85 20 87 3a 20 |...$. .: . . .: | 00000010 f1 20 f6 24 3b 22 20 61 74 20 6c 69 6e 65 20 22 |. .$;" at line "| 00000020 3b 9e 3a e0 0d 00 02 08 eb 20 31 35 0d 00 03 0a |;.:...... 15....| 00000030 eb 20 31 33 3a 87 0d 00 04 0d 63 6f 6c 6f 75 72 |. 13:.....colour| 00000040 25 3d b9 0d 00 05 0a f2 61 73 73 3a 87 0d 00 06 |%=......ass:....| 00000050 0d 53 31 3d 31 3a 53 32 3d 32 0d 00 07 07 d1 3d |.S1=1:S2=2.....=| 00000060 30 0d 00 08 05 f5 0d 00 09 29 c8 96 3a c8 99 20 |0........)..:.. | 00000070 36 2c 31 31 32 2c 53 31 3a c8 99 20 36 2c 31 31 |6,112,S1:.. 6,11| 00000080 33 2c 53 32 3a db 3a c8 94 20 53 31 2c 53 32 0d |3,S2:.:.. S1,S2.| 00000090 00 0a 0f d6 20 70 6c 6f 74 5f 67 72 69 64 0d 00 |.... plot_grid..| 000000a0 0b 09 fd 20 30 3d 31 0d 00 0c 08 eb 20 31 33 0d |... 0=1..... 13.| 000000b0 00 0d 05 e0 0d 00 0e 05 3a 0d 00 0f 0a dd 20 f2 |........:..... .| 000000c0 61 73 73 0d 00 10 2c de 20 63 6f 64 65 25 20 32 |ass...,. code% 2| 000000d0 30 34 38 2c 61 72 72 61 79 25 20 33 32 30 2a 32 |048,array% 320*2| 000000e0 35 36 2c 63 6f 6c 5f 74 61 62 6c 65 20 39 30 0d |56,col_table 90.| 000000f0 00 11 14 e3 20 70 61 73 73 3d 30 20 b8 20 32 20 |.... pass=0 . 2 | 00000100 88 20 32 0d 00 12 0c 50 25 3d 63 6f 64 65 25 0d |. 2....P%=code%.| 00000110 00 13 0d 5b 4f 50 54 20 70 61 73 73 0d 00 14 0e |...[OPT pass....| 00000120 2e 70 6c 6f 74 5f 67 72 69 64 0d 00 15 1f 41 44 |.plot_grid....AD| 00000130 52 20 52 30 2c 73 31 3a 41 44 52 20 52 31 2c 73 |R R0,s1:ADR R1,s| 00000140 32 3a 53 57 49 20 26 33 31 0d 00 16 4d 4c 44 52 |2:SWI &31...MLDR| 00000150 20 52 31 32 2c 73 32 20 20 20 20 20 20 20 20 20 | R12,s2 | 00000160 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b | ;| 00000170 72 31 32 20 2d 20 73 63 72 2c 20 72 31 31 20 2d |r12 - scr, r11 -| 00000180 20 67 72 69 64 2c 20 72 31 30 20 2d 20 63 6f 6c | grid, r10 - col| 00000190 5f 74 61 62 6c 65 0d 00 17 15 4c 44 52 20 52 31 |_table....LDR R1| 000001a0 31 2c 67 72 69 64 5f 61 64 64 72 0d 00 18 14 4c |1,grid_addr....L| 000001b0 44 52 20 52 31 30 2c 63 6f 6c 5f 61 64 64 72 0d |DR R10,col_addr.| 000001c0 00 19 14 4c 44 52 20 52 30 2c 73 63 72 5f 61 64 |...LDR R0,scr_ad| 000001d0 64 65 72 0d 00 1a 12 41 44 44 20 52 31 32 2c 52 |der....ADD R12,R| 000001e0 31 32 2c 52 30 0d 00 1b 0d 4d 4f 56 20 52 39 2c |12,R0....MOV R9,| 000001f0 23 30 0d 00 1c 0a 2e 79 6c 6f 6f 70 0d 00 1d 2e |#0.....yloop....| 00000200 4d 4f 56 20 52 38 2c 23 30 20 20 20 20 20 20 20 |MOV R8,#0 | 00000210 20 20 20 20 20 20 20 20 20 20 20 20 3b 72 39 20 | ;r9 | 00000220 3d 79 2c 20 72 38 20 3d 20 78 0d 00 1e 0a 2e 78 |=y, r8 = x.....x| 00000230 6c 6f 6f 70 0d 00 1f 11 4c 44 52 42 20 52 30 2c |loop....LDRB R0,| 00000240 5b 52 31 31 5d 0d 00 20 17 4c 44 52 42 20 52 31 |[R11].. .LDRB R1| 00000250 2c 5b 52 31 31 2c 23 2d 33 32 30 5d 0d 00 21 14 |,[R11,#-320]..!.| 00000260 4c 44 52 42 20 52 32 2c 5b 52 31 31 2c 23 31 5d |LDRB R2,[R11,#1]| 00000270 0d 00 22 16 4c 44 52 42 20 52 33 2c 5b 52 31 31 |..".LDRB R3,[R11| 00000280 2c 23 33 32 30 5d 0d 00 23 04 0d 00 24 2c 43 4d |,#320]..#...$,CM| 00000290 50 20 52 30 2c 23 34 35 3a 41 44 44 4c 54 20 52 |P R0,#45:ADDLT R| 000002a0 30 2c 52 30 2c 23 31 3a 53 55 42 47 54 20 52 30 |0,R0,#1:SUBGT R0| 000002b0 2c 52 30 2c 23 31 0d 00 25 2c 43 4d 50 20 52 31 |,R0,#1..%,CMP R1| 000002c0 2c 23 32 35 3a 41 44 44 4c 54 20 52 31 2c 52 31 |,#25:ADDLT R1,R1| 000002d0 2c 23 32 3a 53 55 42 47 54 20 52 31 2c 52 31 2c |,#2:SUBGT R1,R1,| 000002e0 23 32 0d 00 26 2c 43 4d 50 20 52 32 2c 23 36 35 |#2..&,CMP R2,#65| 000002f0 3a 41 44 44 4c 54 20 52 32 2c 52 32 2c 23 32 3a |:ADDLT R2,R2,#2:| 00000300 53 55 42 47 54 20 52 32 2c 52 32 2c 23 32 0d 00 |SUBGT R2,R2,#2..| 00000310 27 2c 43 4d 50 20 52 33 2c 23 38 30 3a 41 44 44 |',CMP R3,#80:ADD| 00000320 4c 54 20 52 33 2c 52 33 2c 23 32 3a 53 55 42 47 |LT R3,R3,#2:SUBG| 00000330 54 20 52 33 2c 52 33 2c 23 32 0d 00 28 04 0d 00 |T R3,R3,#2..(...| 00000340 29 04 0d 00 2a 10 41 44 44 20 52 30 2c 52 30 2c |)...*.ADD R0,R0,| 00000350 52 31 0d 00 2b 10 41 44 44 20 52 30 2c 52 30 2c |R1..+.ADD R0,R0,| 00000360 52 32 0d 00 2c 10 41 44 44 20 52 30 2c 52 30 2c |R2..,.ADD R0,R0,| 00000370 52 33 0d 00 2d 14 4d 4f 56 20 52 30 2c 52 30 2c |R3..-.MOV R0,R0,| 00000380 4c 53 52 20 23 32 0d 00 2e 04 0d 00 2f 10 41 44 |LSR #2....../.AD| 00000390 44 20 52 30 2c 52 30 2c 23 35 0d 00 30 0e 43 4d |D R0,R0,#5..0.CM| 000003a0 50 20 52 30 2c 23 39 30 0d 00 31 0f 4d 4f 56 47 |P R0,#90..1.MOVG| 000003b0 45 20 52 30 2c 23 30 0d 00 32 04 0d 00 33 04 0d |E R0,#0..2...3..| 000003c0 00 34 11 53 54 52 42 20 52 30 2c 5b 52 31 31 5d |.4.STRB R0,[R11]| 000003d0 0d 00 35 04 0d 00 36 14 4c 44 52 42 20 52 31 2c |..5...6.LDRB R1,| 000003e0 5b 52 31 30 2c 52 30 5d 0d 00 37 11 53 54 52 42 |[R10,R0]..7.STRB| 000003f0 20 52 31 2c 5b 52 31 32 5d 0d 00 38 04 0d 00 39 | R1,[R12]..8...9| 00000400 12 41 44 44 20 52 31 31 2c 52 31 31 2c 23 31 0d |.ADD R11,R11,#1.| 00000410 00 3a 12 41 44 44 20 52 31 32 2c 52 31 32 2c 23 |.:.ADD R12,R12,#| 00000420 31 0d 00 3b 04 0d 00 3c 04 0d 00 3d 04 0d 00 3e |1..;...<...=...>| 00000430 10 41 44 44 20 52 38 2c 52 38 2c 23 31 0d 00 3f |.ADD R8,R8,#1..?| 00000440 0f 43 4d 50 20 52 38 2c 23 33 32 30 0d 00 40 0d |.CMP R8,#320..@.| 00000450 42 4c 45 20 78 6c 6f 6f 70 0d 00 41 04 0d 00 42 |BLE xloop..A...B| 00000460 15 3b 41 44 44 20 52 31 32 2c 52 31 32 2c 23 33 |.;ADD R12,R12,#3| 00000470 32 30 0d 00 43 04 0d 00 44 10 41 44 44 20 52 39 |20..C...D.ADD R9| 00000480 2c 52 39 2c 23 31 0d 00 45 0f 43 4d 50 20 52 39 |,R9,#1..E.CMP R9| 00000490 2c 23 32 35 35 0d 00 46 0d 42 4c 54 20 79 6c 6f |,#255..F.BLT ylo| 000004a0 6f 70 0d 00 47 04 0d 00 48 04 0d 00 49 0e 4d 4f |op..G...H...I.MO| 000004b0 56 20 50 43 2c 52 31 34 0d 00 4a 17 2e 73 31 20 |V PC,R14..J..s1 | 000004c0 20 20 20 20 20 20 20 45 51 55 44 20 31 34 38 0d | EQUD 148.| 000004d0 00 4b 16 20 20 20 20 20 20 20 20 20 20 20 45 51 |.K. EQ| 000004e0 55 44 20 2d 31 0d 00 4c 15 2e 73 32 20 20 20 20 |UD -1..L..s2 | 000004f0 20 20 20 20 45 51 55 44 20 30 0d 00 4d 1a 2e 67 | EQUD 0..M..g| 00000500 72 69 64 5f 61 64 64 72 20 45 51 55 44 20 61 72 |rid_addr EQUD ar| 00000510 72 61 79 25 0d 00 4e 1d 2e 63 6f 6c 5f 61 64 64 |ray%..N..col_add| 00000520 72 20 20 45 51 55 44 20 63 6f 6c 5f 74 61 62 6c |r EQUD col_tabl| 00000530 65 0d 00 4f 15 2e 73 63 72 5f 61 64 64 65 72 20 |e..O..scr_adder | 00000540 45 51 55 44 20 30 0d 00 50 05 5d 0d 00 51 0a ed |EQUD 0..P.]..Q..| 00000550 20 70 61 73 73 0d 00 52 04 0d 00 53 22 f4 20 2a | pass..R...S". *| 00000560 2a 2a 2a 2a 2a 2a 2a 2a 20 53 65 74 75 70 20 63 |******** Setup c| 00000570 6f 6c 6f 75 72 20 74 61 62 6c 65 0d 00 54 11 6c |olour table..T.l| 00000580 6f 63 3d 63 6f 6c 5f 74 61 62 6c 65 0d 00 55 19 |oc=col_table..U.| 00000590 c8 99 20 26 33 31 2c 73 31 2c 73 32 3a 62 61 73 |.. &31,s1,s2:bas| 000005a0 65 3d 21 73 32 0d 00 56 04 0d 00 57 0f e7 20 63 |e=!s2..V...W.. c| 000005b0 6f 6c 6f 75 72 25 20 8c 0d 00 58 13 e3 20 68 3d |olour% ...X.. h=| 000005c0 30 20 b8 20 33 35 39 20 88 20 34 0d 00 59 42 c8 |0 . 359 . 4..YB.| 000005d0 99 20 22 43 6f 6c 6f 75 72 54 72 61 6e 73 5f 43 |. "ColourTrans_C| 000005e0 6f 6e 76 65 72 74 48 53 56 54 6f 52 47 42 22 2c |onvertHSVToRGB",| 000005f0 68 2a 36 35 30 30 30 2a 32 2c 31 33 30 2a 32 35 |h*65000*2,130*25| 00000600 36 2c 32 35 35 20 b8 20 72 2c 67 2c 62 0d 00 5a |6,255 . r,g,b..Z| 00000610 33 c8 99 20 22 43 6f 6c 6f 75 72 54 72 61 6e 73 |3.. "ColourTrans| 00000620 5f 53 65 74 47 43 4f 4c 22 2c 28 72 3c 3c 38 29 |_SetGCOL",(r<<8)| 00000630 2b 28 67 3c 3c 31 36 29 2b 28 62 3c 3c 32 34 29 |+(g<<16)+(b<<24)| 00000640 0d 00 5b 0d c8 92 20 30 2c 31 30 32 33 0d 00 5c |..[... 0,1023..\| 00000650 0e 3f 6c 6f 63 3d 3f 62 61 73 65 0d 00 5d 0a 6c |.?loc=?base..].l| 00000660 6f 63 2b 3d 31 0d 00 5e 07 ed 20 68 0d 00 5f 05 |oc+=1..^.. h.._.| 00000670 cc 0d 00 60 0e e3 20 72 3d 30 20 b8 20 38 39 0d |...`.. r=0 . 89.| 00000680 00 61 04 0d 00 62 38 e7 20 72 3c 34 35 20 8c 20 |.a...b8. r<45 . | 00000690 67 3d 28 34 35 2d 72 29 2a 32 2e 38 33 33 33 33 |g=(45-r)*2.83333| 000006a0 2b 31 32 38 20 8b 20 67 3d 28 72 2d 34 35 29 2a |+128 . g=(r-45)*| 000006b0 32 2e 38 33 33 33 33 2b 31 32 38 0d 00 63 04 0d |2.83333+128..c..| 000006c0 00 64 33 c8 99 20 22 43 6f 6c 6f 75 72 54 72 61 |.d3.. "ColourTra| 000006d0 6e 73 5f 53 65 74 47 43 4f 4c 22 2c 28 67 3c 3c |ns_SetGCOL",(g<<| 000006e0 38 29 2b 28 67 3c 3c 31 36 29 2b 28 67 3c 3c 32 |8)+(g<<16)+(g<<2| 000006f0 34 29 0d 00 65 0d c8 92 20 30 2c 31 30 32 33 0d |4)..e... 0,1023.| 00000700 00 66 0e 3f 6c 6f 63 3d 3f 62 61 73 65 0d 00 67 |.f.?loc=?base..g| 00000710 0a 6c 6f 63 2b 3d 31 0d 00 68 07 ed 20 72 0d 00 |.loc+=1..h.. r..| 00000720 69 05 cd 0d 00 6a 04 0d 00 6b 0b 3f 62 61 73 65 |i....j...k.?base| 00000730 3d 30 0d 00 6c 04 0d 00 6d 04 0d 00 6e 1a f4 20 |=0..l...m...n.. | 00000740 2a 2a 2a 2a 2a 2a 2a 2a 2a 20 53 65 74 75 70 20 |********* Setup | 00000750 67 72 69 64 0d 00 6f 27 e3 20 6c 6f 63 3d 61 72 |grid..o'. loc=ar| 00000760 72 61 79 25 20 b8 20 61 72 72 61 79 25 2b 33 32 |ray% . array%+32| 00000770 30 2a 32 35 36 2d 31 20 88 20 34 0d 00 70 11 21 |0*256-1 . 4..p.!| 00000780 6c 6f 63 3d b3 28 31 3c 3c 33 30 29 0d 00 71 05 |loc=.(1<<30)..q.| 00000790 ed 0d 00 72 05 db 0d 00 73 05 e1 0d ff |...r....s....| 0000079d