Home » Archimedes archive » Acorn User » AU 1997-07 A.adf » Regulars » info/Mellor/MagicTree

info/Mellor/MagicTree

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-07 A.adf » Regulars
Filename: info/Mellor/MagicTree
Read OK:
File size: 062C bytes
Load address: 0000
Exec address: 0000
File contents
   10REM Magic Tree
   20REM By Philip Mellor (aged 15)
   30REM Acorn User/Star Info
   40:
   50MODE9:OFF
   60PROCsetupcolours
   70:
   80FOR I=1 TO 15
   90COLOUR I,200-(I*13),64+(I*13),RND(32)
  100NEXT
  110REPEAT
  120INPUT"Spread (degrees) (35):"spread
  121IF spread=0 spread=35
  130INPUT"Split (number) (2):"split
  131IF split=0 split=2
  132INPUT"Height (units) (160):"height
  133IF height=0 height=160
  150cycle%=FALSE:INPUT"Cycle colours while drawing? Y/N";a$
  160IF a$="Y" OR a$="y" cycle%=TRUE
  170CLS
  180PROCbranch(640,0,height,FNr(2),1,8)
  190REPEAT
  200MOUSEX,Y,Z
  210PROCcycle:WAIT:WAIT:WAIT:WAIT
  220UNTILZ<>0
  230UNTIL0
  240END
  250:
  260DEFPROCbranch(x,y,z,a,c,s)
  270IF cycle% PROCcycle:WAIT
  280LOCAL q,w,I,l
  290IF z<8 ENDPROC
  300l=z/12
  310q=x+(z*SINRADa)
  320w=y+(z*COSRADa)
  330GCOL c TINT RND(256)-1:REM1+(15/1024)*y
  340IF c<0 THEN
  350MOVE x,y
  360DRAW q,w
  370ELSE
  380MOVE x-l,y
  390DRAW q-l,w
  400PLOT85,q+l,w
  410MOVEx+l,y
  420PLOT85,x-l,y
  430ENDIF
  440FOR I=1 TO ((s-2)+RND(2))
  450PROCbranch(q,w,z*RND(1),a+FNr(spread),c+1,s*.9)
  460NEXT
  470ENDPROC
  480:
  490DEFFNr(a)
  500IF RND(2)=1 THEN =RND(a) ELSE =-RND(a)
  510:
  520DEFPROCsetupcolours
  530DIM a(16),b(16),c(16)
  540FOR I=0 TO 16
  550a(I)=I*17:b(I)=I*17:c(I)=I*17
  560COLOUR I,a(I),b(I),c(I)
  570NEXT
  580IF RND(2)=1 ad=RND(16) ELSE ad=-RND(16)
  590IF RND(2)=1 bd=RND(16) ELSE bd=-RND(16)
  600IF RND(2)=1 cd=RND(16) ELSE cd=-RND(16)
  610ENDPROC
  620:
  630DEFPROCcycle
  640LOCAL I
  650a(16)+=ad:b(16)+=bd:c(16)+=cd
  660IF RND(10)=1 ad=RND(16):IF RND(2)=1 ad=-RND(16)
  670IF RND(10)=1 bd=RND(16):IF RND(2)=1 bd=-RND(16)
  680IF RND(10)=1 cd=RND(16):IF RND(2)=1 cd=-RND(16)
  690IF a(16)<0 a(16)=0:ad=RND(16)
  700IF a(16)>255 a(16)=255:ad=-RND(16)
  710IF b(16)<0 b(16)=0:bd=RND(16)
  720IF b(16)>255 b(16)=255:bd=-RND(16)
  730IF c(16)<0 c(16)=0:cd=RND(16)
  740IF c(16)>255 c(16)=255:cd=-RND(16)
  750FOR I=1 TO 15
  760a(I)=a(I+1)
  770b(I)=b(I+1)
  780c(I)=c(I+1)
  790COLOUR 16-I,a(I),b(I),c(I)
  800NEXT
  810ENDPROC

� Magic Tree
 � By Philip Mellor (aged 15)
� Acorn User/Star Info
(:
2�9:�
<�setupcolours
F:
P� I=1 � 15
Z"� I,200-(I*13),64+(I*13),�(32)
d�
n�
x#�"Spread (degrees) (35):"spread
y� spread=0 spread=35
��"Split (number) (2):"split
�� split=0 split=2
�"�"Height (units) (160):"height
�� height=0 height=160
�3cycle%=�:�"Cycle colours while drawing? Y/N";a$
�� a$="Y" � a$="y" cycle%=�
��
�#�branch(640,0,height,�r(2),1,8)
��
�ȗX,Y,Z
��cycle:Ȗ:Ȗ:Ȗ:Ȗ
�	�Z<>0
��0
��
�:
��branch(x,y,z,a,c,s)
� cycle% �cycle:Ȗ

� q,w,I,l
"� z<8 �
,
l=z/12
6q=x+(z*��a)
@w=y+(z*��a)
J"� c Ȝ �(256)-1:�1+(15/1024)*y
T� c<0 �
^	� x,y
h	� q,w
r�
|� x-l,y
�� q-l,w
�
�85,q+l,w
�
�x+l,y
�
�85,x-l,y
��
�� I=1 � ((s-2)+�(2))
�-�branch(q,w,z*�(1),a+�r(spread),c+1,s*.9)
��
��
�:
�
ݤr(a)
�� �(2)=1 � =�(a) � =-�(a)
�:
��setupcolours
� a(16),b(16),c(16)
� I=0 � 16
&!a(I)=I*17:b(I)=I*17:c(I)=I*17
0� I,a(I),b(I),c(I)
:�
D!� �(2)=1 ad=�(16) � ad=-�(16)
N!� �(2)=1 bd=�(16) � bd=-�(16)
X!� �(2)=1 cd=�(16) � cd=-�(16)
b�
l:
v��cycle
�� I
�!a(16)+=ad:b(16)+=bd:c(16)+=cd
�)� �(10)=1 ad=�(16):� �(2)=1 ad=-�(16)
�)� �(10)=1 bd=�(16):� �(2)=1 bd=-�(16)
�)� �(10)=1 cd=�(16):� �(2)=1 cd=-�(16)
�� a(16)<0 a(16)=0:ad=�(16)
�#� a(16)>255 a(16)=255:ad=-�(16)
�� b(16)<0 b(16)=0:bd=�(16)
�#� b(16)>255 b(16)=255:bd=-�(16)
�� c(16)<0 c(16)=0:cd=�(16)
�#� c(16)>255 c(16)=255:cd=-�(16)
�� I=1 � 15
�a(I)=a(I+1)
b(I)=b(I+1)
c(I)=c(I+1)
� 16-I,a(I),b(I),c(I)
 �
*�
�
00000000  0d 00 0a 10 f4 20 4d 61  67 69 63 20 54 72 65 65  |..... Magic Tree|
00000010  0d 00 14 20 f4 20 42 79  20 50 68 69 6c 69 70 20  |... . By Philip |
00000020  4d 65 6c 6c 6f 72 20 28  61 67 65 64 20 31 35 29  |Mellor (aged 15)|
00000030  0d 00 1e 1a f4 20 41 63  6f 72 6e 20 55 73 65 72  |..... Acorn User|
00000040  2f 53 74 61 72 20 49 6e  66 6f 0d 00 28 05 3a 0d  |/Star Info..(.:.|
00000050  00 32 08 eb 39 3a 87 0d  00 3c 11 f2 73 65 74 75  |.2..9:...<..setu|
00000060  70 63 6f 6c 6f 75 72 73  0d 00 46 05 3a 0d 00 50  |pcolours..F.:..P|
00000070  0e e3 20 49 3d 31 20 b8  20 31 35 0d 00 5a 22 fb  |.. I=1 . 15..Z".|
00000080  20 49 2c 32 30 30 2d 28  49 2a 31 33 29 2c 36 34  | I,200-(I*13),64|
00000090  2b 28 49 2a 31 33 29 2c  b3 28 33 32 29 0d 00 64  |+(I*13),.(32)..d|
000000a0  05 ed 0d 00 6e 05 f5 0d  00 78 23 e8 22 53 70 72  |....n....x#."Spr|
000000b0  65 61 64 20 28 64 65 67  72 65 65 73 29 20 28 33  |ead (degrees) (3|
000000c0  35 29 3a 22 73 70 72 65  61 64 0d 00 79 18 e7 20  |5):"spread..y.. |
000000d0  73 70 72 65 61 64 3d 30  20 73 70 72 65 61 64 3d  |spread=0 spread=|
000000e0  33 35 0d 00 82 1f e8 22  53 70 6c 69 74 20 28 6e  |35....."Split (n|
000000f0  75 6d 62 65 72 29 20 28  32 29 3a 22 73 70 6c 69  |umber) (2):"spli|
00000100  74 0d 00 83 15 e7 20 73  70 6c 69 74 3d 30 20 73  |t..... split=0 s|
00000110  70 6c 69 74 3d 32 0d 00  84 22 e8 22 48 65 69 67  |plit=2..."."Heig|
00000120  68 74 20 28 75 6e 69 74  73 29 20 28 31 36 30 29  |ht (units) (160)|
00000130  3a 22 68 65 69 67 68 74  0d 00 85 19 e7 20 68 65  |:"height..... he|
00000140  69 67 68 74 3d 30 20 68  65 69 67 68 74 3d 31 36  |ight=0 height=16|
00000150  30 0d 00 96 33 63 79 63  6c 65 25 3d a3 3a e8 22  |0...3cycle%=.:."|
00000160  43 79 63 6c 65 20 63 6f  6c 6f 75 72 73 20 77 68  |Cycle colours wh|
00000170  69 6c 65 20 64 72 61 77  69 6e 67 3f 20 59 2f 4e  |ile drawing? Y/N|
00000180  22 3b 61 24 0d 00 a0 1e  e7 20 61 24 3d 22 59 22  |";a$..... a$="Y"|
00000190  20 84 20 61 24 3d 22 79  22 20 63 79 63 6c 65 25  | . a$="y" cycle%|
000001a0  3d b9 0d 00 aa 05 db 0d  00 b4 23 f2 62 72 61 6e  |=.........#.bran|
000001b0  63 68 28 36 34 30 2c 30  2c 68 65 69 67 68 74 2c  |ch(640,0,height,|
000001c0  a4 72 28 32 29 2c 31 2c  38 29 0d 00 be 05 f5 0d  |.r(2),1,8)......|
000001d0  00 c8 0b c8 97 58 2c 59  2c 5a 0d 00 d2 16 f2 63  |.....X,Y,Z.....c|
000001e0  79 63 6c 65 3a c8 96 3a  c8 96 3a c8 96 3a c8 96  |ycle:..:..:..:..|
000001f0  0d 00 dc 09 fd 5a 3c 3e  30 0d 00 e6 06 fd 30 0d  |.....Z<>0.....0.|
00000200  00 f0 05 e0 0d 00 fa 05  3a 0d 01 04 19 dd f2 62  |........:......b|
00000210  72 61 6e 63 68 28 78 2c  79 2c 7a 2c 61 2c 63 2c  |ranch(x,y,z,a,c,|
00000220  73 29 0d 01 0e 16 e7 20  63 79 63 6c 65 25 20 f2  |s)..... cycle% .|
00000230  63 79 63 6c 65 3a c8 96  0d 01 18 0d ea 20 71 2c  |cycle:....... q,|
00000240  77 2c 49 2c 6c 0d 01 22  0b e7 20 7a 3c 38 20 e1  |w,I,l..".. z<8 .|
00000250  0d 01 2c 0a 6c 3d 7a 2f  31 32 0d 01 36 0f 71 3d  |..,.l=z/12..6.q=|
00000260  78 2b 28 7a 2a b5 b2 61  29 0d 01 40 0f 77 3d 79  |x+(z*..a)..@.w=y|
00000270  2b 28 7a 2a 9b b2 61 29  0d 01 4a 22 e6 20 63 20  |+(z*..a)..J". c |
00000280  c8 9c 20 b3 28 32 35 36  29 2d 31 3a f4 31 2b 28  |.. .(256)-1:.1+(|
00000290  31 35 2f 31 30 32 34 29  2a 79 0d 01 54 0b e7 20  |15/1024)*y..T.. |
000002a0  63 3c 30 20 8c 0d 01 5e  09 ec 20 78 2c 79 0d 01  |c<0 ...^.. x,y..|
000002b0  68 09 df 20 71 2c 77 0d  01 72 05 cc 0d 01 7c 0b  |h.. q,w..r....|.|
000002c0  ec 20 78 2d 6c 2c 79 0d  01 86 0b df 20 71 2d 6c  |. x-l,y..... q-l|
000002d0  2c 77 0d 01 90 0d f0 38  35 2c 71 2b 6c 2c 77 0d  |,w.....85,q+l,w.|
000002e0  01 9a 0a ec 78 2b 6c 2c  79 0d 01 a4 0d f0 38 35  |....x+l,y.....85|
000002f0  2c 78 2d 6c 2c 79 0d 01  ae 05 cd 0d 01 b8 18 e3  |,x-l,y..........|
00000300  20 49 3d 31 20 b8 20 28  28 73 2d 32 29 2b b3 28  | I=1 . ((s-2)+.(|
00000310  32 29 29 0d 01 c2 2d f2  62 72 61 6e 63 68 28 71  |2))...-.branch(q|
00000320  2c 77 2c 7a 2a b3 28 31  29 2c 61 2b a4 72 28 73  |,w,z*.(1),a+.r(s|
00000330  70 72 65 61 64 29 2c 63  2b 31 2c 73 2a 2e 39 29  |pread),c+1,s*.9)|
00000340  0d 01 cc 05 ed 0d 01 d6  05 e1 0d 01 e0 05 3a 0d  |..............:.|
00000350  01 ea 0a dd a4 72 28 61  29 0d 01 f4 1d e7 20 b3  |.....r(a)..... .|
00000360  28 32 29 3d 31 20 8c 20  3d b3 28 61 29 20 8b 20  |(2)=1 . =.(a) . |
00000370  3d 2d b3 28 61 29 0d 01  fe 05 3a 0d 02 08 12 dd  |=-.(a)....:.....|
00000380  f2 73 65 74 75 70 63 6f  6c 6f 75 72 73 0d 02 12  |.setupcolours...|
00000390  17 de 20 61 28 31 36 29  2c 62 28 31 36 29 2c 63  |.. a(16),b(16),c|
000003a0  28 31 36 29 0d 02 1c 0e  e3 20 49 3d 30 20 b8 20  |(16)..... I=0 . |
000003b0  31 36 0d 02 26 21 61 28  49 29 3d 49 2a 31 37 3a  |16..&!a(I)=I*17:|
000003c0  62 28 49 29 3d 49 2a 31  37 3a 63 28 49 29 3d 49  |b(I)=I*17:c(I)=I|
000003d0  2a 31 37 0d 02 30 16 fb  20 49 2c 61 28 49 29 2c  |*17..0.. I,a(I),|
000003e0  62 28 49 29 2c 63 28 49  29 0d 02 3a 05 ed 0d 02  |b(I),c(I)..:....|
000003f0  44 21 e7 20 b3 28 32 29  3d 31 20 61 64 3d b3 28  |D!. .(2)=1 ad=.(|
00000400  31 36 29 20 8b 20 61 64  3d 2d b3 28 31 36 29 0d  |16) . ad=-.(16).|
00000410  02 4e 21 e7 20 b3 28 32  29 3d 31 20 62 64 3d b3  |.N!. .(2)=1 bd=.|
00000420  28 31 36 29 20 8b 20 62  64 3d 2d b3 28 31 36 29  |(16) . bd=-.(16)|
00000430  0d 02 58 21 e7 20 b3 28  32 29 3d 31 20 63 64 3d  |..X!. .(2)=1 cd=|
00000440  b3 28 31 36 29 20 8b 20  63 64 3d 2d b3 28 31 36  |.(16) . cd=-.(16|
00000450  29 0d 02 62 05 e1 0d 02  6c 05 3a 0d 02 76 0b dd  |)..b....l.:..v..|
00000460  f2 63 79 63 6c 65 0d 02  80 07 ea 20 49 0d 02 8a  |.cycle..... I...|
00000470  21 61 28 31 36 29 2b 3d  61 64 3a 62 28 31 36 29  |!a(16)+=ad:b(16)|
00000480  2b 3d 62 64 3a 63 28 31  36 29 2b 3d 63 64 0d 02  |+=bd:c(16)+=cd..|
00000490  94 29 e7 20 b3 28 31 30  29 3d 31 20 61 64 3d b3  |.). .(10)=1 ad=.|
000004a0  28 31 36 29 3a e7 20 b3  28 32 29 3d 31 20 61 64  |(16):. .(2)=1 ad|
000004b0  3d 2d b3 28 31 36 29 0d  02 9e 29 e7 20 b3 28 31  |=-.(16)...). .(1|
000004c0  30 29 3d 31 20 62 64 3d  b3 28 31 36 29 3a e7 20  |0)=1 bd=.(16):. |
000004d0  b3 28 32 29 3d 31 20 62  64 3d 2d b3 28 31 36 29  |.(2)=1 bd=-.(16)|
000004e0  0d 02 a8 29 e7 20 b3 28  31 30 29 3d 31 20 63 64  |...). .(10)=1 cd|
000004f0  3d b3 28 31 36 29 3a e7  20 b3 28 32 29 3d 31 20  |=.(16):. .(2)=1 |
00000500  63 64 3d 2d b3 28 31 36  29 0d 02 b2 1e e7 20 61  |cd=-.(16)..... a|
00000510  28 31 36 29 3c 30 20 61  28 31 36 29 3d 30 3a 61  |(16)<0 a(16)=0:a|
00000520  64 3d b3 28 31 36 29 0d  02 bc 23 e7 20 61 28 31  |d=.(16)...#. a(1|
00000530  36 29 3e 32 35 35 20 61  28 31 36 29 3d 32 35 35  |6)>255 a(16)=255|
00000540  3a 61 64 3d 2d b3 28 31  36 29 0d 02 c6 1e e7 20  |:ad=-.(16)..... |
00000550  62 28 31 36 29 3c 30 20  62 28 31 36 29 3d 30 3a  |b(16)<0 b(16)=0:|
00000560  62 64 3d b3 28 31 36 29  0d 02 d0 23 e7 20 62 28  |bd=.(16)...#. b(|
00000570  31 36 29 3e 32 35 35 20  62 28 31 36 29 3d 32 35  |16)>255 b(16)=25|
00000580  35 3a 62 64 3d 2d b3 28  31 36 29 0d 02 da 1e e7  |5:bd=-.(16).....|
00000590  20 63 28 31 36 29 3c 30  20 63 28 31 36 29 3d 30  | c(16)<0 c(16)=0|
000005a0  3a 63 64 3d b3 28 31 36  29 0d 02 e4 23 e7 20 63  |:cd=.(16)...#. c|
000005b0  28 31 36 29 3e 32 35 35  20 63 28 31 36 29 3d 32  |(16)>255 c(16)=2|
000005c0  35 35 3a 63 64 3d 2d b3  28 31 36 29 0d 02 ee 0e  |55:cd=-.(16)....|
000005d0  e3 20 49 3d 31 20 b8 20  31 35 0d 02 f8 0f 61 28  |. I=1 . 15....a(|
000005e0  49 29 3d 61 28 49 2b 31  29 0d 03 02 0f 62 28 49  |I)=a(I+1)....b(I|
000005f0  29 3d 62 28 49 2b 31 29  0d 03 0c 0f 63 28 49 29  |)=b(I+1)....c(I)|
00000600  3d 63 28 49 2b 31 29 0d  03 16 19 fb 20 31 36 2d  |=c(I+1)..... 16-|
00000610  49 2c 61 28 49 29 2c 62  28 49 29 2c 63 28 49 29  |I,a(I),b(I),c(I)|
00000620  0d 03 20 05 ed 0d 03 2a  05 e1 0d ff              |.. ....*....|
0000062c