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