File: gui.html

package info (click to toggle)
fped 0.1%2B201210-1.2
  • links: PTS
  • area: main
  • in suites: bookworm, bullseye
  • size: 968 kB
  • sloc: ansic: 12,651; yacc: 1,112; sh: 974; lex: 204; makefile: 140; awk: 75
file content (282 lines) | stat: -rw-r--r-- 12,522 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
<HTML>
<HEAD>
<TITLE>Fped GUI Manual</TITLE>
</HEAD>
<BODY>
<H1>Fped GUI Manual</H1>

This manual introduces the basic concepts of Fped and explains the elements
of the graphical user interface. Please refer to the file 
<A href="README">README</A> for more
technical details and a discussion of the scripting language used by fped.


<H1>Objects and instances</H1>

Footprints tend to be highly repetitive, with many pads placed in a
simple geometrical pattern. With fped, the user specifies the elements
to repeat and the way they are repeated. Fped then generates the
repetitions automatically.

<H2>Hands-on example</H2>
<P>
Here is a simple example that illustrated the basic steps of constructing
things with fled:
<UL>
  <LI> Start fped without a command-line argument.
  <LI> Right-click on the yellow field that says "(root)" and select
    "Add loop". An entry saying "_ = 0 ... 0 (0)" appears next to the
    yellow field.
    <P><IMG src="manual/intro-1.png">
  <LI> Click on the underscore, type <B>n=1,5</B> and press Enter.
    The entry should now show "n = 1 ... 5 (1 2 3 4 5)"
    <P><IMG src="manual/intro-2.png">
  <LI> Click on the dark-yellow vector icon on the right-hand side.
    A red frame shows that it is selected.
  <LI> Move the mouse pointer to the green dot in the middle of the
    black canvas. A red circle appears when the pointer is over the
    dot.
  <LI> Press the left mouse button, drag a little to the right, and
    release the mouse button. A white line appears and changes
    to dark yellow after the button is released.
  <LI> Click on the yellow line. It is now shown in bright yellow and
    a number of text entry fields appear below the canvas.
    <P><IMG src="manual/intro-3.png">
  <LI> Click into the field on the top that probably says "0.1mm",
    change it to <B>n*1mm</B> and press Enter.
  <LI> Select "Zoom all" from the "View" drop-down menu. The canvas
    should now show the green dot on the left, with a yellow arrow
    pointing to the right, and four more even darker arrows following
    that arrow.
    <P><IMG src="manual/intro-4.png">
  <LI> Click on the icon depicting a light-blue circle.
  <LI> Move the mouse pointer over the green dot, then drag to the
    circle at the end of the vector, and release the mouse button.
    A series of partial circles should appear.
    <P><IMG src="manual/intro-5.png">
  <LI> Select "Zoom all" again to show the full circles.
    <P><IMG src="manual/intro-6.png">
</UL>
The graphical items you have entered are a vector and a circle with the
radius determined by the vector. We call these items "objects". Furthermore,
you have defined a variable that gets set to the values from 1 to 5, in
increments of one. Fped had repeatedly drawn the objects for each such
value. We call the item that have been drawn "instances".
<P>
The innermost vector and circle are highlighted. You can highlight other
instances of the same objects by clicking on the numbers (1 2 3 4 5) shown
next to the loop.

<H2>Conceptual view</H2>
The following picture illustrates the concept: the model is defined in
terms of objects, in this case a vector from the origin to the circle's
center, a vector for the radius, and the circle itself.
<P>
<IMG src="manual/concept-inst.png">
<P>
The vector to the center uses a variable that gets iterated through the
values 0, 1, and 2. For each iteration, an instance is generated.
<P>
Only the instances of silk screen objects and pads are exported to KiCad.
Elements used for construction, such as vectors, only appear in fped.


<H1>Frames</H1>

Frames serve various purposes:
<UL>
  <LI> To structure the footprint drawing by grouping like elements.
    For example, one may want to place pads, outline, and the keep-out
    area in different frames, and probably subdivide some of those 
    constructs even further.
  <LI> To define an element that is used in several places. For example,
    a pad.
  <LI> To define a repetition through a loop or a table.
  <LI> To set variables for child frames. 
</UL>

At the bottom of the hierarchy, we have the root frame. To add another
frame, right-click on the root frame's label "(root)" and select "Add
frame".
<P>
To be able to put items into the new frame, it has to be attached to
the root frame (or to any other frame that's attached). This is called a
<I>frame reference</I>. First, we need a place to attach it to. This
can be the origin of its parent frame or it can be the end of a vector
in the parent frame. To create the frame reference, do this:
<P>
<UL>
  <LI> Click on the parent frame to select it.
  <LI> Press the left mouse button on the frame you wish to reference
    and drag it (move the mouse pointer while keeping the left button
    pressed) into the canvas. When dragging, the mouse cursor changes
    to show a hand.
  <LI> When the mouse pointer is above a suitable point of attachment,
    the point of attachment is highlighted with a red circle and the
    mouse cursor changes to show a hand with a plus sign.
  <LI> At the desired location, release the mouse button.
</UL>

If you wish to cancel the operation, simply release the mouse button at
any place that isn't a point of attachment.


<H1>Variables</H1>


<H1>Iconography</H1>

The right-hand side of the fped window shows the component being drawn on a
black background. We call this the canvas. It is surrounded by a toolbar on
the right side and a few buttons with visibility options at the top.


<H2>The canvas</H2>


<H2>Blue screen</H2>

When an expression uses an unknown variable or evaluates to an incorrect
value (e.g., a bare number where a dimension is expected), the
instantiation fails. Fped indicates this by changing the background color
of the canvas from black to blue. The cause of the failure is explained
in the status bar at the bottom.
<P>
In this state, the canvas is no longer updated when making changes until
the problem has been resolved. The most common causes are a misspelt
variable name in an expression, the use of a number without unit where a
dimension is expected, or the removal of a variable that's still used
somewhere.
<P>
If the location of the error is not obvious, the list of objects can be
shown by selecting "Swap var&amp;code" from the View menu. The object
in which the error occurred is shown in red. If the error occurred in a
loop variable, the variable name is shown in red.


<H2>Visibility options</H2>

When working on a complex component, the number of elements shown can be
overwhelming. The visibility options help to quickly hide irrelevant
details and get one's bearings. They are located in the menu bar at the
top.
<DL>
  <DT><IMG src="manual/all.png">&nbsp;<IMG src="manual/all_off.png"> 
  <DD>Show all frames. If disabled, only show the currently active frame.
  <DT><IMG src="manual/stuff.png">&nbsp;<IMG src="manual/stuff_off.png">
  <DD>Show vectors and frames.
  <DT><IMG src="manual/meas.png">&nbsp;<IMG src="manual/meas_off.png">
  <DD>Show measurements.
  <DT><IMG src="manual/bright.png">&nbsp;<IMG src="manual/bright_off.png">
  <DD>Highlight the elements that will be exported to KiCad, i.e.,
    the pads and the silk screen drawings. To show the component
    exactly as it will appear in KiCad, also turn off vectors,
    frames, and measurements.
</DL>
The visibility options can be combined.


<H2>Tools</H2>

Tools are used to add new elements and to manipulate existing ones.
<DL>
  <DT><IMG src="manual/point.png">
  <DD> The pointer. This is the default tool. The pointer is used to
    select items and do move points of the selected item.
    <P>
    Clicking on an item selects it. If items overlap, the one with the
    highest priority is selected. The priority is based on how difficult
    it usually is to select an item, with frame references having a low
    priority, pads, circles, arcs, rectangles, measurements, and lines
    having increasingly higher priorities. There are a few special cases:
    <UL>
      <LI> The circle at the end of a vector has the highest priority
	while its line has the lowest priority.
      <LI> To select a frame reference, click on the L-shaped upper left
        corner.
      <LI> To select a measurement, click on the line with the text, not
	the (hypothetical) line connecting the points being measured.
    </UL>
    If multiple items are under the mouse pointer, repeatedly clicking
    iterates through them.
    <P>
    To move points, select the item, then move the mouse pointer over
    the point to move. A red circle will appear under the mouse pointer.
    Then drag the point to its new location and release the mouse button.
  <DT><IMG src="manual/delete.png">&nbsp;<IMG src="manual/delete_off.png">
  <DD> Delete the currently selected item. Whenever an item is selected,
    the delete icon lights up. Clicking the icon deletes the item.
    To undelete the item, press <B>U</B>.
  <DT><IMG src="manual/vec.png">
  <DD> Add a vector. To add a new vector, move the mouse pointer to the
    new vector's starting point then drag towards the desired end point.
    Vectors are normally specified via parameters. To enter the parameters,
    click on the new vector.
    <P>
    Note that the starting point of the vector has to be in the same
    frame as the vector being drawn. This limitation also applies to
    points defining pads and silk-screen items.
  <DT><IMG src="manual/pad.png">&nbsp;<IMG src="manual/rpad.png">
  <DD> Add a pad. Pads are either rectangular or rounded. They are
    defined by two points which are opposite corners of the rectangle
    containing the pad. Move the mouse cursor to the first point, then
    drag to the second point. The pad's name can be edited after selecting
    the pad.
  <DT><IMG src="manual/hole.png">
  <DD> Add a hole. There are two purposes for holes:
    <UL>
      <LI> Pins of through-hole components. In this case, the hole has to be
	inside a pad.
      <LI> Mechanical support. In this case, the hole has to be outside any
       pads.
    </UL>
    The construction of holes is the same as for pads.
  <DT><IMG src="manual/line.png">&nbsp;<IMG src="manual/rect.png">
  <DD> Add a line or a rectangle. Similar to pads, lines and rectangles
    are defined by two points. The width of the line can be edited after
    selecting the line or rectangle.
  <DT><IMG src="manual/circ.png">
  <DD> Add circle or arc. Circles are defined by their center end a
    point at their radius. An arc has a third point, which defines the
    angle at which the arc ends. If this third point is not located on
    the radius, the arc ends where an imaginary line between the center
    and the end point would intersect with the radius.
    <P>
    An arc is made by first drawing a circle with the radius point at
    the location where the arc should start. Then click and hold the
    radius point to drag the end point to the desired location.
    <P>
    To change the radius point of a circle, first drag the end point,
    then drag the radius point itself to that same location.
  <DT><IMG src="manual/meas.png">&nbsp;<IMG src="manual/meas_x.png">&nbsp;
    <IMG src="manual/meas_y.png">
  <DD> Add a measurement. Measurements show the distance between points.
    They can either measure diagonally or only horizontally or only vertically.
    Unlike other items, measurements are not limited to points in the same
    frame. Instead, they operate on the minimum, maximum, and next greater
    coordinates of instances of objects.
    <P>
    A measurement is added as follows:
    <UL>
      <LI> Click on one of the three measurement icons to select the 
	measurement type. All possible endpoints are highlighted.
      <LI> Drag from the desired starting point. Now all the endpoints
	available for this starting point are highlighted.
      <LI> Drag to the endpoint and release the mouse button. The measurement
	will now appear as a double-headed arrow and text between the two
	points (if this is a diagonal measurement) or extending vertically or
	horizontally from one of the two points.
      <LI> To move the measurement arrow away from the two points, select
	the measurement and set an offset.
    </UL>
    Sometimes, the second point becomes unavailable after selecting the
    first point. This means that the two points are not a minimum or maximum,
    or a minimum and the next greater neighbour. In this case, just try
    another pair of points measuring the same distance.
</DL>


<H1>Keyboard shortcuts</H1>

</BODY>
</HTML>