chiark / gitweb /
tt_atlas_motor
[trains.git] / layout / parts.i4
1 define(`def_thing_l_r',`
2 dnl OBJNAME-EXCLUDING-L
3  defpart $1r
4   abs c 200 200 0
5   objflip $1l c c =
6  enddef
7 ')
8
9 define(`def_point_ord',`
10 dnl OBJNAME-EXCLUDING-PT-L ANGLE STRAIGHT-L CURVE-LONGER CURVE-DIVERGE-Y MIN-R
11  defpart pt_$1l
12   abs c 200 200 0
13   extend c a len $3
14   rel a b $4 -$5 $2
15   join c b $6
16  enddef
17  def_thing_l_r(`pt_$1')
18 ')
19
20 define(`def_point_curve',`
21 dnl OBJNAME-EXCLUDING-PT-L TIGHT-ANG TIGHT-RECT TIGHT-DIVERGE-Y SHALLOW.. MIN-R
22  defpart pt_$1l
23   abs c 200 200 0
24   rel c a $6 -$7 $5
25   rel c b $3 -$4 $2
26   join c a $8
27   join c b $8
28  enddef
29  def_thing_l_r(`pt_$1')
30 ')
31
32 define(`def_point_y',`
33 dnl OBJNAME-EXCLUDING-PT HALF-ANG RECT HALF-DIVERGE-Y MIN-R
34  defpart pt_$1
35   abs c 200 200 0
36   rel c l $3 -$4  $2
37   rel c r $3  $4 -$2
38   join c l $5
39   join c r $5
40  enddef
41 ')
42
43 define(`def_crossing',`
44 dnl OBJNAME-EXCLUDING-CROSS HALF-ANG HALF-LENGTH
45  defpart cross_$1
46   abs m 200 200 0
47   rel m ml 0 0 $2
48   rel m mr 0 0 -$2
49   extend ml tl len $3
50   extend mr tr len $3
51   extend mr bl len -$3
52   extend ml br len -$3
53  enddef
54 ')
55
56 def_point_ord(`peco_s', 22.5, 87,  -0.5, 17,    200) # not minr 230 ?
57 def_point_ord(`peco_m', 14,  126.5,-1.55,13.21, 315) # not minr 457 ?
58 def_point_ord(`peco_l',  8,  160,  -0.4, 13.21, 914)
59  # catalogue says 123.7 for STRAIGHT-L ?!
60
61 def_point_curve(`peco_c',  10, 154.4, 13.8,  3, 156.0, 0.8, 457)
62  dnl 163.2-  } dist to markings on paper cribsheet from c
63  dnl 32.8-   }
64
65 def_point_y(`peco_y', 4, 127, 8.4, 800) # not minr 762 ?
66
67 #def_crossing(`mythical',7,   80)
68 def_crossing(`peco_l',  4,   93.75)
69 def_crossing(`peco_s', 12.5, 46)
70
71
72 def_crossing(`atlas_15',   7.5, 64)
73 def_crossing(`atlas_15m',  7.5, 61)
74 def_crossing(`atlas_90',  45,   62.4)
75 def_crossing(`atlas_90m', 45,    8.5)
76 def_crossing(`atlas_30',  15,   32.9)
77 def_crossing(`atlas_30m', 15,   30.9)
78 def_crossing(`atlas_60',  30,   48.5)
79 def_crossing(`atlas_60m', 30,   14.5)
80 def_crossing(`atlas_20',  10,   63.5)
81 def_crossing(`atlas_20m', 10,   46.0)
82 def_crossing(`atlas_45',  22.5, 50.9)
83 def_crossing(`atlas_45m', 22.5, 19.5)
84
85 define(`def_point_shino',`
86 dnl OBJNAME-EXCLUDING-PT-L($1) A($2) B($3) Q($4)
87 dnl not R($5)
88  defpart pt_$1l
89   abs c 200 200 0
90   layer s
91   rel c strintersect $3 0 $4
92   rel strintersect strbackanal -$3
93   layer =
94   rel strbackanal b $2
95   join c b 240 arcline
96   extend c a len $2
97  enddef
98  def_thing_l_r(`pt_$1')
99 ')
100
101 def_point_shino(`shino_4', 136, 45, 14.25)
102 def_point_shino(`shino_6', 177, 49,  9.50)
103 def_point_y(`shino_y', 7.125, 140, 10.9, 750) # not minr 500 ?
104
105 defpart pt_shino_x3
106   abs c 200 200 0
107   layer s
108   rel c strintersectc  74 0   9.5
109   rel c strintersectb 103 0 -12
110   layer =
111   rel strintersectc l 141
112   rel strintersectb r 112
113   extend c m len 215
114   join c l 315 arcline
115   join c r 315 arcline
116 enddef
117
118 # this one is broken, because we don't have full details
119 #defpart pt_shino_cl
120 #  abs c 200 200 -20
121 #  extend c a len 268 -315
122 #  rel a b -4 -18 10
123 #  join c b 275 twoarcs
124 ##  extend c b upto a -285
125 #enddef
126 #defpart pt_shino_cr
127 #  abs c 200 200 20
128 #  objflip pt_shino_cl c c =
129 #enddef
130
131 defpart slip2_shino
132  abs m 200 200 0
133  rel m ml 0 0  4.75
134  rel m mr 0 0 -4.75
135  extend ml tl len 114
136  extend mr tr len 114
137  extend ml br len -114
138  extend mr bl len -114
139  join bl tl 500
140  join br tr 500
141 enddef
142
143 defpart scis_shino
144   abs bl 200 200 0
145   rel bl br 0 33 0
146   extend bl tl len 308
147   extend br tr len 308
148   layer s
149   rel bl m 154 16.5
150   rel m ml 0 0 9.5
151   rel m mr 0 0 -9.5
152   layer =
153   join bl mr 315
154   join mr tr 315
155   join br ml 315
156   join ml tl 315
157 enddef
158
159 define(`tt_do_circle',`
160  layer s
161  rel mid forcirc0$2 0 $1 0
162  rel mid forcirc1$2 0 -$1 180
163  layer l
164  join forcirc0$2 forcirc1$2 0
165  join forcirc1$2 forcirc0$2 0
166  layer =
167 ')
168
169 defpart tt_peco
170  layer =
171  abs mid 200 200 0
172  extend mid out len 80
173  extend -mid -in len 80
174
175  tt_do_circle(80, `')
176 enddef
177
178 define(`tt_atlas_out',`
179  layer s
180  rel mid mid$1 0 0 $1
181  layer =
182  rel mid$1 out$1 109 0
183 ')
184
185 defpart tt_atlas
186  layer =
187  abs mid 200 200 0
188  extend mid out len 109
189  extend -mid -in len 109
190
191  tt_atlas_out(`0')
192  tt_atlas_out(`15')
193  tt_atlas_out(`30')
194  tt_atlas_out(`45')
195  tt_atlas_out(`60')
196  tt_atlas_out(`75')
197  tt_atlas_out(`90')
198  tt_atlas_out(`105')
199  tt_atlas_out(`120')
200  tt_atlas_out(`135')
201  tt_atlas_out(`150')
202  tt_atlas_out(`165')
203  tt_atlas_out(`180')
204  tt_atlas_out(`195')
205  tt_atlas_out(`210')
206  tt_atlas_out(`225')
207  tt_atlas_out(`240')
208  tt_atlas_out(`255')
209  tt_atlas_out(`270')
210  tt_atlas_out(`285')
211  tt_atlas_out(`300')
212  tt_atlas_out(`315')
213  tt_atlas_out(`330')
214  tt_atlas_out(`345')
215
216  tt_do_circle(95.25, i)
217  tt_do_circle(109, `')
218 enddef
219
220 defpart tt_atlas_motor
221  abs cout 200 200 0
222  layer p
223  rel cout bl -40 -40
224  rel cout br -40  40
225  extend bl tl len 100
226  extend br tr len 100
227  join tl -tr 0.1
228 enddef