Home » Archimedes archive » Acorn User » AU 1998-04 A.adf » Regulars » StarInfo/Boham/!Cradle/Balls
StarInfo/Boham/!Cradle/Balls
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 1998-04 A.adf » Regulars |
Filename: | StarInfo/Boham/!Cradle/Balls |
Read OK: | ✔ |
File size: | 056C bytes |
Load address: | 0000 |
Exec address: | 0000 |
File contents
1DIM ba(5),bv(5) 2REM the next five lines set the starting angle of all the marbles 3ba(1)=-45 4ba(2)=0 5ba(3)=0 6ba(4)=0 7ba(5)=0 8REM 0 is vertically downwards and -90 is 90POINT( clockwise 9 10ON ERROR: ON ERROR OFF: MODE 25:PRINT REPORT$;" at line ";ERL:END 11MODE 26 12MODE 25:OFF 13bv()=0 14VOICES 4 15VOICE 1,"Click" 16VOICE 2,"Click" 17VOICE 3,"Click" 18VOICE 4,"Click" 19S1=1 20S2=2 21f%=0 22force%=0 23v%=1 24disp%=4 25radius%=46 26REPEAT 27IF (f% MOD disp%)= 0 THEN WAIT:SYS 6,112,S1:SYS 6,113,S2:CLS:SWAP S1,S2 28 29FOR n%=1 TO 5 30accel = -SINRADba(n%)*0.1 31bv(n%)=(bv(n%)+accel)*0.998 32ba(n%)=ba(n%)+bv(n%) 33hit%=FALSE 34 35IF n%<5 THEN 36dx = SINRADba(n%)*500 - SINRADba(n%+1)*500 -100 37dy = COSRADba(n%)*500 - COSRADba(n%+1)*500 38d = SQR(dx*dx+dy*dy) 39IF d<radius%*2 THEN 40ba(n%)=ba(n%)-bv(n%) 41bv(n%)=bv(n%)-accel 42SWAP bv(n%),bv(n%+1) 43hit%=TRUE 44force%=ABS(bv(n%)-bv(n%+1))*25 45ENDIF 46ENDIF 47 48IF n%>1 AND NOT(hit%) THEN 49dx = SINRADba(n%-1)*500 - SINRADba(n%)*500 -100 50dy = COSRADba(n%-1)*500 - COSRADba(n%)*500 51d = SQR(dx*dx+dy*dy) 52IF d<radius%*2 THEN 53ba(n%)=ba(n%)-bv(n%) 54bv(n%)=bv(n%)-accel 55SWAP bv(n%),bv(n%-1) 56hit%=TRUE 57force%=ABS(bv(n%)-bv(n%-1))*25 58ENDIF 59ENDIF 60 61IF force%>15 THEN force%=15 62IF hit% THEN SOUND v%,-force%,&4500,1:v% = v%+1 63IF v%>4 THEN v%=1 64 65IF (f% MOD disp%)=0 THEN 66MOVE n%*100+300,800 67x%=SINRADba(n%)*500 68y%=COSRADba(n%)*500 69DRAW n%*100+300+x%,800-y% 70CIRCLE n%*100+300+x%,800-y%,radius% 71ENDIF 72NEXT n% 73 74f%=f%+1 75UNTIL FALSE
� ba(5),bv(5) C� the next five lines set the starting angle of all the marbles ba(1)=-45 ba(2)=0 ba(3)=0 ba(4)=0 ba(5)=0 8� 0 is vertically downwards and -90 is 90� clockwise )� �: � � �: � 25:� �$;" at line ";�:� � 26 � 25:� bv()=0 Ƞ 4 ȡ 1,"Click" ȡ 2,"Click" ȡ 3,"Click" ȡ 4,"Click" S1=1 S2=2 f%=0 force%=0 v%=1 disp%=4 radius%=46 � =� (f% � disp%)= 0 � Ȗ:ș 6,112,S1:ș 6,113,S2:�:Ȕ S1,S2 � n%=1 � 5 accel = -��ba(n%)*0.1 bv(n%)=(bv(n%)+accel)*0.998 ba(n%)=ba(n%)+bv(n%) ! hit%=� " #� n%<5 � $+dx = ��ba(n%)*500 - ��ba(n%+1)*500 -100 %&dy = ��ba(n%)*500 - ��ba(n%+1)*500 &d = �(dx*dx+dy*dy) '� d<radius%*2 � (ba(n%)=ba(n%)-bv(n%) )bv(n%)=bv(n%)-accel *Ȕ bv(n%),bv(n%+1) + hit%=� , force%=�(bv(n%)-bv(n%+1))*25 -� .� / 0� n%>1 � �(hit%) � 1+dx = ��ba(n%-1)*500 - ��ba(n%)*500 -100 2&dy = ��ba(n%-1)*500 - ��ba(n%)*500 3d = �(dx*dx+dy*dy) 4� d<radius%*2 � 5ba(n%)=ba(n%)-bv(n%) 6bv(n%)=bv(n%)-accel 7Ȕ bv(n%),bv(n%-1) 8 hit%=� 9 force%=�(bv(n%)-bv(n%-1))*25 :� ;� < =� force%>15 � force%=15 >+� hit% � � v%,-force%,&4500,1:v% = v%+1 ?� v%>4 � v%=1 @ A� (f% � disp%)=0 � B� n%*100+300,800 Cx%=��ba(n%)*500 Dy%=��ba(n%)*500 E� n%*100+300+x%,800-y% F#ȏ n%*100+300+x%,800-y%,radius% G� H� n% I Jf%=f%+1 K� � �
00000000 0d 00 01 11 de 20 62 61 28 35 29 2c 62 76 28 35 |..... ba(5),bv(5| 00000010 29 0d 00 02 43 f4 20 74 68 65 20 6e 65 78 74 20 |)...C. the next | 00000020 66 69 76 65 20 6c 69 6e 65 73 20 73 65 74 20 74 |five lines set t| 00000030 68 65 20 73 74 61 72 74 69 6e 67 20 61 6e 67 6c |he starting angl| 00000040 65 20 6f 66 20 61 6c 6c 20 74 68 65 20 6d 61 72 |e of all the mar| 00000050 62 6c 65 73 0d 00 03 0d 62 61 28 31 29 3d 2d 34 |bles....ba(1)=-4| 00000060 35 0d 00 04 0b 62 61 28 32 29 3d 30 0d 00 05 0b |5....ba(2)=0....| 00000070 62 61 28 33 29 3d 30 0d 00 06 0b 62 61 28 34 29 |ba(3)=0....ba(4)| 00000080 3d 30 0d 00 07 0b 62 61 28 35 29 3d 30 0d 00 08 |=0....ba(5)=0...| 00000090 38 f4 20 30 20 69 73 20 76 65 72 74 69 63 61 6c |8. 0 is vertical| 000000a0 6c 79 20 64 6f 77 6e 77 61 72 64 73 20 61 6e 64 |ly downwards and| 000000b0 20 2d 39 30 20 69 73 20 39 30 b0 20 63 6c 6f 63 | -90 is 90. cloc| 000000c0 6b 77 69 73 65 0d 00 09 04 0d 00 0a 29 ee 20 85 |kwise.......). .| 000000d0 3a 20 ee 20 85 20 87 3a 20 eb 20 32 35 3a f1 20 |: . . .: . 25:. | 000000e0 f6 24 3b 22 20 61 74 20 6c 69 6e 65 20 22 3b 9e |.$;" at line ";.| 000000f0 3a e0 0d 00 0b 08 eb 20 32 36 0d 00 0c 0a eb 20 |:...... 26..... | 00000100 32 35 3a 87 0d 00 0d 0a 62 76 28 29 3d 30 0d 00 |25:.....bv()=0..| 00000110 0e 08 c8 a0 20 34 0d 00 0f 10 c8 a1 20 31 2c 22 |.... 4...... 1,"| 00000120 43 6c 69 63 6b 22 0d 00 10 10 c8 a1 20 32 2c 22 |Click"...... 2,"| 00000130 43 6c 69 63 6b 22 0d 00 11 10 c8 a1 20 33 2c 22 |Click"...... 3,"| 00000140 43 6c 69 63 6b 22 0d 00 12 10 c8 a1 20 34 2c 22 |Click"...... 4,"| 00000150 43 6c 69 63 6b 22 0d 00 13 08 53 31 3d 31 0d 00 |Click"....S1=1..| 00000160 14 08 53 32 3d 32 0d 00 15 08 66 25 3d 30 0d 00 |..S2=2....f%=0..| 00000170 16 0c 66 6f 72 63 65 25 3d 30 0d 00 17 08 76 25 |..force%=0....v%| 00000180 3d 31 0d 00 18 0d 64 69 73 70 25 3d 34 20 20 0d |=1....disp%=4 .| 00000190 00 19 0e 72 61 64 69 75 73 25 3d 34 36 0d 00 1a |...radius%=46...| 000001a0 05 f5 0d 00 1b 3d e7 20 28 66 25 20 83 20 64 69 |.....=. (f% . di| 000001b0 73 70 25 29 3d 20 30 20 8c 20 c8 96 3a c8 99 20 |sp%)= 0 . ..:.. | 000001c0 36 2c 31 31 32 2c 53 31 3a c8 99 20 36 2c 31 31 |6,112,S1:.. 6,11| 000001d0 33 2c 53 32 3a db 3a c8 94 20 53 31 2c 53 32 0d |3,S2:.:.. S1,S2.| 000001e0 00 1c 04 0d 00 1d 0e e3 20 6e 25 3d 31 20 b8 20 |........ n%=1 . | 000001f0 35 0d 00 1e 19 61 63 63 65 6c 20 3d 20 2d b5 b2 |5....accel = -..| 00000200 62 61 28 6e 25 29 2a 30 2e 31 0d 00 1f 1f 62 76 |ba(n%)*0.1....bv| 00000210 28 6e 25 29 3d 28 62 76 28 6e 25 29 2b 61 63 63 |(n%)=(bv(n%)+acc| 00000220 65 6c 29 2a 30 2e 39 39 38 0d 00 20 18 62 61 28 |el)*0.998.. .ba(| 00000230 6e 25 29 3d 62 61 28 6e 25 29 2b 62 76 28 6e 25 |n%)=ba(n%)+bv(n%| 00000240 29 0d 00 21 0a 68 69 74 25 3d a3 0d 00 22 04 0d |)..!.hit%=..."..| 00000250 00 23 0c e7 20 6e 25 3c 35 20 8c 0d 00 24 2b 64 |.#.. n%<5 ...$+d| 00000260 78 20 3d 20 b5 b2 62 61 28 6e 25 29 2a 35 30 30 |x = ..ba(n%)*500| 00000270 20 2d 20 b5 b2 62 61 28 6e 25 2b 31 29 2a 35 30 | - ..ba(n%+1)*50| 00000280 30 20 2d 31 30 30 0d 00 25 26 64 79 20 3d 20 9b |0 -100..%&dy = .| 00000290 b2 62 61 28 6e 25 29 2a 35 30 30 20 2d 20 9b b2 |.ba(n%)*500 - ..| 000002a0 62 61 28 6e 25 2b 31 29 2a 35 30 30 0d 00 26 16 |ba(n%+1)*500..&.| 000002b0 64 20 3d 20 b6 28 64 78 2a 64 78 2b 64 79 2a 64 |d = .(dx*dx+dy*d| 000002c0 79 29 0d 00 27 13 e7 20 64 3c 72 61 64 69 75 73 |y)..'.. d<radius| 000002d0 25 2a 32 20 8c 0d 00 28 18 62 61 28 6e 25 29 3d |%*2 ...(.ba(n%)=| 000002e0 62 61 28 6e 25 29 2d 62 76 28 6e 25 29 0d 00 29 |ba(n%)-bv(n%)..)| 000002f0 17 62 76 28 6e 25 29 3d 62 76 28 6e 25 29 2d 61 |.bv(n%)=bv(n%)-a| 00000300 63 63 65 6c 0d 00 2a 16 c8 94 20 62 76 28 6e 25 |ccel..*... bv(n%| 00000310 29 2c 62 76 28 6e 25 2b 31 29 0d 00 2b 0a 68 69 |),bv(n%+1)..+.hi| 00000320 74 25 3d b9 0d 00 2c 20 66 6f 72 63 65 25 3d 94 |t%=..., force%=.| 00000330 28 62 76 28 6e 25 29 2d 62 76 28 6e 25 2b 31 29 |(bv(n%)-bv(n%+1)| 00000340 29 2a 32 35 0d 00 2d 05 cd 0d 00 2e 05 cd 0d 00 |)*25..-.........| 00000350 2f 04 0d 00 30 16 e7 20 6e 25 3e 31 20 80 20 ac |/...0.. n%>1 . .| 00000360 28 68 69 74 25 29 20 8c 0d 00 31 2b 64 78 20 3d |(hit%) ...1+dx =| 00000370 20 b5 b2 62 61 28 6e 25 2d 31 29 2a 35 30 30 20 | ..ba(n%-1)*500 | 00000380 2d 20 b5 b2 62 61 28 6e 25 29 2a 35 30 30 20 2d |- ..ba(n%)*500 -| 00000390 31 30 30 0d 00 32 26 64 79 20 3d 20 9b b2 62 61 |100..2&dy = ..ba| 000003a0 28 6e 25 2d 31 29 2a 35 30 30 20 2d 20 9b b2 62 |(n%-1)*500 - ..b| 000003b0 61 28 6e 25 29 2a 35 30 30 0d 00 33 16 64 20 3d |a(n%)*500..3.d =| 000003c0 20 b6 28 64 78 2a 64 78 2b 64 79 2a 64 79 29 0d | .(dx*dx+dy*dy).| 000003d0 00 34 13 e7 20 64 3c 72 61 64 69 75 73 25 2a 32 |.4.. d<radius%*2| 000003e0 20 8c 0d 00 35 18 62 61 28 6e 25 29 3d 62 61 28 | ...5.ba(n%)=ba(| 000003f0 6e 25 29 2d 62 76 28 6e 25 29 0d 00 36 17 62 76 |n%)-bv(n%)..6.bv| 00000400 28 6e 25 29 3d 62 76 28 6e 25 29 2d 61 63 63 65 |(n%)=bv(n%)-acce| 00000410 6c 0d 00 37 16 c8 94 20 62 76 28 6e 25 29 2c 62 |l..7... bv(n%),b| 00000420 76 28 6e 25 2d 31 29 0d 00 38 0a 68 69 74 25 3d |v(n%-1)..8.hit%=| 00000430 b9 0d 00 39 20 66 6f 72 63 65 25 3d 94 28 62 76 |...9 force%=.(bv| 00000440 28 6e 25 29 2d 62 76 28 6e 25 2d 31 29 29 2a 32 |(n%)-bv(n%-1))*2| 00000450 35 0d 00 3a 05 cd 0d 00 3b 05 cd 0d 00 3c 04 0d |5..:....;....<..| 00000460 00 3d 1b e7 20 66 6f 72 63 65 25 3e 31 35 20 8c |.=.. force%>15 .| 00000470 20 66 6f 72 63 65 25 3d 31 35 0d 00 3e 2b e7 20 | force%=15..>+. | 00000480 68 69 74 25 20 8c 20 d4 20 76 25 2c 2d 66 6f 72 |hit% . . v%,-for| 00000490 63 65 25 2c 26 34 35 30 30 2c 31 3a 76 25 20 3d |ce%,&4500,1:v% =| 000004a0 20 76 25 2b 31 0d 00 3f 11 e7 20 76 25 3e 34 20 | v%+1..?.. v%>4 | 000004b0 8c 20 76 25 3d 31 0d 00 40 04 0d 00 41 16 e7 20 |. v%=1..@...A.. | 000004c0 28 66 25 20 83 20 64 69 73 70 25 29 3d 30 20 8c |(f% . disp%)=0 .| 000004d0 0d 00 42 14 ec 20 6e 25 2a 31 30 30 2b 33 30 30 |..B.. n%*100+300| 000004e0 2c 38 30 30 0d 00 43 13 78 25 3d b5 b2 62 61 28 |,800..C.x%=..ba(| 000004f0 6e 25 29 2a 35 30 30 0d 00 44 13 79 25 3d 9b b2 |n%)*500..D.y%=..| 00000500 62 61 28 6e 25 29 2a 35 30 30 0d 00 45 1a df 20 |ba(n%)*500..E.. | 00000510 6e 25 2a 31 30 30 2b 33 30 30 2b 78 25 2c 38 30 |n%*100+300+x%,80| 00000520 30 2d 79 25 0d 00 46 23 c8 8f 20 6e 25 2a 31 30 |0-y%..F#.. n%*10| 00000530 30 2b 33 30 30 2b 78 25 2c 38 30 30 2d 79 25 2c |0+300+x%,800-y%,| 00000540 72 61 64 69 75 73 25 0d 00 47 05 cd 0d 00 48 08 |radius%..G....H.| 00000550 ed 20 6e 25 0d 00 49 04 0d 00 4a 0b 66 25 3d 66 |. n%..I...J.f%=f| 00000560 25 2b 31 0d 00 4b 07 fd 20 a3 0d ff |%+1..K.. ...| 0000056c