Home » Archimedes archive » Acorn User » AU 1997-09 B.adf » Regulars » StarInfo/Stoner/PlasBallXF
StarInfo/Stoner/PlasBallXF
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-09 B.adf » Regulars |
Filename: | StarInfo/Stoner/PlasBallXF |
Read OK: | ✔ |
File size: | 06DA bytes |
Load address: | 0000 |
Exec address: | 0000 |
File contents
1REM 3D Plasma Ball 2REM X Files version 3REM (I finnally sussed it!!) 4ON ERROR MODE12:REPORT:PRINT " at line ";ERL:END 5PROCinit 6REPEAT SYS 6,112,s%:s%=s%EOR3:SYS6,113,s%:WAIT:CLS:PROCrotate:PROCsort:t%=TIME:ORIGIN 320*SINRAD(t%/6)+640,256*SINRAD(t%/6.23)+512:zmag=1.5*SINRAD(t%/5)+1.7:PROCdraw:UNTIL FALSE 7END 8 9DEFPROCinit 10MODE 9+128:ORIGIN640,512:OFF:PROCcolors:DIM lx(99),ly(99),lz(99),depth(1024),dh%(99),dv%(99):s%=1:lines%=19 11FOR a%=-512 TO 512:depth(a%+512) = 1/((a%/720)+1):NEXT 12FOR a%=0 TO lines%:x%=380:y%=0:z%=0:yang%=RND(360):xang%=RND(360):s=SINRAD(yang%):c=COSRAD(yang%):xnew=x%*c-y%*s:ynew=x%*s+y%*c:x%=xnew:y%=ynew:s=SINRAD(xang%):c=COSRAD(xang%):znew=z%*c-y%*s:ynew=z%*s+y%*c:z%=znew:y%=ynew:lx(a%)=x%:lz(a%)=y%:ly(a%)=z% 13REPEAT:dh%(a%)=RND(8)-4:UNTIL dh%(a%)<>0:REPEAT:dv%(a%)=RND(8)-4:UNTIL dv%(a%)<>0:NEXT:zmag=0 14ENDPROC 15 16DEFPROCrotate 17FOR vtx%= 0 TO lines%:c=COSRAD(dh%(vtx%)):s=SINRAD(dh%(vtx%)):xnew=lx(vtx%)*c-lz(vtx%)*s:znew=lx(vtx%)*s+lz(vtx%)*c:lx(vtx%)=xnew:lz(vtx%)=znew 18c=COSRAD(dv%(vtx%)):s=SINRAD(dv%(vtx%)):ynew=ly(vtx%)*c-lz(vtx%)*s:znew=ly(vtx%)*s+lz(vtx%)*c:ly(vtx%)=ynew:lz(vtx%)=znew:NEXT vtx% 19ENDPROC 20 21DEFPROCsort 22FOR a%=0 TO lines%-1:IF lz(a%)<lz(a%+1) THEN SWAP lx(a%),lx(a%+1):SWAP ly(a%),ly(a%+1):SWAP lz(a%),lz(a%+1):SWAP dh%(a%),dh%(a%+1):SWAP dv%(a%),dv%(a%+1):a%=0 23NEXT a% 24ENDPROC 25 26DEFPROCdraw 27GCOL12:CIRCLE0,0,468*zmag:half%=(lines%+1)/2:FOR a%=0 TO half%:f=depth(INT(lz(a%))+512):px%=lx(a%)*f*zmag:py%=ly(a%)*f*zmag:GCOL f*7+1:MOVEpx%/6,py%/6:DRAWpx%,py%:CIRCLEFILLpx%,py%,3*zmag:NEXT a%:GCOL 0:CIRCLEFILL0,0,64*zmag:GCOL15:CIRCLEFILL-24*zmag,24*zmag,8*zmag 28FOR a%=half%+1 TO lines%:f=depth(INT(lz(a%))+512):GCOL f*7+1:px%=lx(a%)*f*zmag:py%=ly(a%)*f*zmag:CIRCLEFILLpx%/6,py%/6,3*zmag:FOR b = .25 TO 1 STEP .25:x%=RND(28*zmag)-14*zmag:y%=RND(28*zmag)-14*zmag:DRAWpx%*b+x%,py%*b+y%:NEXT b:CIRCLEFILLpx%+x%,py%+y%,6*zmag:NEXT a% 29ENDPROC 30 31DEFPROCcolors 32FOR a%=0 TO 15 STEP 2:COLOUR a%,a%*16,a%*8,a%*15:COLOUR a%+1,a%*8,a%*4,a%*7 33NEXT:COLOUR15,240,200,240 34ENDPROC
� 3D Plasma Ball � X Files version � (I finnally sussed it!!) � � �12:�:� " at line ";�:� �init �� ș 6,112,s%:s%=s%�3:ș6,113,s%:Ȗ:�:�rotate:�sort:t%=�:ȑ 320*��(t%/6)+640,256*��(t%/6.23)+512:zmag=1.5*��(t%/5)+1.7:�draw:� � � ��init a� 9+128:ȑ640,512:�:�colors:� lx(99),ly(99),lz(99),depth(1024),dh%(99),dv%(99):s%=1:lines%=19 4� a%=-512 � 512:depth(a%+512) = 1/((a%/720)+1):� �� a%=0 � lines%:x%=380:y%=0:z%=0:yang%=�(360):xang%=�(360):s=��(yang%):c=��(yang%):xnew=x%*c-y%*s:ynew=x%*s+y%*c:x%=xnew:y%=ynew:s=��(xang%):c=��(xang%):znew=z%*c-y%*s:ynew=z%*s+y%*c:z%=znew:y%=ynew:lx(a%)=x%:lz(a%)=y%:ly(a%)=z% H�:dh%(a%)=�(8)-4:� dh%(a%)<>0:�:dv%(a%)=�(8)-4:� dv%(a%)<>0:�:zmag=0 � ��rotate �� vtx%= 0 � lines%:c=��(dh%(vtx%)):s=��(dh%(vtx%)):xnew=lx(vtx%)*c-lz(vtx%)*s:znew=lx(vtx%)*s+lz(vtx%)*c:lx(vtx%)=xnew:lz(vtx%)=znew |c=��(dv%(vtx%)):s=��(dv%(vtx%)):ynew=ly(vtx%)*c-lz(vtx%)*s:znew=ly(vtx%)*s+lz(vtx%)*c:ly(vtx%)=ynew:lz(vtx%)=znew:� vtx% � ��sort �� a%=0 � lines%-1:� lz(a%)<lz(a%+1) � Ȕ lx(a%),lx(a%+1):Ȕ ly(a%),ly(a%+1):Ȕ lz(a%),lz(a%+1):Ȕ dh%(a%),dh%(a%+1):Ȕ dv%(a%),dv%(a%+1):a%=0 � a% � ��draw ��12:ȏ0,0,468*zmag:half%=(lines%+1)/2:� a%=0 � half%:f=depth(�(lz(a%))+512):px%=lx(a%)*f*zmag:py%=ly(a%)*f*zmag:� f*7+1:�px%/6,py%/6:�px%,py%:ȏȐpx%,py%,3*zmag:� a%:� 0:ȏȐ0,0,64*zmag:�15:ȏȐ-24*zmag,24*zmag,8*zmag �� a%=half%+1 � lines%:f=depth(�(lz(a%))+512):� f*7+1:px%=lx(a%)*f*zmag:py%=ly(a%)*f*zmag:ȏȐpx%/6,py%/6,3*zmag:� b = .25 � 1 � .25:x%=�(28*zmag)-14*zmag:y%=�(28*zmag)-14*zmag:�px%*b+x%,py%*b+y%:� b:ȏȐpx%+x%,py%+y%,6*zmag:� a% � ��colors ?� a%=0 � 15 � 2:� a%,a%*16,a%*8,a%*15:� a%+1,a%*8,a%*4,a%*7 !�:�15,240,200,240 "� �
00000000 0d 00 01 15 f4 20 20 33 44 20 50 6c 61 73 6d 61 |..... 3D Plasma| 00000010 20 42 61 6c 6c 0d 00 02 16 f4 20 20 58 20 46 69 | Ball..... X Fi| 00000020 6c 65 73 20 76 65 72 73 69 6f 6e 0d 00 03 1e f4 |les version.....| 00000030 20 28 49 20 66 69 6e 6e 61 6c 6c 79 20 73 75 73 | (I finnally sus| 00000040 73 65 64 20 69 74 21 21 29 0d 00 04 1f ee 20 85 |sed it!!)..... .| 00000050 20 eb 31 32 3a f6 3a f1 20 22 20 61 74 20 6c 69 | .12:.:. " at li| 00000060 6e 65 20 22 3b 9e 3a e0 0d 00 05 09 f2 69 6e 69 |ne ";.:......ini| 00000070 74 0d 00 06 84 f5 20 c8 99 20 36 2c 31 31 32 2c |t..... .. 6,112,| 00000080 73 25 3a 73 25 3d 73 25 82 33 3a c8 99 36 2c 31 |s%:s%=s%.3:..6,1| 00000090 31 33 2c 73 25 3a c8 96 3a db 3a f2 72 6f 74 61 |13,s%:..:.:.rota| 000000a0 74 65 3a f2 73 6f 72 74 3a 74 25 3d 91 3a c8 91 |te:.sort:t%=.:..| 000000b0 20 33 32 30 2a b5 b2 28 74 25 2f 36 29 2b 36 34 | 320*..(t%/6)+64| 000000c0 30 2c 32 35 36 2a b5 b2 28 74 25 2f 36 2e 32 33 |0,256*..(t%/6.23| 000000d0 29 2b 35 31 32 3a 7a 6d 61 67 3d 31 2e 35 2a b5 |)+512:zmag=1.5*.| 000000e0 b2 28 74 25 2f 35 29 2b 31 2e 37 3a f2 64 72 61 |.(t%/5)+1.7:.dra| 000000f0 77 3a fd 20 a3 0d 00 07 05 e0 0d 00 08 04 0d 00 |w:. ............| 00000100 09 0a dd f2 69 6e 69 74 0d 00 0a 61 eb 20 39 2b |....init...a. 9+| 00000110 31 32 38 3a c8 91 36 34 30 2c 35 31 32 3a 87 3a |128:..640,512:.:| 00000120 f2 63 6f 6c 6f 72 73 3a de 20 6c 78 28 39 39 29 |.colors:. lx(99)| 00000130 2c 6c 79 28 39 39 29 2c 6c 7a 28 39 39 29 2c 64 |,ly(99),lz(99),d| 00000140 65 70 74 68 28 31 30 32 34 29 2c 64 68 25 28 39 |epth(1024),dh%(9| 00000150 39 29 2c 64 76 25 28 39 39 29 3a 73 25 3d 31 3a |9),dv%(99):s%=1:| 00000160 6c 69 6e 65 73 25 3d 31 39 0d 00 0b 34 e3 20 61 |lines%=19...4. a| 00000170 25 3d 2d 35 31 32 20 b8 20 35 31 32 3a 64 65 70 |%=-512 . 512:dep| 00000180 74 68 28 61 25 2b 35 31 32 29 20 3d 20 31 2f 28 |th(a%+512) = 1/(| 00000190 28 61 25 2f 37 32 30 29 2b 31 29 3a ed 0d 00 0c |(a%/720)+1):....| 000001a0 e8 e3 20 61 25 3d 30 20 b8 20 6c 69 6e 65 73 25 |.. a%=0 . lines%| 000001b0 3a 78 25 3d 33 38 30 3a 79 25 3d 30 3a 7a 25 3d |:x%=380:y%=0:z%=| 000001c0 30 3a 79 61 6e 67 25 3d b3 28 33 36 30 29 3a 78 |0:yang%=.(360):x| 000001d0 61 6e 67 25 3d b3 28 33 36 30 29 3a 73 3d b5 b2 |ang%=.(360):s=..| 000001e0 28 79 61 6e 67 25 29 3a 63 3d 9b b2 28 79 61 6e |(yang%):c=..(yan| 000001f0 67 25 29 3a 78 6e 65 77 3d 78 25 2a 63 2d 79 25 |g%):xnew=x%*c-y%| 00000200 2a 73 3a 79 6e 65 77 3d 78 25 2a 73 2b 79 25 2a |*s:ynew=x%*s+y%*| 00000210 63 3a 78 25 3d 78 6e 65 77 3a 79 25 3d 79 6e 65 |c:x%=xnew:y%=yne| 00000220 77 3a 73 3d b5 b2 28 78 61 6e 67 25 29 3a 63 3d |w:s=..(xang%):c=| 00000230 9b b2 28 78 61 6e 67 25 29 3a 7a 6e 65 77 3d 7a |..(xang%):znew=z| 00000240 25 2a 63 2d 79 25 2a 73 3a 79 6e 65 77 3d 7a 25 |%*c-y%*s:ynew=z%| 00000250 2a 73 2b 79 25 2a 63 3a 7a 25 3d 7a 6e 65 77 3a |*s+y%*c:z%=znew:| 00000260 79 25 3d 79 6e 65 77 3a 6c 78 28 61 25 29 3d 78 |y%=ynew:lx(a%)=x| 00000270 25 3a 6c 7a 28 61 25 29 3d 79 25 3a 6c 79 28 61 |%:lz(a%)=y%:ly(a| 00000280 25 29 3d 7a 25 0d 00 0d 48 f5 3a 64 68 25 28 61 |%)=z%...H.:dh%(a| 00000290 25 29 3d b3 28 38 29 2d 34 3a fd 20 64 68 25 28 |%)=.(8)-4:. dh%(| 000002a0 61 25 29 3c 3e 30 3a f5 3a 64 76 25 28 61 25 29 |a%)<>0:.:dv%(a%)| 000002b0 3d b3 28 38 29 2d 34 3a fd 20 64 76 25 28 61 25 |=.(8)-4:. dv%(a%| 000002c0 29 3c 3e 30 3a ed 3a 7a 6d 61 67 3d 30 0d 00 0e |)<>0:.:zmag=0...| 000002d0 05 e1 0d 00 0f 04 0d 00 10 0c dd f2 72 6f 74 61 |............rota| 000002e0 74 65 0d 00 11 88 e3 20 76 74 78 25 3d 20 30 20 |te..... vtx%= 0 | 000002f0 b8 20 6c 69 6e 65 73 25 3a 63 3d 9b b2 28 64 68 |. lines%:c=..(dh| 00000300 25 28 76 74 78 25 29 29 3a 73 3d b5 b2 28 64 68 |%(vtx%)):s=..(dh| 00000310 25 28 76 74 78 25 29 29 3a 78 6e 65 77 3d 6c 78 |%(vtx%)):xnew=lx| 00000320 28 76 74 78 25 29 2a 63 2d 6c 7a 28 76 74 78 25 |(vtx%)*c-lz(vtx%| 00000330 29 2a 73 3a 7a 6e 65 77 3d 6c 78 28 76 74 78 25 |)*s:znew=lx(vtx%| 00000340 29 2a 73 2b 6c 7a 28 76 74 78 25 29 2a 63 3a 6c |)*s+lz(vtx%)*c:l| 00000350 78 28 76 74 78 25 29 3d 78 6e 65 77 3a 6c 7a 28 |x(vtx%)=xnew:lz(| 00000360 76 74 78 25 29 3d 7a 6e 65 77 0d 00 12 7c 63 3d |vtx%)=znew...|c=| 00000370 9b b2 28 64 76 25 28 76 74 78 25 29 29 3a 73 3d |..(dv%(vtx%)):s=| 00000380 b5 b2 28 64 76 25 28 76 74 78 25 29 29 3a 79 6e |..(dv%(vtx%)):yn| 00000390 65 77 3d 6c 79 28 76 74 78 25 29 2a 63 2d 6c 7a |ew=ly(vtx%)*c-lz| 000003a0 28 76 74 78 25 29 2a 73 3a 7a 6e 65 77 3d 6c 79 |(vtx%)*s:znew=ly| 000003b0 28 76 74 78 25 29 2a 73 2b 6c 7a 28 76 74 78 25 |(vtx%)*s+lz(vtx%| 000003c0 29 2a 63 3a 6c 79 28 76 74 78 25 29 3d 79 6e 65 |)*c:ly(vtx%)=yne| 000003d0 77 3a 6c 7a 28 76 74 78 25 29 3d 7a 6e 65 77 3a |w:lz(vtx%)=znew:| 000003e0 ed 20 76 74 78 25 0d 00 13 05 e1 0d 00 14 04 0d |. vtx%..........| 000003f0 00 15 0a dd f2 73 6f 72 74 0d 00 16 91 e3 20 61 |.....sort..... a| 00000400 25 3d 30 20 b8 20 6c 69 6e 65 73 25 2d 31 3a e7 |%=0 . lines%-1:.| 00000410 20 6c 7a 28 61 25 29 3c 6c 7a 28 61 25 2b 31 29 | lz(a%)<lz(a%+1)| 00000420 20 8c 20 c8 94 20 6c 78 28 61 25 29 2c 6c 78 28 | . .. lx(a%),lx(| 00000430 61 25 2b 31 29 3a c8 94 20 6c 79 28 61 25 29 2c |a%+1):.. ly(a%),| 00000440 6c 79 28 61 25 2b 31 29 3a c8 94 20 6c 7a 28 61 |ly(a%+1):.. lz(a| 00000450 25 29 2c 6c 7a 28 61 25 2b 31 29 3a c8 94 20 64 |%),lz(a%+1):.. d| 00000460 68 25 28 61 25 29 2c 64 68 25 28 61 25 2b 31 29 |h%(a%),dh%(a%+1)| 00000470 3a c8 94 20 64 76 25 28 61 25 29 2c 64 76 25 28 |:.. dv%(a%),dv%(| 00000480 61 25 2b 31 29 3a 61 25 3d 30 0d 00 17 08 ed 20 |a%+1):a%=0..... | 00000490 61 25 0d 00 18 05 e1 0d 00 19 04 0d 00 1a 0a dd |a%..............| 000004a0 f2 64 72 61 77 0d 00 1b dd e6 31 32 3a c8 8f 30 |.draw.....12:..0| 000004b0 2c 30 2c 34 36 38 2a 7a 6d 61 67 3a 68 61 6c 66 |,0,468*zmag:half| 000004c0 25 3d 28 6c 69 6e 65 73 25 2b 31 29 2f 32 3a e3 |%=(lines%+1)/2:.| 000004d0 20 61 25 3d 30 20 b8 20 68 61 6c 66 25 3a 66 3d | a%=0 . half%:f=| 000004e0 64 65 70 74 68 28 a8 28 6c 7a 28 61 25 29 29 2b |depth(.(lz(a%))+| 000004f0 35 31 32 29 3a 70 78 25 3d 6c 78 28 61 25 29 2a |512):px%=lx(a%)*| 00000500 66 2a 7a 6d 61 67 3a 70 79 25 3d 6c 79 28 61 25 |f*zmag:py%=ly(a%| 00000510 29 2a 66 2a 7a 6d 61 67 3a e6 20 66 2a 37 2b 31 |)*f*zmag:. f*7+1| 00000520 3a ec 70 78 25 2f 36 2c 70 79 25 2f 36 3a df 70 |:.px%/6,py%/6:.p| 00000530 78 25 2c 70 79 25 3a c8 8f c8 90 70 78 25 2c 70 |x%,py%:....px%,p| 00000540 79 25 2c 33 2a 7a 6d 61 67 3a ed 20 61 25 3a e6 |y%,3*zmag:. a%:.| 00000550 20 30 3a c8 8f c8 90 30 2c 30 2c 36 34 2a 7a 6d | 0:....0,0,64*zm| 00000560 61 67 3a e6 31 35 3a c8 8f c8 90 2d 32 34 2a 7a |ag:.15:....-24*z| 00000570 6d 61 67 2c 32 34 2a 7a 6d 61 67 2c 38 2a 7a 6d |mag,24*zmag,8*zm| 00000580 61 67 0d 00 1c e8 e3 20 61 25 3d 68 61 6c 66 25 |ag..... a%=half%| 00000590 2b 31 20 b8 20 6c 69 6e 65 73 25 3a 66 3d 64 65 |+1 . lines%:f=de| 000005a0 70 74 68 28 a8 28 6c 7a 28 61 25 29 29 2b 35 31 |pth(.(lz(a%))+51| 000005b0 32 29 3a e6 20 66 2a 37 2b 31 3a 70 78 25 3d 6c |2):. f*7+1:px%=l| 000005c0 78 28 61 25 29 2a 66 2a 7a 6d 61 67 3a 70 79 25 |x(a%)*f*zmag:py%| 000005d0 3d 6c 79 28 61 25 29 2a 66 2a 7a 6d 61 67 3a c8 |=ly(a%)*f*zmag:.| 000005e0 8f c8 90 70 78 25 2f 36 2c 70 79 25 2f 36 2c 33 |...px%/6,py%/6,3| 000005f0 2a 7a 6d 61 67 3a e3 20 62 20 3d 20 2e 32 35 20 |*zmag:. b = .25 | 00000600 b8 20 31 20 88 20 2e 32 35 3a 78 25 3d b3 28 32 |. 1 . .25:x%=.(2| 00000610 38 2a 7a 6d 61 67 29 2d 31 34 2a 7a 6d 61 67 3a |8*zmag)-14*zmag:| 00000620 79 25 3d b3 28 32 38 2a 7a 6d 61 67 29 2d 31 34 |y%=.(28*zmag)-14| 00000630 2a 7a 6d 61 67 3a df 70 78 25 2a 62 2b 78 25 2c |*zmag:.px%*b+x%,| 00000640 70 79 25 2a 62 2b 79 25 3a ed 20 62 3a c8 8f c8 |py%*b+y%:. b:...| 00000650 90 70 78 25 2b 78 25 2c 70 79 25 2b 79 25 2c 36 |.px%+x%,py%+y%,6| 00000660 2a 7a 6d 61 67 3a ed 20 61 25 0d 00 1d 05 e1 0d |*zmag:. a%......| 00000670 00 1e 04 0d 00 1f 0c dd f2 63 6f 6c 6f 72 73 0d |.........colors.| 00000680 00 20 3f e3 20 61 25 3d 30 20 b8 20 31 35 20 88 |. ?. a%=0 . 15 .| 00000690 20 32 3a fb 20 61 25 2c 61 25 2a 31 36 2c 61 25 | 2:. a%,a%*16,a%| 000006a0 2a 38 2c 61 25 2a 31 35 3a fb 20 61 25 2b 31 2c |*8,a%*15:. a%+1,| 000006b0 61 25 2a 38 2c 61 25 2a 34 2c 61 25 2a 37 0d 00 |a%*8,a%*4,a%*7..| 000006c0 21 15 ed 3a fb 31 35 2c 32 34 30 2c 32 30 30 2c |!..:.15,240,200,| 000006d0 32 34 30 0d 00 22 05 e1 0d ff |240.."....| 000006da