Home » Archimedes archive » Acorn User » AU 1997-06 B.adf » Regulars » StarInfo/Bolt/MouseP

StarInfo/Bolt/MouseP

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-06 B.adf » Regulars
Filename: StarInfo/Bolt/MouseP
Read OK:
File size: 0C9C bytes
Load address: 0000
Exec address: 0000
File contents
   10MODE27+128
   20OFF
   30COLOUR 0, 127,29,223
   40COLOUR 5, 0,0,0
   50COLOUR 8, 0,0,255
   60COLOUR 7, 255,255,255
   70REM x,y,z - 3d coords
   80REM u,v - screen coords
   90
  100DIM rad(6), dx(6), dy(6), dz(6)
  110
  120rad(1) = 0
  130rad(2) = 18
  140rad(3) = 8
  150rad(4) = 8
  160rad(5) = 0
  170rad(6) = 0
  180
  190x3mulu = 1: x3mulv = 0
  200y3mulu = 0: y3mulv = 1
  210z3mulu = 0: z3mulv = 1
  220l3mulu = .2: l3mulv = 0
  230
  240mhgt = 16
  250dz(1) = mhgt
  260dz(2) = mhgt
  270dz(3) = mhgt
  280dz(4) = mhgt
  290
  300rdth = 0
  310
  320MOUSE mmx, mmy, mz%
  330taillen = 45
  331wibblegunk = .4
  340wibblefr = .95: wibblescale = .4
  350wibblelen = taillen
  360wibblestr = 0
  370
  380
  390scr%=1
  400REPEAT
  410MOUSE mx, my, mz
  420dx = mx - mmx
  430dy = my - mmy
  440ln = 0
  450IF ABSdx>0 OR ABSdy>0 THEN
  460ln = SQR(dx*dx+dy*dy)
  470mmx = mx - dx / ln * taillen
  480mmy = my - dy / ln * taillen
  490
  500rdth=FNang(dx,dy)-PI/2
  520ENDIF
  530
  550force = (taillen - wibblelen) / taillen
  560wibblestr = wibblestr * wibblefr + force
  570wibblelen += wibblestr * wibblescale + ( ln - taillen ) * wibblegunk
  580IF wibblelen < 6 wibblelen = 6
  590IF wibblelen + 8 > taillen * 2 wibblelen = taillen * 2 - 8
  600
  610rdcth = COSrdth
  620rdsth = SINrdth
  630
  640rdmu = x3mulu * rdcth + y3mulu * rdsth
  650rdmv = x3mulv * rdcth + y3mulv * rdsth
  660
  670dx(1) = 0: dy(1) = 0
  680dx(2) = wibblelen * rdsth: dy(2) = -wibblelen * rdcth
  690dx(3) = wibblelen * rdsth: dy(3) = -wibblelen * rdcth
  700dx(4) = 90 * rdsth: dy(4) = -90 * rdcth
  701rad(2) = 8 + 10 * taillen / wibblelen
  702rad(4) = 2 + 8 * taillen / (taillen * 2 - wibblelen)
  710SYS 6,112,scr%
  720WAIT
  730CLS
  731GCOL 3
  732RECTANGLE FILL 100,100,100,100
  733RECTANGLE FILL 400,400,100,100
  734RECTANGLE FILL 600,200,100,100
  735VDU 5:GCOL 2: MOVE 110,150: PRINT"EXIT":VDU4
  740PROCplotmouse( mx, my)
  750SYS 6,113,scr%
  760scr%=3-scr%
  770UNTIL mz AND mx > 100 AND mx < 200 AND my > 100 AND my < 200
  780SYS 6,112,1
  790SYS 6,113,1
  800END
  810
  820
  830
  840DEFPROCplotmouse( du, dv)
  850du -= mhgt * z3mulu
  860dv -= mhgt * z3mulv
  870ORIGIN du, dv
  880
  890FOR pair% = 1 TO 6 STEP 2
  900rad1 = rad(pair%)
  910rad2 = rad(pair%+1)
  920IF rad1 > 0 OR rad2 > 0 THEN
  930ru1 = rad1 * rdmu: rv1 = rad1 * rdmv
  940ru2 = rad2 * rdmu: rv2 = rad2 * rdmv
  950PROCconverts(pair%  ,bu1,bv1)
  960PROCconverts(pair%+1,bu2,bv2)
  970
  980GCOL 0, 5
  990MOVE bu2 - ru2, bv2 - rv2
 1000MOVE bu2 + ru2, bv2 + rv2
 1010PLOT85, bu1 - ru1, bv1 - rv1
 1020PLOT85, bu1 + ru1, bv1 + rv1
 1030ENDIF
 1040
 1050NEXT
 1060
 1070
 1080FOR pair% = 1 TO 6 STEP 2
 1090rad1 = rad(pair%)
 1100rad2 = rad(pair%+1)
 1110IF rad1 > 0 OR rad2 > 0 THEN
 1120ru1 = rad1 * rdmu: rv1 = rad1 * rdmv
 1130ru2 = rad2 * rdmu: rv2 = rad2 * rdmv
 1140PROCconvert(pair%  ,bu1,bv1)
 1150PROCconvert(pair%+1,bu2,bv2)
 1160
 1170GCOL 0, 8
 1180MOVE bu2 - ru2, bv2 - rv2
 1190MOVE bu2 + ru2, bv2 + rv2
 1200PLOT85, bu1 - ru1, bv1 - rv1
 1210PLOT85, bu1 + ru1, bv1 + rv1
 1220
 1230GCOL 0, 7
 1240DRAW bu1 - ru1, bv1 - rv1
 1250DRAW bu2 - ru2, bv2 - rv2
 1260DRAW bu2 + ru2, bv2 + rv2
 1270DRAW bu1 + ru1, bv1 + rv1
 1280ENDIF
 1290
 1300NEXT
 1310ORIGIN 0,0
 1320ENDPROC
 1330
 1340DEFPROCconvert(pt%, RETURN su, RETURN sv)
 1350su = dx(pt%) * x3mulu + dy(pt%) * y3mulu + dz(pt%) * z3mulu
 1360sv = dx(pt%) * x3mulv + dy(pt%) * y3mulv + dz(pt%) * z3mulv
 1370ENDPROC
 1380
 1390DEFPROCconverts(pt%, RETURN su, RETURN sv)
 1400su = dx(pt%) * x3mulu + dy(pt%) * y3mulu + dz(pt%) * l3mulu
 1410sv = dx(pt%) * x3mulv + dy(pt%) * y3mulv + dz(pt%) * l3mulv
 1420ENDPROC
 1430
 1440DEFFNang(dx,dy)
 1450LOCAL th
 1460IF ABSdy<ABSdx THEN
 1470  th = ATNABS(dy/dx)
 1480ELSE
 1490  th = PI/2-ATNABS(dx/dy)
 1500ENDIF
 1510IF dx<0 th=PI-th
 1520IF dy<0 th=-th
 1530=th

�27+128
�
� 0, 127,29,223
(� 5, 0,0,0
2� 8, 0,0,255
<� 7, 255,255,255
F� x,y,z - 3d coords
P� u,v - screen coords
Z
d!� rad(6), dx(6), dy(6), dz(6)
n
xrad(1) = 0
�rad(2) = 18
�rad(3) = 8
�rad(4) = 8
�rad(5) = 0
�rad(6) = 0
�
�x3mulu = 1: x3mulv = 0
�y3mulu = 0: y3mulv = 1
�z3mulu = 0: z3mulv = 1
�l3mulu = .2: l3mulv = 0
�
�
mhgt = 16
�dz(1) = mhgt
dz(2) = mhgt
dz(3) = mhgt
dz(4) = mhgt
"
,rdth = 0
6
@ȗ mmx, mmy, mz%
Jtaillen = 45
Kwibblegunk = .4
T$wibblefr = .95: wibblescale = .4
^wibblelen = taillen
hwibblestr = 0
r
|
�
scr%=1
��
�ȗ mx, my, mz
�dx = mx - mmx
�dy = my - mmy
�
ln = 0
�� �dx>0 � �dy>0 �
�ln = �(dx*dx+dy*dy)
� mmx = mx - dx / ln * taillen
� mmy = my - dy / ln * taillen
�
�rdth=�ang(dx,dy)-�/2
�

&+force = (taillen - wibblelen) / taillen
0,wibblestr = wibblestr * wibblefr + force
:Hwibblelen += wibblestr * wibblescale + ( ln - taillen ) * wibblegunk
D!� wibblelen < 6 wibblelen = 6
N=� wibblelen + 8 > taillen * 2 wibblelen = taillen * 2 - 8
X
brdcth = �rdth
lrdsth = �rdth
v
�*rdmu = x3mulu * rdcth + y3mulu * rdsth
�*rdmv = x3mulv * rdcth + y3mulv * rdsth
�
�dx(1) = 0: dy(1) = 0
�9dx(2) = wibblelen * rdsth: dy(2) = -wibblelen * rdcth
�9dx(3) = wibblelen * rdsth: dy(3) = -wibblelen * rdcth
�+dx(4) = 90 * rdsth: dy(4) = -90 * rdcth
�)rad(2) = 8 + 10 * taillen / wibblelen
�8rad(4) = 2 + 8 * taillen / (taillen * 2 - wibblelen)
�ș 6,112,scr%
�Ȗ
��
�� 3
�ȓ Ȑ 100,100,100,100
�ȓ Ȑ 400,400,100,100
�ȓ Ȑ 600,200,100,100
�"� 5:� 2: � 110,150: �"EXIT":�4
��plotmouse( mx, my)
�ș 6,113,scr%
�scr%=3-scr%
4� mz � mx > 100 � mx < 200 � my > 100 � my < 200
ș 6,112,1
ș 6,113,1
 �
*
4
>
H��plotmouse( du, dv)
Rdu -= mhgt * z3mulu
\dv -= mhgt * z3mulv
f
ȑ du, dv
p
z� pair% = 1 � 6 � 2
�rad1 = rad(pair%)
�rad2 = rad(pair%+1)
�� rad1 > 0 � rad2 > 0 �
�(ru1 = rad1 * rdmu: rv1 = rad1 * rdmv
�(ru2 = rad2 * rdmu: rv2 = rad2 * rdmv
��converts(pair%  ,bu1,bv1)
��converts(pair%+1,bu2,bv2)
�
�
� 0, 5
�� bu2 - ru2, bv2 - rv2
�� bu2 + ru2, bv2 + rv2
��85, bu1 - ru1, bv1 - rv1
��85, bu1 + ru1, bv1 + rv1
�

�
$
.
8� pair% = 1 � 6 � 2
Brad1 = rad(pair%)
Lrad2 = rad(pair%+1)
V� rad1 > 0 � rad2 > 0 �
`(ru1 = rad1 * rdmu: rv1 = rad1 * rdmv
j(ru2 = rad2 * rdmu: rv2 = rad2 * rdmv
t�convert(pair%  ,bu1,bv1)
~�convert(pair%+1,bu2,bv2)
�
�
� 0, 8
�� bu2 - ru2, bv2 - rv2
�� bu2 + ru2, bv2 + rv2
��85, bu1 - ru1, bv1 - rv1
��85, bu1 + ru1, bv1 + rv1
�
�
� 0, 7
�� bu1 - ru1, bv1 - rv1
�� bu2 - ru2, bv2 - rv2
�� bu2 + ru2, bv2 + rv2
�� bu1 + ru1, bv1 + rv1
�


�

ȑ 0,0
(�
2
<��convert(pt%, � su, � sv)
F?su = dx(pt%) * x3mulu + dy(pt%) * y3mulu + dz(pt%) * z3mulu
P?sv = dx(pt%) * x3mulv + dy(pt%) * y3mulv + dz(pt%) * z3mulv
Z�
d
n��converts(pt%, � su, � sv)
x?su = dx(pt%) * x3mulu + dy(pt%) * y3mulu + dz(pt%) * l3mulu
�?sv = dx(pt%) * x3mulv + dy(pt%) * y3mulv + dz(pt%) * l3mulv
��
�
�ݤang(dx,dy)
�� th
�� �dy<�dx �
�  th = ��(dy/dx)
��
�  th = �/2-��(dx/dy)
��
�� dx<0 th=�-th
�� dy<0 th=-th
�=th
�
00000000  0d 00 0a 0b eb 32 37 2b  31 32 38 0d 00 14 05 87  |.....27+128.....|
00000010  0d 00 1e 13 fb 20 30 2c  20 31 32 37 2c 32 39 2c  |..... 0, 127,29,|
00000020  32 32 33 0d 00 28 0e fb  20 35 2c 20 30 2c 30 2c  |223..(.. 5, 0,0,|
00000030  30 0d 00 32 10 fb 20 38  2c 20 30 2c 30 2c 32 35  |0..2.. 8, 0,0,25|
00000040  35 0d 00 3c 14 fb 20 37  2c 20 32 35 35 2c 32 35  |5..<.. 7, 255,25|
00000050  35 2c 32 35 35 0d 00 46  17 f4 20 78 2c 79 2c 7a  |5,255..F.. x,y,z|
00000060  20 2d 20 33 64 20 63 6f  6f 72 64 73 0d 00 50 19  | - 3d coords..P.|
00000070  f4 20 75 2c 76 20 2d 20  73 63 72 65 65 6e 20 63  |. u,v - screen c|
00000080  6f 6f 72 64 73 0d 00 5a  04 0d 00 64 21 de 20 72  |oords..Z...d!. r|
00000090  61 64 28 36 29 2c 20 64  78 28 36 29 2c 20 64 79  |ad(6), dx(6), dy|
000000a0  28 36 29 2c 20 64 7a 28  36 29 0d 00 6e 04 0d 00  |(6), dz(6)..n...|
000000b0  78 0e 72 61 64 28 31 29  20 3d 20 30 0d 00 82 0f  |x.rad(1) = 0....|
000000c0  72 61 64 28 32 29 20 3d  20 31 38 0d 00 8c 0e 72  |rad(2) = 18....r|
000000d0  61 64 28 33 29 20 3d 20  38 0d 00 96 0e 72 61 64  |ad(3) = 8....rad|
000000e0  28 34 29 20 3d 20 38 0d  00 a0 0e 72 61 64 28 35  |(4) = 8....rad(5|
000000f0  29 20 3d 20 30 0d 00 aa  0e 72 61 64 28 36 29 20  |) = 0....rad(6) |
00000100  3d 20 30 0d 00 b4 04 0d  00 be 1a 78 33 6d 75 6c  |= 0........x3mul|
00000110  75 20 3d 20 31 3a 20 78  33 6d 75 6c 76 20 3d 20  |u = 1: x3mulv = |
00000120  30 0d 00 c8 1a 79 33 6d  75 6c 75 20 3d 20 30 3a  |0....y3mulu = 0:|
00000130  20 79 33 6d 75 6c 76 20  3d 20 31 0d 00 d2 1a 7a  | y3mulv = 1....z|
00000140  33 6d 75 6c 75 20 3d 20  30 3a 20 7a 33 6d 75 6c  |3mulu = 0: z3mul|
00000150  76 20 3d 20 31 0d 00 dc  1b 6c 33 6d 75 6c 75 20  |v = 1....l3mulu |
00000160  3d 20 2e 32 3a 20 6c 33  6d 75 6c 76 20 3d 20 30  |= .2: l3mulv = 0|
00000170  0d 00 e6 04 0d 00 f0 0d  6d 68 67 74 20 3d 20 31  |........mhgt = 1|
00000180  36 0d 00 fa 10 64 7a 28  31 29 20 3d 20 6d 68 67  |6....dz(1) = mhg|
00000190  74 0d 01 04 10 64 7a 28  32 29 20 3d 20 6d 68 67  |t....dz(2) = mhg|
000001a0  74 0d 01 0e 10 64 7a 28  33 29 20 3d 20 6d 68 67  |t....dz(3) = mhg|
000001b0  74 0d 01 18 10 64 7a 28  34 29 20 3d 20 6d 68 67  |t....dz(4) = mhg|
000001c0  74 0d 01 22 04 0d 01 2c  0c 72 64 74 68 20 3d 20  |t.."...,.rdth = |
000001d0  30 0d 01 36 04 0d 01 40  14 c8 97 20 6d 6d 78 2c  |0..6...@... mmx,|
000001e0  20 6d 6d 79 2c 20 6d 7a  25 0d 01 4a 10 74 61 69  | mmy, mz%..J.tai|
000001f0  6c 6c 65 6e 20 3d 20 34  35 0d 01 4b 13 77 69 62  |llen = 45..K.wib|
00000200  62 6c 65 67 75 6e 6b 20  3d 20 2e 34 0d 01 54 24  |blegunk = .4..T$|
00000210  77 69 62 62 6c 65 66 72  20 3d 20 2e 39 35 3a 20  |wibblefr = .95: |
00000220  77 69 62 62 6c 65 73 63  61 6c 65 20 3d 20 2e 34  |wibblescale = .4|
00000230  0d 01 5e 17 77 69 62 62  6c 65 6c 65 6e 20 3d 20  |..^.wibblelen = |
00000240  74 61 69 6c 6c 65 6e 0d  01 68 11 77 69 62 62 6c  |taillen..h.wibbl|
00000250  65 73 74 72 20 3d 20 30  0d 01 72 04 0d 01 7c 04  |estr = 0..r...|.|
00000260  0d 01 86 0a 73 63 72 25  3d 31 0d 01 90 05 f5 0d  |....scr%=1......|
00000270  01 9a 11 c8 97 20 6d 78  2c 20 6d 79 2c 20 6d 7a  |..... mx, my, mz|
00000280  0d 01 a4 11 64 78 20 3d  20 6d 78 20 2d 20 6d 6d  |....dx = mx - mm|
00000290  78 0d 01 ae 11 64 79 20  3d 20 6d 79 20 2d 20 6d  |x....dy = my - m|
000002a0  6d 79 0d 01 b8 0a 6c 6e  20 3d 20 30 0d 01 c2 15  |my....ln = 0....|
000002b0  e7 20 94 64 78 3e 30 20  84 20 94 64 79 3e 30 20  |. .dx>0 . .dy>0 |
000002c0  8c 0d 01 cc 17 6c 6e 20  3d 20 b6 28 64 78 2a 64  |.....ln = .(dx*d|
000002d0  78 2b 64 79 2a 64 79 29  0d 01 d6 20 6d 6d 78 20  |x+dy*dy)... mmx |
000002e0  3d 20 6d 78 20 2d 20 64  78 20 2f 20 6c 6e 20 2a  |= mx - dx / ln *|
000002f0  20 74 61 69 6c 6c 65 6e  0d 01 e0 20 6d 6d 79 20  | taillen... mmy |
00000300  3d 20 6d 79 20 2d 20 64  79 20 2f 20 6c 6e 20 2a  |= my - dy / ln *|
00000310  20 74 61 69 6c 6c 65 6e  0d 01 ea 04 0d 01 f4 18  | taillen........|
00000320  72 64 74 68 3d a4 61 6e  67 28 64 78 2c 64 79 29  |rdth=.ang(dx,dy)|
00000330  2d af 2f 32 0d 02 08 05  cd 0d 02 12 04 0d 02 26  |-./2...........&|
00000340  2b 66 6f 72 63 65 20 3d  20 28 74 61 69 6c 6c 65  |+force = (taille|
00000350  6e 20 2d 20 77 69 62 62  6c 65 6c 65 6e 29 20 2f  |n - wibblelen) /|
00000360  20 74 61 69 6c 6c 65 6e  0d 02 30 2c 77 69 62 62  | taillen..0,wibb|
00000370  6c 65 73 74 72 20 3d 20  77 69 62 62 6c 65 73 74  |lestr = wibblest|
00000380  72 20 2a 20 77 69 62 62  6c 65 66 72 20 2b 20 66  |r * wibblefr + f|
00000390  6f 72 63 65 0d 02 3a 48  77 69 62 62 6c 65 6c 65  |orce..:Hwibblele|
000003a0  6e 20 2b 3d 20 77 69 62  62 6c 65 73 74 72 20 2a  |n += wibblestr *|
000003b0  20 77 69 62 62 6c 65 73  63 61 6c 65 20 2b 20 28  | wibblescale + (|
000003c0  20 6c 6e 20 2d 20 74 61  69 6c 6c 65 6e 20 29 20  | ln - taillen ) |
000003d0  2a 20 77 69 62 62 6c 65  67 75 6e 6b 0d 02 44 21  |* wibblegunk..D!|
000003e0  e7 20 77 69 62 62 6c 65  6c 65 6e 20 3c 20 36 20  |. wibblelen < 6 |
000003f0  77 69 62 62 6c 65 6c 65  6e 20 3d 20 36 0d 02 4e  |wibblelen = 6..N|
00000400  3d e7 20 77 69 62 62 6c  65 6c 65 6e 20 2b 20 38  |=. wibblelen + 8|
00000410  20 3e 20 74 61 69 6c 6c  65 6e 20 2a 20 32 20 77  | > taillen * 2 w|
00000420  69 62 62 6c 65 6c 65 6e  20 3d 20 74 61 69 6c 6c  |ibblelen = taill|
00000430  65 6e 20 2a 20 32 20 2d  20 38 0d 02 58 04 0d 02  |en * 2 - 8..X...|
00000440  62 11 72 64 63 74 68 20  3d 20 9b 72 64 74 68 0d  |b.rdcth = .rdth.|
00000450  02 6c 11 72 64 73 74 68  20 3d 20 b5 72 64 74 68  |.l.rdsth = .rdth|
00000460  0d 02 76 04 0d 02 80 2a  72 64 6d 75 20 3d 20 78  |..v....*rdmu = x|
00000470  33 6d 75 6c 75 20 2a 20  72 64 63 74 68 20 2b 20  |3mulu * rdcth + |
00000480  79 33 6d 75 6c 75 20 2a  20 72 64 73 74 68 0d 02  |y3mulu * rdsth..|
00000490  8a 2a 72 64 6d 76 20 3d  20 78 33 6d 75 6c 76 20  |.*rdmv = x3mulv |
000004a0  2a 20 72 64 63 74 68 20  2b 20 79 33 6d 75 6c 76  |* rdcth + y3mulv|
000004b0  20 2a 20 72 64 73 74 68  0d 02 94 04 0d 02 9e 18  | * rdsth........|
000004c0  64 78 28 31 29 20 3d 20  30 3a 20 64 79 28 31 29  |dx(1) = 0: dy(1)|
000004d0  20 3d 20 30 0d 02 a8 39  64 78 28 32 29 20 3d 20  | = 0...9dx(2) = |
000004e0  77 69 62 62 6c 65 6c 65  6e 20 2a 20 72 64 73 74  |wibblelen * rdst|
000004f0  68 3a 20 64 79 28 32 29  20 3d 20 2d 77 69 62 62  |h: dy(2) = -wibb|
00000500  6c 65 6c 65 6e 20 2a 20  72 64 63 74 68 0d 02 b2  |lelen * rdcth...|
00000510  39 64 78 28 33 29 20 3d  20 77 69 62 62 6c 65 6c  |9dx(3) = wibblel|
00000520  65 6e 20 2a 20 72 64 73  74 68 3a 20 64 79 28 33  |en * rdsth: dy(3|
00000530  29 20 3d 20 2d 77 69 62  62 6c 65 6c 65 6e 20 2a  |) = -wibblelen *|
00000540  20 72 64 63 74 68 0d 02  bc 2b 64 78 28 34 29 20  | rdcth...+dx(4) |
00000550  3d 20 39 30 20 2a 20 72  64 73 74 68 3a 20 64 79  |= 90 * rdsth: dy|
00000560  28 34 29 20 3d 20 2d 39  30 20 2a 20 72 64 63 74  |(4) = -90 * rdct|
00000570  68 0d 02 bd 29 72 61 64  28 32 29 20 3d 20 38 20  |h...)rad(2) = 8 |
00000580  2b 20 31 30 20 2a 20 74  61 69 6c 6c 65 6e 20 2f  |+ 10 * taillen /|
00000590  20 77 69 62 62 6c 65 6c  65 6e 0d 02 be 38 72 61  | wibblelen...8ra|
000005a0  64 28 34 29 20 3d 20 32  20 2b 20 38 20 2a 20 74  |d(4) = 2 + 8 * t|
000005b0  61 69 6c 6c 65 6e 20 2f  20 28 74 61 69 6c 6c 65  |aillen / (taille|
000005c0  6e 20 2a 20 32 20 2d 20  77 69 62 62 6c 65 6c 65  |n * 2 - wibblele|
000005d0  6e 29 0d 02 c6 11 c8 99  20 36 2c 31 31 32 2c 73  |n)...... 6,112,s|
000005e0  63 72 25 0d 02 d0 06 c8  96 0d 02 da 05 db 0d 02  |cr%.............|
000005f0  db 07 e6 20 33 0d 02 dc  19 c8 93 20 c8 90 20 31  |... 3...... .. 1|
00000600  30 30 2c 31 30 30 2c 31  30 30 2c 31 30 30 0d 02  |00,100,100,100..|
00000610  dd 19 c8 93 20 c8 90 20  34 30 30 2c 34 30 30 2c  |.... .. 400,400,|
00000620  31 30 30 2c 31 30 30 0d  02 de 19 c8 93 20 c8 90  |100,100...... ..|
00000630  20 36 30 30 2c 32 30 30  2c 31 30 30 2c 31 30 30  | 600,200,100,100|
00000640  0d 02 df 22 ef 20 35 3a  e6 20 32 3a 20 ec 20 31  |...". 5:. 2: . 1|
00000650  31 30 2c 31 35 30 3a 20  f1 22 45 58 49 54 22 3a  |10,150: ."EXIT":|
00000660  ef 34 0d 02 e4 17 f2 70  6c 6f 74 6d 6f 75 73 65  |.4.....plotmouse|
00000670  28 20 6d 78 2c 20 6d 79  29 0d 02 ee 11 c8 99 20  |( mx, my)...... |
00000680  36 2c 31 31 33 2c 73 63  72 25 0d 02 f8 0f 73 63  |6,113,scr%....sc|
00000690  72 25 3d 33 2d 73 63 72  25 0d 03 02 34 fd 20 6d  |r%=3-scr%...4. m|
000006a0  7a 20 80 20 6d 78 20 3e  20 31 30 30 20 80 20 6d  |z . mx > 100 . m|
000006b0  78 20 3c 20 32 30 30 20  80 20 6d 79 20 3e 20 31  |x < 200 . my > 1|
000006c0  30 30 20 80 20 6d 79 20  3c 20 32 30 30 0d 03 0c  |00 . my < 200...|
000006d0  0e c8 99 20 36 2c 31 31  32 2c 31 0d 03 16 0e c8  |... 6,112,1.....|
000006e0  99 20 36 2c 31 31 33 2c  31 0d 03 20 05 e0 0d 03  |. 6,113,1.. ....|
000006f0  2a 04 0d 03 34 04 0d 03  3e 04 0d 03 48 18 dd f2  |*...4...>...H...|
00000700  70 6c 6f 74 6d 6f 75 73  65 28 20 64 75 2c 20 64  |plotmouse( du, d|
00000710  76 29 0d 03 52 17 64 75  20 2d 3d 20 6d 68 67 74  |v)..R.du -= mhgt|
00000720  20 2a 20 7a 33 6d 75 6c  75 0d 03 5c 17 64 76 20  | * z3mulu..\.dv |
00000730  2d 3d 20 6d 68 67 74 20  2a 20 7a 33 6d 75 6c 76  |-= mhgt * z3mulv|
00000740  0d 03 66 0d c8 91 20 64  75 2c 20 64 76 0d 03 70  |..f... du, dv..p|
00000750  04 0d 03 7a 17 e3 20 70  61 69 72 25 20 3d 20 31  |...z.. pair% = 1|
00000760  20 b8 20 36 20 88 20 32  0d 03 84 15 72 61 64 31  | . 6 . 2....rad1|
00000770  20 3d 20 72 61 64 28 70  61 69 72 25 29 0d 03 8e  | = rad(pair%)...|
00000780  17 72 61 64 32 20 3d 20  72 61 64 28 70 61 69 72  |.rad2 = rad(pair|
00000790  25 2b 31 29 0d 03 98 1b  e7 20 72 61 64 31 20 3e  |%+1)..... rad1 >|
000007a0  20 30 20 84 20 72 61 64  32 20 3e 20 30 20 8c 0d  | 0 . rad2 > 0 ..|
000007b0  03 a2 28 72 75 31 20 3d  20 72 61 64 31 20 2a 20  |..(ru1 = rad1 * |
000007c0  72 64 6d 75 3a 20 72 76  31 20 3d 20 72 61 64 31  |rdmu: rv1 = rad1|
000007d0  20 2a 20 72 64 6d 76 0d  03 ac 28 72 75 32 20 3d  | * rdmv...(ru2 =|
000007e0  20 72 61 64 32 20 2a 20  72 64 6d 75 3a 20 72 76  | rad2 * rdmu: rv|
000007f0  32 20 3d 20 72 61 64 32  20 2a 20 72 64 6d 76 0d  |2 = rad2 * rdmv.|
00000800  03 b6 1e f2 63 6f 6e 76  65 72 74 73 28 70 61 69  |....converts(pai|
00000810  72 25 20 20 2c 62 75 31  2c 62 76 31 29 0d 03 c0  |r%  ,bu1,bv1)...|
00000820  1e f2 63 6f 6e 76 65 72  74 73 28 70 61 69 72 25  |..converts(pair%|
00000830  2b 31 2c 62 75 32 2c 62  76 32 29 0d 03 ca 04 0d  |+1,bu2,bv2).....|
00000840  03 d4 0a e6 20 30 2c 20  35 0d 03 de 1a ec 20 62  |.... 0, 5..... b|
00000850  75 32 20 2d 20 72 75 32  2c 20 62 76 32 20 2d 20  |u2 - ru2, bv2 - |
00000860  72 76 32 0d 03 e8 1a ec  20 62 75 32 20 2b 20 72  |rv2..... bu2 + r|
00000870  75 32 2c 20 62 76 32 20  2b 20 72 76 32 0d 03 f2  |u2, bv2 + rv2...|
00000880  1d f0 38 35 2c 20 62 75  31 20 2d 20 72 75 31 2c  |..85, bu1 - ru1,|
00000890  20 62 76 31 20 2d 20 72  76 31 0d 03 fc 1d f0 38  | bv1 - rv1.....8|
000008a0  35 2c 20 62 75 31 20 2b  20 72 75 31 2c 20 62 76  |5, bu1 + ru1, bv|
000008b0  31 20 2b 20 72 76 31 0d  04 06 05 cd 0d 04 10 04  |1 + rv1.........|
000008c0  0d 04 1a 05 ed 0d 04 24  04 0d 04 2e 04 0d 04 38  |.......$.......8|
000008d0  17 e3 20 70 61 69 72 25  20 3d 20 31 20 b8 20 36  |.. pair% = 1 . 6|
000008e0  20 88 20 32 0d 04 42 15  72 61 64 31 20 3d 20 72  | . 2..B.rad1 = r|
000008f0  61 64 28 70 61 69 72 25  29 0d 04 4c 17 72 61 64  |ad(pair%)..L.rad|
00000900  32 20 3d 20 72 61 64 28  70 61 69 72 25 2b 31 29  |2 = rad(pair%+1)|
00000910  0d 04 56 1b e7 20 72 61  64 31 20 3e 20 30 20 84  |..V.. rad1 > 0 .|
00000920  20 72 61 64 32 20 3e 20  30 20 8c 0d 04 60 28 72  | rad2 > 0 ...`(r|
00000930  75 31 20 3d 20 72 61 64  31 20 2a 20 72 64 6d 75  |u1 = rad1 * rdmu|
00000940  3a 20 72 76 31 20 3d 20  72 61 64 31 20 2a 20 72  |: rv1 = rad1 * r|
00000950  64 6d 76 0d 04 6a 28 72  75 32 20 3d 20 72 61 64  |dmv..j(ru2 = rad|
00000960  32 20 2a 20 72 64 6d 75  3a 20 72 76 32 20 3d 20  |2 * rdmu: rv2 = |
00000970  72 61 64 32 20 2a 20 72  64 6d 76 0d 04 74 1d f2  |rad2 * rdmv..t..|
00000980  63 6f 6e 76 65 72 74 28  70 61 69 72 25 20 20 2c  |convert(pair%  ,|
00000990  62 75 31 2c 62 76 31 29  0d 04 7e 1d f2 63 6f 6e  |bu1,bv1)..~..con|
000009a0  76 65 72 74 28 70 61 69  72 25 2b 31 2c 62 75 32  |vert(pair%+1,bu2|
000009b0  2c 62 76 32 29 0d 04 88  04 0d 04 92 0a e6 20 30  |,bv2)......... 0|
000009c0  2c 20 38 0d 04 9c 1a ec  20 62 75 32 20 2d 20 72  |, 8..... bu2 - r|
000009d0  75 32 2c 20 62 76 32 20  2d 20 72 76 32 0d 04 a6  |u2, bv2 - rv2...|
000009e0  1a ec 20 62 75 32 20 2b  20 72 75 32 2c 20 62 76  |.. bu2 + ru2, bv|
000009f0  32 20 2b 20 72 76 32 0d  04 b0 1d f0 38 35 2c 20  |2 + rv2.....85, |
00000a00  62 75 31 20 2d 20 72 75  31 2c 20 62 76 31 20 2d  |bu1 - ru1, bv1 -|
00000a10  20 72 76 31 0d 04 ba 1d  f0 38 35 2c 20 62 75 31  | rv1.....85, bu1|
00000a20  20 2b 20 72 75 31 2c 20  62 76 31 20 2b 20 72 76  | + ru1, bv1 + rv|
00000a30  31 0d 04 c4 04 0d 04 ce  0a e6 20 30 2c 20 37 0d  |1......... 0, 7.|
00000a40  04 d8 1a df 20 62 75 31  20 2d 20 72 75 31 2c 20  |.... bu1 - ru1, |
00000a50  62 76 31 20 2d 20 72 76  31 0d 04 e2 1a df 20 62  |bv1 - rv1..... b|
00000a60  75 32 20 2d 20 72 75 32  2c 20 62 76 32 20 2d 20  |u2 - ru2, bv2 - |
00000a70  72 76 32 0d 04 ec 1a df  20 62 75 32 20 2b 20 72  |rv2..... bu2 + r|
00000a80  75 32 2c 20 62 76 32 20  2b 20 72 76 32 0d 04 f6  |u2, bv2 + rv2...|
00000a90  1a df 20 62 75 31 20 2b  20 72 75 31 2c 20 62 76  |.. bu1 + ru1, bv|
00000aa0  31 20 2b 20 72 76 31 0d  05 00 05 cd 0d 05 0a 04  |1 + rv1.........|
00000ab0  0d 05 14 05 ed 0d 05 1e  0a c8 91 20 30 2c 30 0d  |........... 0,0.|
00000ac0  05 28 05 e1 0d 05 32 04  0d 05 3c 1e dd f2 63 6f  |.(....2...<...co|
00000ad0  6e 76 65 72 74 28 70 74  25 2c 20 f8 20 73 75 2c  |nvert(pt%, . su,|
00000ae0  20 f8 20 73 76 29 0d 05  46 3f 73 75 20 3d 20 64  | . sv)..F?su = d|
00000af0  78 28 70 74 25 29 20 2a  20 78 33 6d 75 6c 75 20  |x(pt%) * x3mulu |
00000b00  2b 20 64 79 28 70 74 25  29 20 2a 20 79 33 6d 75  |+ dy(pt%) * y3mu|
00000b10  6c 75 20 2b 20 64 7a 28  70 74 25 29 20 2a 20 7a  |lu + dz(pt%) * z|
00000b20  33 6d 75 6c 75 0d 05 50  3f 73 76 20 3d 20 64 78  |3mulu..P?sv = dx|
00000b30  28 70 74 25 29 20 2a 20  78 33 6d 75 6c 76 20 2b  |(pt%) * x3mulv +|
00000b40  20 64 79 28 70 74 25 29  20 2a 20 79 33 6d 75 6c  | dy(pt%) * y3mul|
00000b50  76 20 2b 20 64 7a 28 70  74 25 29 20 2a 20 7a 33  |v + dz(pt%) * z3|
00000b60  6d 75 6c 76 0d 05 5a 05  e1 0d 05 64 04 0d 05 6e  |mulv..Z....d...n|
00000b70  1f dd f2 63 6f 6e 76 65  72 74 73 28 70 74 25 2c  |...converts(pt%,|
00000b80  20 f8 20 73 75 2c 20 f8  20 73 76 29 0d 05 78 3f  | . su, . sv)..x?|
00000b90  73 75 20 3d 20 64 78 28  70 74 25 29 20 2a 20 78  |su = dx(pt%) * x|
00000ba0  33 6d 75 6c 75 20 2b 20  64 79 28 70 74 25 29 20  |3mulu + dy(pt%) |
00000bb0  2a 20 79 33 6d 75 6c 75  20 2b 20 64 7a 28 70 74  |* y3mulu + dz(pt|
00000bc0  25 29 20 2a 20 6c 33 6d  75 6c 75 0d 05 82 3f 73  |%) * l3mulu...?s|
00000bd0  76 20 3d 20 64 78 28 70  74 25 29 20 2a 20 78 33  |v = dx(pt%) * x3|
00000be0  6d 75 6c 76 20 2b 20 64  79 28 70 74 25 29 20 2a  |mulv + dy(pt%) *|
00000bf0  20 79 33 6d 75 6c 76 20  2b 20 64 7a 28 70 74 25  | y3mulv + dz(pt%|
00000c00  29 20 2a 20 6c 33 6d 75  6c 76 0d 05 8c 05 e1 0d  |) * l3mulv......|
00000c10  05 96 04 0d 05 a0 10 dd  a4 61 6e 67 28 64 78 2c  |.........ang(dx,|
00000c20  64 79 29 0d 05 aa 08 ea  20 74 68 0d 05 b4 0f e7  |dy)..... th.....|
00000c30  20 94 64 79 3c 94 64 78  20 8c 0d 05 be 14 20 20  | .dy<.dx .....  |
00000c40  74 68 20 3d 20 99 94 28  64 79 2f 64 78 29 0d 05  |th = ..(dy/dx)..|
00000c50  c8 05 cc 0d 05 d2 18 20  20 74 68 20 3d 20 af 2f  |.......  th = ./|
00000c60  32 2d 99 94 28 64 78 2f  64 79 29 0d 05 dc 05 cd  |2-..(dx/dy).....|
00000c70  0d 05 e6 12 e7 20 64 78  3c 30 20 74 68 3d af 2d  |..... dx<0 th=.-|
00000c80  74 68 0d 05 f0 11 e7 20  64 79 3c 30 20 74 68 3d  |th..... dy<0 th=|
00000c90  2d 74 68 0d 05 fa 07 3d  74 68 0d ff              |-th....=th..|
00000c9c