Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
K
kicad-source-mirror
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Commits
Open sidebar
Elphel
kicad-source-mirror
Commits
3d9cbb54
Commit
3d9cbb54
authored
Sep 14, 2008
by
charras
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
eeschema: code cleaning
parent
4d7149b1
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
55 additions
and
85 deletions
+55
-85
plot.cpp
eeschema/plot.cpp
+55
-85
No files found.
eeschema/plot.cpp
View file @
3d9cbb54
/************************************************/
/************************************************
***
/
/*
Routine de trace communes aux divers
formats */
/*
Plot functions common to different plot
formats */
/************************************************/
/************************************************
***
/
#include "fctsys.h"
#include "fctsys.h"
#include "gr_basic.h"
#include "gr_basic.h"
...
@@ -14,24 +14,18 @@
...
@@ -14,24 +14,18 @@
#include "protos.h"
#include "protos.h"
/*
Variables loca
les : */
/*
Local Variab
les : */
static
void
PlotSheetLabelStruct
(
Hierarchical_PIN_Sheet_Struct
*
Struct
);
static
void
PlotSheetLabelStruct
(
Hierarchical_PIN_Sheet_Struct
*
Struct
);
static
void
PlotTextField
(
SCH_COMPONENT
*
DrawLibItem
,
static
void
PlotTextField
(
SCH_COMPONENT
*
DrawLibItem
,
int
FieldNumber
,
int
IsMulti
,
int
DrawMode
);
int
FieldNumber
,
int
IsMulti
,
int
DrawMode
);
static
void
PlotPinSymbol
(
int
posX
,
int
posY
,
int
len
,
int
orient
,
int
Shape
);
static
void
PlotPinSymbol
(
const
wxPoint
&
pos
,
int
len
,
int
orient
,
int
Shape
);
/***/
/***/
/*
cte pour remplissage de polygone
s */
/*
Defines for filling polygons in plot polygon function
s */
#define FILL true
#define FILL true
#define NOFILL false
#define NOFILL false
#define PLOT_SHEETREF_MARGIN 0 // margin for sheet refs
/*******************************/
/* Routines de base de trace : */
/*******************************/
/* routine de lever ou baisser de plume.
/* routine de lever ou baisser de plume.
* si plume = 'U' les traces suivants se feront plume levee
* si plume = 'U' les traces suivants se feront plume levee
* si plume = 'D' les traces suivants se feront plume levee
* si plume = 'D' les traces suivants se feront plume levee
...
@@ -89,32 +83,36 @@ void PlotRect( wxPoint p1, wxPoint p2, int fill, int width )
...
@@ -89,32 +83,36 @@ void PlotRect( wxPoint p1, wxPoint p2, int fill, int width )
}
}
}
}
/*******************************************************************************/
/*****************************************************************************************/
void
PlotArc
(
wxPoint
centre
,
int
StAngle
,
int
EndAngle
,
int
rayon
,
bool
fill
,
int
width
)
void
PlotArc
(
wxPoint
aCentre
,
int
aStAngle
,
int
aEndAngle
,
int
aRadius
,
bool
aFill
,
int
aWidth
)
/*******************************************************************************/
/*****************************************************************************************/
/* trace d'un arc de cercle:
/** Function PlotArc
* x, y = coord du centre
* Plot an arc:
* StAngle, EndAngle = angle de debut et fin
* @param aCentre = Arc centre
* rayon = rayon de l'arc
* @param aStAngle = begining of arc in 0.1 degrees
* @param aEndAngle = end of arc in 0.1 degrees
* @param aRadius = Arc radius
* @param aFill = fill option
* @param aWidth = Tickness of outlines
*/
*/
{
{
switch
(
g_PlotFormat
)
switch
(
g_PlotFormat
)
{
{
case
PLOT_FORMAT_HPGL
:
case
PLOT_FORMAT_HPGL
:
PlotArcHPGL
(
centre
,
StAngle
,
EndAngle
,
rayon
,
fill
,
w
idth
);
PlotArcHPGL
(
aCentre
,
aStAngle
,
aEndAngle
,
aRadius
,
aFill
,
aW
idth
);
break
;
break
;
case
PLOT_FORMAT_POST
:
case
PLOT_FORMAT_POST
:
PlotArcPS
(
centre
,
StAngle
,
EndAngle
,
rayon
,
fill
,
w
idth
);
PlotArcPS
(
aCentre
,
aStAngle
,
aEndAngle
,
aRadius
,
aFill
,
aW
idth
);
break
;
break
;
}
}
}
}
/*******************************************************/
/*******************************************************
**********
/
void
PlotCercle
(
wxPoint
pos
,
int
diametre
,
bool
fill
,
int
width
)
void
PlotCercle
(
wxPoint
pos
,
int
diametre
,
bool
fill
,
int
width
)
/*******************************************************/
/*******************************************************
**********
/
{
{
switch
(
g_PlotFormat
)
switch
(
g_PlotFormat
)
{
{
...
@@ -179,12 +177,12 @@ void PlotNoConnectStruct( DrawNoConnectStruct* Struct )
...
@@ -179,12 +177,12 @@ void PlotNoConnectStruct( DrawNoConnectStruct* Struct )
/*************************************************/
/*************************************************/
void
PlotLibPart
(
SCH_COMPONENT
*
DrawLibItem
)
void
PlotLibPart
(
SCH_COMPONENT
*
DrawLibItem
)
/*************************************************/
/*************************************************/
/*
Genere le trace d'un composa
nt */
/*
Polt a compone
nt */
{
{
int
ii
,
x1
,
y1
,
x2
,
y2
,
t1
,
t2
,
*
Poly
,
orient
;
int
ii
,
t1
,
t2
,
*
Poly
,
orient
;
LibEDA_BaseStruct
*
DEntry
;
LibEDA_BaseStruct
*
DEntry
;
EDA_LibComponentStruct
*
Entry
;
EDA_LibComponentStruct
*
Entry
;
int
TransMat
[
2
][
2
],
PartX
,
PartY
,
Multi
,
convert
;
int
TransMat
[
2
][
2
],
Multi
,
convert
;
int
CharColor
=
-
1
;
int
CharColor
=
-
1
;
wxPoint
pos
;
wxPoint
pos
;
bool
draw_bgfill
=
false
;
bool
draw_bgfill
=
false
;
...
@@ -193,7 +191,6 @@ void PlotLibPart( SCH_COMPONENT* DrawLibItem )
...
@@ -193,7 +191,6 @@ void PlotLibPart( SCH_COMPONENT* DrawLibItem )
if
(
Entry
==
NULL
)
if
(
Entry
==
NULL
)
return
;;
return
;;
memcpy
(
TransMat
,
DrawLibItem
->
m_Transform
,
sizeof
(
TransMat
)
);
memcpy
(
TransMat
,
DrawLibItem
->
m_Transform
,
sizeof
(
TransMat
)
);
PartX
=
DrawLibItem
->
m_Pos
.
x
;
PartY
=
DrawLibItem
->
m_Pos
.
y
;
Multi
=
DrawLibItem
->
m_Multi
;
Multi
=
DrawLibItem
->
m_Multi
;
convert
=
DrawLibItem
->
m_Convert
;
convert
=
DrawLibItem
->
m_Convert
;
...
@@ -218,10 +215,7 @@ void PlotLibPart( SCH_COMPONENT* DrawLibItem )
...
@@ -218,10 +215,7 @@ void PlotLibPart( SCH_COMPONENT* DrawLibItem )
{
{
LibDrawArc
*
Arc
=
(
LibDrawArc
*
)
DEntry
;
LibDrawArc
*
Arc
=
(
LibDrawArc
*
)
DEntry
;
t1
=
Arc
->
t1
;
t2
=
Arc
->
t2
;
t1
=
Arc
->
t1
;
t2
=
Arc
->
t2
;
pos
.
x
=
PartX
+
TransMat
[
0
][
0
]
*
Arc
->
m_Pos
.
x
+
pos
=
TransformCoordinate
(
TransMat
,
Arc
->
m_Pos
)
+
DrawLibItem
->
m_Pos
;
TransMat
[
0
][
1
]
*
Arc
->
m_Pos
.
y
;
pos
.
y
=
PartY
+
TransMat
[
1
][
0
]
*
Arc
->
m_Pos
.
x
+
TransMat
[
1
][
1
]
*
Arc
->
m_Pos
.
y
;
MapAngles
(
&
t1
,
&
t2
,
TransMat
);
MapAngles
(
&
t1
,
&
t2
,
TransMat
);
if
(
draw_bgfill
&&
Arc
->
m_Fill
==
FILLED_WITH_BG_BODYCOLOR
)
if
(
draw_bgfill
&&
Arc
->
m_Fill
==
FILLED_WITH_BG_BODYCOLOR
)
{
{
...
@@ -237,11 +231,7 @@ void PlotLibPart( SCH_COMPONENT* DrawLibItem )
...
@@ -237,11 +231,7 @@ void PlotLibPart( SCH_COMPONENT* DrawLibItem )
case
COMPONENT_CIRCLE_DRAW_TYPE
:
case
COMPONENT_CIRCLE_DRAW_TYPE
:
{
{
LibDrawCircle
*
Circle
=
(
LibDrawCircle
*
)
DEntry
;
LibDrawCircle
*
Circle
=
(
LibDrawCircle
*
)
DEntry
;
pos
.
x
=
PartX
+
TransMat
[
0
][
0
]
*
Circle
->
m_Pos
.
x
+
pos
=
TransformCoordinate
(
TransMat
,
Circle
->
m_Pos
)
+
DrawLibItem
->
m_Pos
;
TransMat
[
0
][
1
]
*
Circle
->
m_Pos
.
y
;
pos
.
y
=
PartY
+
TransMat
[
1
][
0
]
*
Circle
->
m_Pos
.
x
+
TransMat
[
1
][
1
]
*
Circle
->
m_Pos
.
y
;
if
(
draw_bgfill
&&
Circle
->
m_Fill
==
FILLED_WITH_BG_BODYCOLOR
)
if
(
draw_bgfill
&&
Circle
->
m_Fill
==
FILLED_WITH_BG_BODYCOLOR
)
{
{
SetColorMapPS
(
ReturnLayerColor
(
LAYER_DEVICE_BACKGROUND
)
);
SetColorMapPS
(
ReturnLayerColor
(
LAYER_DEVICE_BACKGROUND
)
);
...
@@ -260,10 +250,7 @@ void PlotLibPart( SCH_COMPONENT* DrawLibItem )
...
@@ -260,10 +250,7 @@ void PlotLibPart( SCH_COMPONENT* DrawLibItem )
/* The text orientation may need to be flipped if the
/* The text orientation may need to be flipped if the
* transformation matrix causes xy axes to be flipped. */
* transformation matrix causes xy axes to be flipped. */
t1
=
(
TransMat
[
0
][
0
]
!=
0
)
^
(
Text
->
m_Horiz
!=
0
);
t1
=
(
TransMat
[
0
][
0
]
!=
0
)
^
(
Text
->
m_Horiz
!=
0
);
pos
.
x
=
PartX
+
TransMat
[
0
][
0
]
*
Text
->
m_Pos
.
x
pos
=
TransformCoordinate
(
TransMat
,
Text
->
m_Pos
)
+
DrawLibItem
->
m_Pos
;
+
TransMat
[
0
][
1
]
*
Text
->
m_Pos
.
y
;
pos
.
y
=
PartY
+
TransMat
[
1
][
0
]
*
Text
->
m_Pos
.
x
+
TransMat
[
1
][
1
]
*
Text
->
m_Pos
.
y
;
SetCurrentLineWidth
(
-
1
);
SetCurrentLineWidth
(
-
1
);
PlotGraphicText
(
g_PlotFormat
,
pos
,
CharColor
,
PlotGraphicText
(
g_PlotFormat
,
pos
,
CharColor
,
Text
->
m_Text
,
Text
->
m_Text
,
...
@@ -276,23 +263,17 @@ void PlotLibPart( SCH_COMPONENT* DrawLibItem )
...
@@ -276,23 +263,17 @@ void PlotLibPart( SCH_COMPONENT* DrawLibItem )
case
COMPONENT_RECT_DRAW_TYPE
:
case
COMPONENT_RECT_DRAW_TYPE
:
{
{
LibDrawSquare
*
Square
=
(
LibDrawSquare
*
)
DEntry
;
LibDrawSquare
*
Square
=
(
LibDrawSquare
*
)
DEntry
;
x1
=
PartX
+
TransMat
[
0
][
0
]
*
Square
->
m_Pos
.
x
pos
=
TransformCoordinate
(
TransMat
,
Square
->
m_Pos
)
+
DrawLibItem
->
m_Pos
;
+
TransMat
[
0
][
1
]
*
Square
->
m_Pos
.
y
;
wxPoint
end
=
TransformCoordinate
(
TransMat
,
Square
->
m_End
)
+
DrawLibItem
->
m_Pos
;
y1
=
PartY
+
TransMat
[
1
][
0
]
*
Square
->
m_Pos
.
x
+
TransMat
[
1
][
1
]
*
Square
->
m_Pos
.
y
;
x2
=
PartX
+
TransMat
[
0
][
0
]
*
Square
->
m_End
.
x
+
TransMat
[
0
][
1
]
*
Square
->
m_End
.
y
;
y2
=
PartY
+
TransMat
[
1
][
0
]
*
Square
->
m_End
.
x
+
TransMat
[
1
][
1
]
*
Square
->
m_End
.
y
;
if
(
draw_bgfill
&&
Square
->
m_Fill
==
FILLED_WITH_BG_BODYCOLOR
)
if
(
draw_bgfill
&&
Square
->
m_Fill
==
FILLED_WITH_BG_BODYCOLOR
)
{
{
SetColorMapPS
(
ReturnLayerColor
(
LAYER_DEVICE_BACKGROUND
)
);
SetColorMapPS
(
ReturnLayerColor
(
LAYER_DEVICE_BACKGROUND
)
);
PlotRect
(
wxPoint
(
x1
,
y1
),
wxPoint
(
x2
,
y2
)
,
true
,
0
);
PlotRect
(
pos
,
end
,
true
,
0
);
}
}
if
(
(
g_PlotFormat
==
PLOT_FORMAT_POST
)
&&
g_PlotPSColorOpt
)
if
(
(
g_PlotFormat
==
PLOT_FORMAT_POST
)
&&
g_PlotPSColorOpt
)
SetColorMapPS
(
ReturnLayerColor
(
LAYER_DEVICE
)
);
SetColorMapPS
(
ReturnLayerColor
(
LAYER_DEVICE
)
);
PlotRect
(
wxPoint
(
x1
,
y1
),
wxPoint
(
x2
,
y2
)
,
Square
->
m_Fill
==
FILLED_SHAPE
?
true
:
false
,
Square
->
m_Width
);
PlotRect
(
pos
,
end
,
Square
->
m_Fill
==
FILLED_SHAPE
?
true
:
false
,
Square
->
m_Width
);
}
}
break
;
break
;
...
@@ -308,16 +289,12 @@ void PlotLibPart( SCH_COMPONENT* DrawLibItem )
...
@@ -308,16 +289,12 @@ void PlotLibPart( SCH_COMPONENT* DrawLibItem )
/* Calcul de l'orientation reelle de la Pin */
/* Calcul de l'orientation reelle de la Pin */
orient
=
Pin
->
ReturnPinDrawOrient
(
TransMat
);
orient
=
Pin
->
ReturnPinDrawOrient
(
TransMat
);
/* compute Pin Pos */
/* compute Pin Pos */
x2
=
PartX
+
TransMat
[
0
][
0
]
*
Pin
->
m_Pos
.
x
pos
=
TransformCoordinate
(
TransMat
,
Pin
->
m_Pos
)
+
DrawLibItem
->
m_Pos
;
+
TransMat
[
0
][
1
]
*
Pin
->
m_Pos
.
y
;
y2
=
PartY
+
TransMat
[
1
][
0
]
*
Pin
->
m_Pos
.
x
+
TransMat
[
1
][
1
]
*
Pin
->
m_Pos
.
y
;
/* Dessin de la pin et du symbole special associe */
/* Dessin de la pin et du symbole special associe */
SetCurrentLineWidth
(
-
1
);
SetCurrentLineWidth
(
-
1
);
PlotPinSymbol
(
x2
,
y2
,
Pin
->
m_PinLen
,
orient
,
Pin
->
m_PinShape
);
PlotPinSymbol
(
pos
,
Pin
->
m_PinLen
,
orient
,
Pin
->
m_PinShape
);
wxPoint
pinpos
(
x2
,
y2
);
Pin
->
PlotPinTexts
(
pos
,
orient
,
Pin
->
PlotPinTexts
(
pinpos
,
orient
,
Entry
->
m_TextInside
,
Entry
->
m_TextInside
,
Entry
->
m_DrawPinNum
,
Entry
->
m_DrawPinName
);
Entry
->
m_DrawPinNum
,
Entry
->
m_DrawPinName
);
}
}
...
@@ -329,12 +306,11 @@ void PlotLibPart( SCH_COMPONENT* DrawLibItem )
...
@@ -329,12 +306,11 @@ void PlotLibPart( SCH_COMPONENT* DrawLibItem )
Poly
=
(
int
*
)
MyMalloc
(
sizeof
(
int
)
*
2
*
polyline
->
m_CornersCount
);
Poly
=
(
int
*
)
MyMalloc
(
sizeof
(
int
)
*
2
*
polyline
->
m_CornersCount
);
for
(
ii
=
0
;
ii
<
polyline
->
m_CornersCount
;
ii
++
)
for
(
ii
=
0
;
ii
<
polyline
->
m_CornersCount
;
ii
++
)
{
{
Poly
[
ii
*
2
]
=
PartX
+
pos
.
x
=
polyline
->
m_PolyList
[
ii
*
2
];
TransMat
[
0
][
0
]
*
polyline
->
m_PolyList
[
ii
*
2
]
+
pos
.
y
=
polyline
->
m_PolyList
[
ii
*
2
+
1
];
TransMat
[
0
][
1
]
*
polyline
->
m_PolyList
[
ii
*
2
+
1
];
pos
=
TransformCoordinate
(
TransMat
,
pos
)
+
DrawLibItem
->
m_Pos
;
Poly
[
ii
*
2
+
1
]
=
PartY
+
Poly
[
ii
*
2
]
=
pos
.
x
;
TransMat
[
1
][
0
]
*
polyline
->
m_PolyList
[
ii
*
2
]
+
Poly
[
ii
*
2
+
1
]
=
pos
.
y
;
TransMat
[
1
][
1
]
*
polyline
->
m_PolyList
[
ii
*
2
+
1
];
}
}
if
(
draw_bgfill
&&
polyline
->
m_Fill
==
FILLED_WITH_BG_BODYCOLOR
)
if
(
draw_bgfill
&&
polyline
->
m_Fill
==
FILLED_WITH_BG_BODYCOLOR
)
...
@@ -398,8 +374,7 @@ static void PlotTextField( SCH_COMPONENT* DrawLibItem,
...
@@ -398,8 +374,7 @@ static void PlotTextField( SCH_COMPONENT* DrawLibItem,
*/
*/
{
{
int
posX
,
posY
;
/* Position des textes */
wxPoint
textpos
;
/* Position des textes */
int
px
,
py
,
x1
,
y1
;
PartTextStruct
*
Field
=
&
DrawLibItem
->
m_Field
[
FieldNumber
];
PartTextStruct
*
Field
=
&
DrawLibItem
->
m_Field
[
FieldNumber
];
int
hjustify
,
vjustify
;
int
hjustify
,
vjustify
;
int
orient
,
color
=
-
1
;
int
orient
,
color
=
-
1
;
...
@@ -416,14 +391,9 @@ static void PlotTextField( SCH_COMPONENT* DrawLibItem,
...
@@ -416,14 +391,9 @@ static void PlotTextField( SCH_COMPONENT* DrawLibItem,
/* Calcul de la position des textes, selon orientation du composant */
/* Calcul de la position des textes, selon orientation du composant */
orient
=
Field
->
m_Orient
;
orient
=
Field
->
m_Orient
;
hjustify
=
Field
->
m_HJustify
;
vjustify
=
Field
->
m_VJustify
;
hjustify
=
Field
->
m_HJustify
;
vjustify
=
Field
->
m_VJustify
;
posX
=
DrawLibItem
->
m_Pos
.
x
;
posY
=
DrawLibItem
->
m_Pos
.
y
;
textpos
=
Field
->
m_Pos
-
DrawLibItem
->
m_Pos
;
// textpos is the text position relative to the component anchor
x1
=
Field
->
m_Pos
.
x
-
posX
;
y1
=
Field
->
m_Pos
.
y
-
posY
;
px
=
posX
+
(
DrawLibItem
->
m_Transform
[
0
][
0
]
*
x1
)
textpos
=
TransformCoordinate
(
DrawLibItem
->
m_Transform
,
textpos
)
+
DrawLibItem
->
m_Pos
;
+
(
DrawLibItem
->
m_Transform
[
0
][
1
]
*
y1
);
py
=
posY
+
(
DrawLibItem
->
m_Transform
[
1
][
0
]
*
x1
)
+
(
DrawLibItem
->
m_Transform
[
1
][
1
]
*
y1
);
/* Y a t-il rotation */
/* Y a t-il rotation */
if
(
DrawLibItem
->
m_Transform
[
0
][
1
]
)
if
(
DrawLibItem
->
m_Transform
[
0
][
1
]
)
...
@@ -453,18 +423,18 @@ static void PlotTextField( SCH_COMPONENT* DrawLibItem,
...
@@ -453,18 +423,18 @@ static void PlotTextField( SCH_COMPONENT* DrawLibItem,
//not sure what to do here in terms of plotting components that may have multiple REFERENCE entries.
//not sure what to do here in terms of plotting components that may have multiple REFERENCE entries.
if
(
!
IsMulti
||
(
FieldNumber
!=
REFERENCE
)
)
if
(
!
IsMulti
||
(
FieldNumber
!=
REFERENCE
)
)
{
{
PlotGraphicText
(
g_PlotFormat
,
wxPoint
(
px
,
py
)
,
color
,
Field
->
m_Text
,
PlotGraphicText
(
g_PlotFormat
,
textpos
,
color
,
Field
->
m_Text
,
orient
?
TEXT_ORIENT_VERT
:
TEXT_ORIENT_HORIZ
,
orient
?
TEXT_ORIENT_VERT
:
TEXT_ORIENT_HORIZ
,
Field
->
m_Size
,
Field
->
m_Size
,
hjustify
,
vjustify
);
hjustify
,
vjustify
);
}
}
else
/*
Le champ est la reference, et il y a plusieurs parts par boitier
*/
else
/*
We plt the reference, for a multiple parts per package
*/
{
{
/*
On ajoute alors A ou B ... a la
reference */
/*
Adding A, B ... to the
reference */
wxString
Text
;
wxString
Text
;
Text
=
Field
->
m_Text
;
Text
=
Field
->
m_Text
;
Text
.
Append
(
'A'
-
1
+
DrawLibItem
->
m_Multi
);
Text
.
Append
(
'A'
-
1
+
DrawLibItem
->
m_Multi
);
PlotGraphicText
(
g_PlotFormat
,
wxPoint
(
px
,
py
)
,
color
,
Text
,
PlotGraphicText
(
g_PlotFormat
,
textpos
,
color
,
Text
,
orient
?
TEXT_ORIENT_VERT
:
TEXT_ORIENT_HORIZ
,
orient
?
TEXT_ORIENT_VERT
:
TEXT_ORIENT_HORIZ
,
Field
->
m_Size
,
hjustify
,
vjustify
);
Field
->
m_Size
,
hjustify
,
vjustify
);
}
}
...
@@ -472,7 +442,7 @@ static void PlotTextField( SCH_COMPONENT* DrawLibItem,
...
@@ -472,7 +442,7 @@ static void PlotTextField( SCH_COMPONENT* DrawLibItem,
/**************************************************************************/
/**************************************************************************/
static
void
PlotPinSymbol
(
int
posX
,
int
posY
,
int
len
,
int
orient
,
int
Shape
)
static
void
PlotPinSymbol
(
const
wxPoint
&
pos
,
int
len
,
int
orient
,
int
Shape
)
/**************************************************************************/
/**************************************************************************/
/* Trace la pin du symbole en cours de trace
/* Trace la pin du symbole en cours de trace
...
@@ -488,24 +458,24 @@ static void PlotPinSymbol( int posX, int posY, int len, int orient, int Shape )
...
@@ -488,24 +458,24 @@ static void PlotPinSymbol( int posX, int posY, int len, int orient, int Shape )
SetCurrentLineWidth
(
-
1
);
SetCurrentLineWidth
(
-
1
);
MapX1
=
MapY1
=
0
;
x1
=
pos
X
;
y1
=
posY
;
MapX1
=
MapY1
=
0
;
x1
=
pos
.
x
;
y1
=
pos
.
y
;
switch
(
orient
)
switch
(
orient
)
{
{
case
PIN_UP
:
case
PIN_UP
:
y1
=
pos
Y
-
len
;
MapY1
=
1
;
y1
=
pos
.
y
-
len
;
MapY1
=
1
;
break
;
break
;
case
PIN_DOWN
:
case
PIN_DOWN
:
y1
=
pos
Y
+
len
;
MapY1
=
-
1
;
y1
=
pos
.
y
+
len
;
MapY1
=
-
1
;
break
;
break
;
case
PIN_LEFT
:
case
PIN_LEFT
:
x1
=
pos
X
-
len
,
MapX1
=
1
;
x1
=
pos
.
x
-
len
,
MapX1
=
1
;
break
;
break
;
case
PIN_RIGHT
:
case
PIN_RIGHT
:
x1
=
pos
X
+
len
;
MapX1
=
-
1
;
x1
=
pos
.
x
+
len
;
MapX1
=
-
1
;
break
;
break
;
}
}
...
@@ -519,12 +489,12 @@ static void PlotPinSymbol( int posX, int posY, int len, int orient, int Shape )
...
@@ -519,12 +489,12 @@ static void PlotPinSymbol( int posX, int posY, int len, int orient, int Shape )
Move_Plume
(
wxPoint
(
MapX1
*
INVERT_PIN_RADIUS
*
2
+
x1
,
Move_Plume
(
wxPoint
(
MapX1
*
INVERT_PIN_RADIUS
*
2
+
x1
,
MapY1
*
INVERT_PIN_RADIUS
*
2
+
y1
),
'U'
);
MapY1
*
INVERT_PIN_RADIUS
*
2
+
y1
),
'U'
);
Move_Plume
(
wxPoint
(
posX
,
posY
)
,
'D'
);
Move_Plume
(
pos
,
'D'
);
}
}
else
else
{
{
Move_Plume
(
wxPoint
(
x1
,
y1
),
'U'
);
Move_Plume
(
wxPoint
(
x1
,
y1
),
'U'
);
Move_Plume
(
wxPoint
(
posX
,
posY
)
,
'D'
);
Move_Plume
(
pos
,
'D'
);
}
}
if
(
Shape
&
CLOCK
)
if
(
Shape
&
CLOCK
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment