Home » Archimedes archive » Acorn User » AU 1998-12.adf » Regulars » StarInfo/Vibe/MANDALA
StarInfo/Vibe/MANDALA
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-12.adf » Regulars |
Filename: | StarInfo/Vibe/MANDALA |
Read OK: | ✔ |
File size: | 05EA bytes |
Load address: | 0000 |
Exec address: | 0000 |
File contents
10REM > MANDALA 20 30MODE21:OFF 40V%=10 50FORI%=660TO60STEP-60:V%=10-V% 60REPEAT:R1%=RND(255):G1%=RND(255):B1%=RND(255):UNTILR1%+G1%+B1%<=63 70REPEAT:R2%=RND(255):G2%=RND(255):B2%=RND(255):UNTILR2%+G2%+B2%>=256 80REPEAT:R3%=RND(255):G3%=RND(255):B3%=RND(255):UNTILR3%+G3%+B3%<=63 90REPEAT:R4%=RND(255):G4%=RND(255):B4%=RND(255):UNTILR4%+G4%+B4%>=256 100FORN%=0TO359STEP20:T1=RAD(N%+V%):T2=RAD(N%+20+V%) 110X1%=I%*SINT1+640:Y1%=I%*COST1+512 120X2%=I%*SINT2+640:Y2%=I%*COST2+512 130PROCFLARE(X1%,Y1%,X2%,Y2%,2.8,R1%,G1%,B1%,R2%,G2%,B2%) 140PROCFLARE(X2%,Y2%,X1%,Y1%,2.8,R3%,G3%,B3%,R4%,G4%,B4%) 150SWAP R1%,R3%:SWAP G1%,G3%:SWAP B1%,B3% 160SWAP R2%,R4%:SWAP G2%,G4%:SWAP B2%,B4% 170NEXT, 180END 190 200DEFPROCFLARE(X1%,Y1%,X2%,Y2%,Z,R1%,G1%,B1%,R2%,B2%,G2%) 210LOCAL XE,YE,D,SI,XC%,YC%,XA%,YA%,N%,TX1,TX2,TY1,TY2,R,G,B 220XC%=(X1%+X2%)/2:YC%=(Y1%+Y2%)/2 230XE=X2%-X1%:YE=Y2%-Y1%:D=SQR(XE^2+YE^2):XE=XE/D:YE=YE/D:SI=DEGASN(XE) 240IF YE<=0 SI=180-SI ELSE SI=360+SI 250IF SI>360 SI=SI-360 260D=D*Z:XA%=XC%+D*SINRAD(SI+270):YA%=YC%+D*COSRAD(SI+270) 270TX1=X1%:TY1=Y1% 280FORN%=1TO32 290R=((32-N%)*R1%+N%*R2%)/32:G=((32-N%)*G1%+N%*G2%)/32 300B=((32-N%)*B1%+N%*B2%)/32:PROCRGB(R,G,B) 310TX2=TX1:TY2=TY1 320TX1=((32-N%)*X1%+N%*XA%)/32 330TY1=((32-N%)*Y1%+N%*YA%)/32 340MOVETX1,TY1:MOVETX2,TY2:PLOT85,XC%,YC% 350NEXT 360TX1=X2%:TY1=Y2% 370FORN%=1TO32 380R=((32-N%)*R1%+N%*R2%)/32:G=((32-N%)*G1%+N%*G2%)/32 390B=((32-N%)*B1%+N%*B2%)/32:PROCRGB(R,G,B) 400TX2=TX1:TY2=TY1 410TX1=((32-N%)*X2%+N%*XA%)/32 420TY1=((32-N%)*Y2%+N%*YA%)/32 430MOVETX1,TY1:MOVETX2,TY2:PLOT85,XC%,YC% 440NEXT 450ENDPROC 460 470DEFPROCRGB(R%,G%,B%) 480LOCAL C%:C%=(R%<<8)+(G%<<16)+(B%<<24) 490SYS "ColourTrans_SetGCOL",C%,,,&100,0 500ENDPROC
� > MANDALA �21:� ( V%=10 2�I%=660�60�-60:V%=10-V% <7�:R1%=�(255):G1%=�(255):B1%=�(255):�R1%+G1%+B1%<=63 F8�:R2%=�(255):G2%=�(255):B2%=�(255):�R2%+G2%+B2%>=256 P7�:R3%=�(255):G3%=�(255):B3%=�(255):�R3%+G3%+B3%<=63 Z8�:R4%=�(255):G4%=�(255):B4%=�(255):�R4%+G4%+B4%>=256 d+�N%=0�359�20:T1=�(N%+V%):T2=�(N%+20+V%) n!X1%=I%*�T1+640:Y1%=I%*�T1+512 x!X2%=I%*�T2+640:Y2%=I%*�T2+512 �7�FLARE(X1%,Y1%,X2%,Y2%,2.8,R1%,G1%,B1%,R2%,G2%,B2%) �7�FLARE(X2%,Y2%,X1%,Y1%,2.8,R3%,G3%,B3%,R4%,G4%,B4%) �$Ȕ R1%,R3%:Ȕ G1%,G3%:Ȕ B1%,B3% �$Ȕ R2%,R4%:Ȕ G2%,G4%:Ȕ B2%,B4% ��, �� � �6��FLARE(X1%,Y1%,X2%,Y2%,Z,R1%,G1%,B1%,R2%,B2%,G2%) �9� XE,YE,D,SI,XC%,YC%,XA%,YA%,N%,TX1,TX2,TY1,TY2,R,G,B �#XC%=(X1%+X2%)/2:YC%=(Y1%+Y2%)/2 �BXE=X2%-X1%:YE=Y2%-Y1%:D=�(XE^2+YE^2):XE=XE/D:YE=YE/D:SI=��(XE) �!� YE<=0 SI=180-SI � SI=360+SI �� SI>360 SI=SI-360 3D=D*Z:XA%=XC%+D*��(SI+270):YA%=YC%+D*��(SI+270) TX1=X1%:TY1=Y1% �N%=1�32 "7R=((32-N%)*R1%+N%*R2%)/32:G=((32-N%)*G1%+N%*G2%)/32 ,)B=((32-N%)*B1%+N%*B2%)/32:�RGB(R,G,B) 6TX2=TX1:TY2=TY1 @TX1=((32-N%)*X1%+N%*XA%)/32 JTY1=((32-N%)*Y1%+N%*YA%)/32 T!�TX1,TY1:�TX2,TY2:�85,XC%,YC% ^� hTX1=X2%:TY1=Y2% r�N%=1�32 |7R=((32-N%)*R1%+N%*R2%)/32:G=((32-N%)*G1%+N%*G2%)/32 �)B=((32-N%)*B1%+N%*B2%)/32:�RGB(R,G,B) �TX2=TX1:TY2=TY1 �TX1=((32-N%)*X2%+N%*XA%)/32 �TY1=((32-N%)*Y2%+N%*YA%)/32 �!�TX1,TY1:�TX2,TY2:�85,XC%,YC% �� �� � ���RGB(R%,G%,B%) �%� C%:C%=(R%<<8)+(G%<<16)+(B%<<24) �(ș "ColourTrans_SetGCOL",C%,,,&100,0 �� �
00000000 0d 00 0a 0f f4 20 3e 20 4d 41 4e 44 41 4c 41 0d |..... > MANDALA.| 00000010 00 14 04 0d 00 1e 09 eb 32 31 3a 87 0d 00 28 09 |........21:...(.| 00000020 56 25 3d 31 30 0d 00 32 1b e3 49 25 3d 36 36 30 |V%=10..2..I%=660| 00000030 b8 36 30 88 2d 36 30 3a 56 25 3d 31 30 2d 56 25 |.60.-60:V%=10-V%| 00000040 0d 00 3c 37 f5 3a 52 31 25 3d b3 28 32 35 35 29 |..<7.:R1%=.(255)| 00000050 3a 47 31 25 3d b3 28 32 35 35 29 3a 42 31 25 3d |:G1%=.(255):B1%=| 00000060 b3 28 32 35 35 29 3a fd 52 31 25 2b 47 31 25 2b |.(255):.R1%+G1%+| 00000070 42 31 25 3c 3d 36 33 0d 00 46 38 f5 3a 52 32 25 |B1%<=63..F8.:R2%| 00000080 3d b3 28 32 35 35 29 3a 47 32 25 3d b3 28 32 35 |=.(255):G2%=.(25| 00000090 35 29 3a 42 32 25 3d b3 28 32 35 35 29 3a fd 52 |5):B2%=.(255):.R| 000000a0 32 25 2b 47 32 25 2b 42 32 25 3e 3d 32 35 36 0d |2%+G2%+B2%>=256.| 000000b0 00 50 37 f5 3a 52 33 25 3d b3 28 32 35 35 29 3a |.P7.:R3%=.(255):| 000000c0 47 33 25 3d b3 28 32 35 35 29 3a 42 33 25 3d b3 |G3%=.(255):B3%=.| 000000d0 28 32 35 35 29 3a fd 52 33 25 2b 47 33 25 2b 42 |(255):.R3%+G3%+B| 000000e0 33 25 3c 3d 36 33 0d 00 5a 38 f5 3a 52 34 25 3d |3%<=63..Z8.:R4%=| 000000f0 b3 28 32 35 35 29 3a 47 34 25 3d b3 28 32 35 35 |.(255):G4%=.(255| 00000100 29 3a 42 34 25 3d b3 28 32 35 35 29 3a fd 52 34 |):B4%=.(255):.R4| 00000110 25 2b 47 34 25 2b 42 34 25 3e 3d 32 35 36 0d 00 |%+G4%+B4%>=256..| 00000120 64 2b e3 4e 25 3d 30 b8 33 35 39 88 32 30 3a 54 |d+.N%=0.359.20:T| 00000130 31 3d b2 28 4e 25 2b 56 25 29 3a 54 32 3d b2 28 |1=.(N%+V%):T2=.(| 00000140 4e 25 2b 32 30 2b 56 25 29 0d 00 6e 21 58 31 25 |N%+20+V%)..n!X1%| 00000150 3d 49 25 2a b5 54 31 2b 36 34 30 3a 59 31 25 3d |=I%*.T1+640:Y1%=| 00000160 49 25 2a 9b 54 31 2b 35 31 32 0d 00 78 21 58 32 |I%*.T1+512..x!X2| 00000170 25 3d 49 25 2a b5 54 32 2b 36 34 30 3a 59 32 25 |%=I%*.T2+640:Y2%| 00000180 3d 49 25 2a 9b 54 32 2b 35 31 32 0d 00 82 37 f2 |=I%*.T2+512...7.| 00000190 46 4c 41 52 45 28 58 31 25 2c 59 31 25 2c 58 32 |FLARE(X1%,Y1%,X2| 000001a0 25 2c 59 32 25 2c 32 2e 38 2c 52 31 25 2c 47 31 |%,Y2%,2.8,R1%,G1| 000001b0 25 2c 42 31 25 2c 52 32 25 2c 47 32 25 2c 42 32 |%,B1%,R2%,G2%,B2| 000001c0 25 29 0d 00 8c 37 f2 46 4c 41 52 45 28 58 32 25 |%)...7.FLARE(X2%| 000001d0 2c 59 32 25 2c 58 31 25 2c 59 31 25 2c 32 2e 38 |,Y2%,X1%,Y1%,2.8| 000001e0 2c 52 33 25 2c 47 33 25 2c 42 33 25 2c 52 34 25 |,R3%,G3%,B3%,R4%| 000001f0 2c 47 34 25 2c 42 34 25 29 0d 00 96 24 c8 94 20 |,G4%,B4%)...$.. | 00000200 52 31 25 2c 52 33 25 3a c8 94 20 47 31 25 2c 47 |R1%,R3%:.. G1%,G| 00000210 33 25 3a c8 94 20 42 31 25 2c 42 33 25 0d 00 a0 |3%:.. B1%,B3%...| 00000220 24 c8 94 20 52 32 25 2c 52 34 25 3a c8 94 20 47 |$.. R2%,R4%:.. G| 00000230 32 25 2c 47 34 25 3a c8 94 20 42 32 25 2c 42 34 |2%,G4%:.. B2%,B4| 00000240 25 0d 00 aa 06 ed 2c 0d 00 b4 05 e0 0d 00 be 04 |%.....,.........| 00000250 0d 00 c8 36 dd f2 46 4c 41 52 45 28 58 31 25 2c |...6..FLARE(X1%,| 00000260 59 31 25 2c 58 32 25 2c 59 32 25 2c 5a 2c 52 31 |Y1%,X2%,Y2%,Z,R1| 00000270 25 2c 47 31 25 2c 42 31 25 2c 52 32 25 2c 42 32 |%,G1%,B1%,R2%,B2| 00000280 25 2c 47 32 25 29 0d 00 d2 39 ea 20 58 45 2c 59 |%,G2%)...9. XE,Y| 00000290 45 2c 44 2c 53 49 2c 58 43 25 2c 59 43 25 2c 58 |E,D,SI,XC%,YC%,X| 000002a0 41 25 2c 59 41 25 2c 4e 25 2c 54 58 31 2c 54 58 |A%,YA%,N%,TX1,TX| 000002b0 32 2c 54 59 31 2c 54 59 32 2c 52 2c 47 2c 42 0d |2,TY1,TY2,R,G,B.| 000002c0 00 dc 23 58 43 25 3d 28 58 31 25 2b 58 32 25 29 |..#XC%=(X1%+X2%)| 000002d0 2f 32 3a 59 43 25 3d 28 59 31 25 2b 59 32 25 29 |/2:YC%=(Y1%+Y2%)| 000002e0 2f 32 0d 00 e6 42 58 45 3d 58 32 25 2d 58 31 25 |/2...BXE=X2%-X1%| 000002f0 3a 59 45 3d 59 32 25 2d 59 31 25 3a 44 3d b6 28 |:YE=Y2%-Y1%:D=.(| 00000300 58 45 5e 32 2b 59 45 5e 32 29 3a 58 45 3d 58 45 |XE^2+YE^2):XE=XE| 00000310 2f 44 3a 59 45 3d 59 45 2f 44 3a 53 49 3d 9d 98 |/D:YE=YE/D:SI=..| 00000320 28 58 45 29 0d 00 f0 21 e7 20 59 45 3c 3d 30 20 |(XE)...!. YE<=0 | 00000330 53 49 3d 31 38 30 2d 53 49 20 8b 20 53 49 3d 33 |SI=180-SI . SI=3| 00000340 36 30 2b 53 49 0d 00 fa 16 e7 20 53 49 3e 33 36 |60+SI..... SI>36| 00000350 30 20 53 49 3d 53 49 2d 33 36 30 0d 01 04 33 44 |0 SI=SI-360...3D| 00000360 3d 44 2a 5a 3a 58 41 25 3d 58 43 25 2b 44 2a b5 |=D*Z:XA%=XC%+D*.| 00000370 b2 28 53 49 2b 32 37 30 29 3a 59 41 25 3d 59 43 |.(SI+270):YA%=YC| 00000380 25 2b 44 2a 9b b2 28 53 49 2b 32 37 30 29 0d 01 |%+D*..(SI+270)..| 00000390 0e 13 54 58 31 3d 58 31 25 3a 54 59 31 3d 59 31 |..TX1=X1%:TY1=Y1| 000003a0 25 0d 01 18 0c e3 4e 25 3d 31 b8 33 32 0d 01 22 |%.....N%=1.32.."| 000003b0 37 52 3d 28 28 33 32 2d 4e 25 29 2a 52 31 25 2b |7R=((32-N%)*R1%+| 000003c0 4e 25 2a 52 32 25 29 2f 33 32 3a 47 3d 28 28 33 |N%*R2%)/32:G=((3| 000003d0 32 2d 4e 25 29 2a 47 31 25 2b 4e 25 2a 47 32 25 |2-N%)*G1%+N%*G2%| 000003e0 29 2f 33 32 0d 01 2c 29 42 3d 28 28 33 32 2d 4e |)/32..,)B=((32-N| 000003f0 25 29 2a 42 31 25 2b 4e 25 2a 42 32 25 29 2f 33 |%)*B1%+N%*B2%)/3| 00000400 32 3a f2 52 47 42 28 52 2c 47 2c 42 29 0d 01 36 |2:.RGB(R,G,B)..6| 00000410 13 54 58 32 3d 54 58 31 3a 54 59 32 3d 54 59 31 |.TX2=TX1:TY2=TY1| 00000420 0d 01 40 1f 54 58 31 3d 28 28 33 32 2d 4e 25 29 |..@.TX1=((32-N%)| 00000430 2a 58 31 25 2b 4e 25 2a 58 41 25 29 2f 33 32 0d |*X1%+N%*XA%)/32.| 00000440 01 4a 1f 54 59 31 3d 28 28 33 32 2d 4e 25 29 2a |.J.TY1=((32-N%)*| 00000450 59 31 25 2b 4e 25 2a 59 41 25 29 2f 33 32 0d 01 |Y1%+N%*YA%)/32..| 00000460 54 21 ec 54 58 31 2c 54 59 31 3a ec 54 58 32 2c |T!.TX1,TY1:.TX2,| 00000470 54 59 32 3a f0 38 35 2c 58 43 25 2c 59 43 25 0d |TY2:.85,XC%,YC%.| 00000480 01 5e 05 ed 0d 01 68 13 54 58 31 3d 58 32 25 3a |.^....h.TX1=X2%:| 00000490 54 59 31 3d 59 32 25 0d 01 72 0c e3 4e 25 3d 31 |TY1=Y2%..r..N%=1| 000004a0 b8 33 32 0d 01 7c 37 52 3d 28 28 33 32 2d 4e 25 |.32..|7R=((32-N%| 000004b0 29 2a 52 31 25 2b 4e 25 2a 52 32 25 29 2f 33 32 |)*R1%+N%*R2%)/32| 000004c0 3a 47 3d 28 28 33 32 2d 4e 25 29 2a 47 31 25 2b |:G=((32-N%)*G1%+| 000004d0 4e 25 2a 47 32 25 29 2f 33 32 0d 01 86 29 42 3d |N%*G2%)/32...)B=| 000004e0 28 28 33 32 2d 4e 25 29 2a 42 31 25 2b 4e 25 2a |((32-N%)*B1%+N%*| 000004f0 42 32 25 29 2f 33 32 3a f2 52 47 42 28 52 2c 47 |B2%)/32:.RGB(R,G| 00000500 2c 42 29 0d 01 90 13 54 58 32 3d 54 58 31 3a 54 |,B)....TX2=TX1:T| 00000510 59 32 3d 54 59 31 0d 01 9a 1f 54 58 31 3d 28 28 |Y2=TY1....TX1=((| 00000520 33 32 2d 4e 25 29 2a 58 32 25 2b 4e 25 2a 58 41 |32-N%)*X2%+N%*XA| 00000530 25 29 2f 33 32 0d 01 a4 1f 54 59 31 3d 28 28 33 |%)/32....TY1=((3| 00000540 32 2d 4e 25 29 2a 59 32 25 2b 4e 25 2a 59 41 25 |2-N%)*Y2%+N%*YA%| 00000550 29 2f 33 32 0d 01 ae 21 ec 54 58 31 2c 54 59 31 |)/32...!.TX1,TY1| 00000560 3a ec 54 58 32 2c 54 59 32 3a f0 38 35 2c 58 43 |:.TX2,TY2:.85,XC| 00000570 25 2c 59 43 25 0d 01 b8 05 ed 0d 01 c2 05 e1 0d |%,YC%...........| 00000580 01 cc 04 0d 01 d6 13 dd f2 52 47 42 28 52 25 2c |.........RGB(R%,| 00000590 47 25 2c 42 25 29 0d 01 e0 25 ea 20 43 25 3a 43 |G%,B%)...%. C%:C| 000005a0 25 3d 28 52 25 3c 3c 38 29 2b 28 47 25 3c 3c 31 |%=(R%<<8)+(G%<<1| 000005b0 36 29 2b 28 42 25 3c 3c 32 34 29 0d 01 ea 28 c8 |6)+(B%<<24)...(.| 000005c0 99 20 22 43 6f 6c 6f 75 72 54 72 61 6e 73 5f 53 |. "ColourTrans_S| 000005d0 65 74 47 43 4f 4c 22 2c 43 25 2c 2c 2c 26 31 30 |etGCOL",C%,,,&10| 000005e0 30 2c 30 0d 01 f4 05 e1 0d ff |0,0.......| 000005ea