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
40027a46
Commit
40027a46
authored
Nov 14, 2008
by
dickelbeck
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
more aperture macro stuff
parent
47aace87
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
136 additions
and
37 deletions
+136
-37
gerbview.h
gerbview/gerbview.h
+12
-0
rs274d.cpp
gerbview/rs274d.cpp
+122
-37
rs274x.cpp
gerbview/rs274x.cpp
+2
-0
No files found.
gerbview/gerbview.h
View file @
40027a46
...
...
@@ -179,6 +179,17 @@ struct AM_PRIMITIVE
{
AM_PRIMITIVE_ID
primitive_id
;
///< The primitive type
DCODE_PARAMS
params
;
///< A sequence of parameters used by the primitive
/**
* Function GetExposure
* returns the first parameter in integer form. Some but not all primitives
* use the first parameter as an exposure control.
*/
int
GetExposure
()
{
wxASSERT
(
params
.
size
()
&&
params
[
0
].
IsImmediate
()
);
// we have no D_CODE* for GetValue()
return
(
int
)
params
[
0
].
GetValue
(
NULL
);
}
};
...
...
@@ -290,6 +301,7 @@ inline double DCODE_PARAM::GetValue( const D_CODE* aDcode )
class
GERBER
{
D_CODE
*
m_Aperture_List
[
MAX_TOOLS
];
///< Dcode (Aperture) List for this layer
bool
m_Exposure
;
///< whether an aperture macro tool is flashed on or off
public
:
...
...
gerbview/rs274d.cpp
View file @
40027a46
...
...
@@ -80,22 +80,25 @@ static wxPoint LastPosition;
static
void
Append_1_Line_GERBER
(
int
Dcode_index
,
WinEDA_GerberFrame
*
frame
,
wxDC
*
DC
,
const
wxPoint
&
startpoint
,
const
wxPoint
&
endpoint
,
int
largeur
);
int
largeur
,
bool
isDark
);
static
void
Append_1_Flash_GERBER
(
int
Dcode_index
,
WinEDA_GerberFrame
*
frame
,
wxDC
*
DC
,
const
wxPoint
&
pos
,
const
wxSize
&
size
,
int
forme
);
const
wxPoint
&
pos
,
const
wxSize
&
size
,
int
form
,
bool
isDark
);
static
void
Append_1_Flash_ROND_GERBER
(
int
Dcode_index
,
WinEDA_GerberFrame
*
frame
,
wxDC
*
DC
,
const
wxPoint
&
pos
,
int
diametre
);
const
wxPoint
&
pos
,
int
diameter
,
bool
isDark
);
static
void
Append_1_SEG_ARC_GERBER
(
int
Dcode_index
,
WinEDA_GerberFrame
*
frame
,
wxDC
*
DC
,
const
wxPoint
&
startpoint
,
const
wxPoint
&
endpoint
,
const
wxPoint
&
rel_center
,
int
largeur
,
bool
trigo_sens
,
bool
multiquadrant
);
bool
trigo_sens
,
bool
multiquadrant
,
bool
isDark
);
/****************************************************************/
static
void
Append_1_Flash_ROND_GERBER
(
int
Dcode_tool
,
WinEDA_GerberFrame
*
frame
,
wxDC
*
DC
,
const
wxPoint
&
pos
,
int
diamet
re
)
wxDC
*
DC
,
const
wxPoint
&
pos
,
int
diamet
er
,
bool
isDark
)
/****************************************************************/
/* Trace 1 flash ROND en position pos
...
...
@@ -108,7 +111,7 @@ static void Append_1_Flash_ROND_GERBER( int Dcode_tool,
track
->
Insert
(
frame
->
m_Pcb
,
NULL
);
track
->
SetLayer
(
frame
->
GetScreen
()
->
m_Active_Layer
);
track
->
m_Width
=
diamet
re
;
track
->
m_Width
=
diamet
er
;
track
->
m_Start
=
track
->
m_End
=
pos
;
NEGATE
(
track
->
m_Start
.
y
);
NEGATE
(
track
->
m_End
.
y
);
...
...
@@ -122,7 +125,7 @@ static void Append_1_Flash_ROND_GERBER( int Dcode_tool,
/**********************************************************************/
static
void
Append_1_Flash_GERBER
(
int
Dcode_index
,
WinEDA_GerberFrame
*
frame
,
wxDC
*
DC
,
const
wxPoint
&
pos
,
const
wxSize
&
size
,
int
forme
)
const
wxPoint
&
pos
,
const
wxSize
&
size
,
int
forme
,
bool
isDark
)
/*********************************************************************/
/*
...
...
@@ -172,11 +175,14 @@ static void Append_1_Flash_GERBER( int Dcode_index,
static
void
Append_1_Line_GERBER
(
int
Dcode_index
,
WinEDA_GerberFrame
*
frame
,
wxDC
*
DC
,
const
wxPoint
&
startpoint
,
const
wxPoint
&
endpoint
,
int
largeur
)
int
largeur
,
bool
isDark
)
/********************************************************************/
{
TRACK
*
track
;
// @todo: need to handle isDark = false case. This means using the background color.
// Best way to do this?
track
=
new
TRACK
(
frame
->
m_Pcb
);
track
->
Insert
(
frame
->
m_Pcb
,
NULL
);
...
...
@@ -198,7 +204,7 @@ static void Append_1_SEG_ARC_GERBER( int Dcode_index,
WinEDA_GerberFrame
*
frame
,
wxDC
*
DC
,
const
wxPoint
&
startpoint
,
const
wxPoint
&
endpoint
,
const
wxPoint
&
rel_center
,
int
largeur
,
bool
trigo_sens
,
bool
multiquadrant
)
bool
trigo_sens
,
bool
multiquadrant
,
bool
isDark
)
/*****************************************************************/
/* creation d'un arc:
...
...
@@ -462,7 +468,8 @@ wxPoint GERBER::ReadIJCoord( char*& Text )
{
type_coord
=
*
Text
;
Text
++
;
text
=
line
;
nbchar
=
0
;
text
=
line
;
nbchar
=
0
;
while
(
IsNumber
(
*
Text
)
)
{
if
(
*
Text
==
'.'
)
...
...
@@ -488,7 +495,8 @@ wxPoint GERBER::ReadIJCoord( char*& Text )
int
min_digit
=
(
type_coord
==
'I'
)
?
m_FmtLen
.
x
:
m_FmtLen
.
y
;
while
(
nbchar
<
min_digit
)
{
*
(
text
++
)
=
'0'
;
nbchar
++
;
*
(
text
++
)
=
'0'
;
nbchar
++
;
}
*
text
=
0
;
...
...
@@ -703,6 +711,59 @@ bool GERBER::Execute_G_Command( char*& text, int G_commande )
}
/**
* Function scale
* converts a distance given in floating point to our deci-mils
*/
static
int
scale
(
double
aCoord
,
bool
isMetric
)
{
int
ret
;
if
(
isMetric
)
ret
=
(
int
)
round
(
aCoord
/
0.00254
);
else
ret
=
(
int
)
round
(
aCoord
*
PCB_INTERNAL_UNIT
);
return
ret
;
}
/**
* Function mapPt
* translates a point from the aperture macro coordinate system to our
* deci-mils coordinate system.
* @return wxSize - The gerbview coordinate system vector.
*/
static
wxSize
mapPt
(
double
x
,
double
y
,
bool
isMetric
)
{
wxSize
ret
(
scale
(
x
,
isMetric
),
scale
(
y
,
isMetric
)
);
return
ret
;
}
static
bool
mapExposure
(
int
param1
,
bool
curExposure
)
{
bool
exposure
;
switch
(
param1
)
{
case
0
:
exposure
=
false
;
break
;
default
:
case
1
:
exposure
=
true
;
break
;
case
2
:
exposure
=
!
curExposure
;
}
return
exposure
;
}
/*****************************************************************************/
bool
GERBER
::
Execute_DCODE_Command
(
WinEDA_GerberFrame
*
frame
,
wxDC
*
DC
,
char
*&
text
,
int
D_commande
)
...
...
@@ -713,7 +774,7 @@ bool GERBER::Execute_DCODE_Command( WinEDA_GerberFrame* frame, wxDC* DC,
APERTURE_T
aperture
=
APT_CIRCLE
;
int
dcode
=
0
;
D_CODE
*
pt_T
ool
=
NULL
;
D_CODE
*
t
ool
=
NULL
;
wxString
msg
;
if
(
D_commande
>=
FIRST_DCODE
)
// This is a "Set tool" command
...
...
@@ -721,7 +782,9 @@ bool GERBER::Execute_DCODE_Command( WinEDA_GerberFrame* frame, wxDC* DC,
if
(
D_commande
>
(
MAX_TOOLS
-
1
)
)
D_commande
=
MAX_TOOLS
-
1
;
// remember which tool it selected, nothing is done with it in this call
m_Current_Tool
=
D_commande
;
D_CODE
*
pt_Dcode
=
GetDCODE
(
D_commande
,
false
);
if
(
pt_Dcode
)
pt_Dcode
->
m_InUse
=
TRUE
;
...
...
@@ -739,6 +802,7 @@ bool GERBER::Execute_DCODE_Command( WinEDA_GerberFrame* frame, wxDC* DC,
{
case
1
:
// code D01 Draw line, exposure ON
{
m_Exposure
=
true
;
SEGZONE
*
edge_poly
,
*
last
;
edge_poly
=
new
SEGZONE
(
frame
->
m_Pcb
);
...
...
@@ -763,6 +827,7 @@ bool GERBER::Execute_DCODE_Command( WinEDA_GerberFrame* frame, wxDC* DC,
}
case
2
:
// code D2: exposure OFF (i.e. "move to")
m_Exposure
=
false
;
m_PreviousPos
=
m_CurrentPos
;
m_PolygonFillModeState
=
0
;
break
;
...
...
@@ -775,12 +840,14 @@ bool GERBER::Execute_DCODE_Command( WinEDA_GerberFrame* frame, wxDC* DC,
switch
(
D_commande
)
{
case
1
:
// code D01 Draw line, exposure ON
pt_Tool
=
GetDCODE
(
m_Current_Tool
,
false
);
if
(
pt_Tool
)
m_Exposure
=
true
;
tool
=
GetDCODE
(
m_Current_Tool
,
false
);
if
(
tool
)
{
size
=
pt_T
ool
->
m_Size
;
dcode
=
pt_T
ool
->
m_Num_Dcode
;
aperture
=
pt_T
ool
->
m_Shape
;
size
=
t
ool
->
m_Size
;
dcode
=
t
ool
->
m_Num_Dcode
;
aperture
=
t
ool
->
m_Shape
;
}
switch
(
m_Iterpolation
)
...
...
@@ -789,7 +856,7 @@ bool GERBER::Execute_DCODE_Command( WinEDA_GerberFrame* frame, wxDC* DC,
Append_1_Line_GERBER
(
dcode
,
frame
,
DC
,
m_PreviousPos
,
m_CurrentPos
,
size
.
x
);
size
.
x
,
m_Exposure
^
m_ImageNegative
);
break
;
case
GERB_INTERPOL_LINEAR_01X
:
...
...
@@ -802,14 +869,16 @@ bool GERBER::Execute_DCODE_Command( WinEDA_GerberFrame* frame, wxDC* DC,
Append_1_SEG_ARC_GERBER
(
dcode
,
frame
,
DC
,
m_PreviousPos
,
m_CurrentPos
,
m_IJPos
,
size
.
x
,
FALSE
,
m_360Arc_enbl
);
size
.
x
,
FALSE
,
m_360Arc_enbl
,
m_Exposure
^
m_ImageNegative
);
break
;
case
GERB_INTERPOL_ARC_POS
:
Append_1_SEG_ARC_GERBER
(
dcode
,
frame
,
DC
,
m_PreviousPos
,
m_CurrentPos
,
m_IJPos
,
size
.
x
,
TRUE
,
m_360Arc_enbl
);
size
.
x
,
TRUE
,
m_360Arc_enbl
,
m_Exposure
^
m_ImageNegative
);
break
;
default
:
...
...
@@ -823,16 +892,17 @@ bool GERBER::Execute_DCODE_Command( WinEDA_GerberFrame* frame, wxDC* DC,
break
;
case
2
:
// code D2: exposure OFF (i.e. "move to")
m_Exposure
=
false
;
m_PreviousPos
=
m_CurrentPos
;
break
;
case
3
:
// code D3: flash aperture
pt_T
ool
=
GetDCODE
(
m_Current_Tool
,
false
);
if
(
pt_T
ool
)
t
ool
=
GetDCODE
(
m_Current_Tool
,
false
);
if
(
t
ool
)
{
size
=
pt_T
ool
->
m_Size
;
dcode
=
pt_T
ool
->
m_Num_Dcode
;
aperture
=
pt_T
ool
->
m_Shape
;
size
=
t
ool
->
m_Size
;
dcode
=
t
ool
->
m_Num_Dcode
;
aperture
=
t
ool
->
m_Shape
;
}
switch
(
aperture
)
...
...
@@ -842,47 +912,61 @@ bool GERBER::Execute_DCODE_Command( WinEDA_GerberFrame* frame, wxDC* DC,
Append_1_Flash_ROND_GERBER
(
dcode
,
frame
,
DC
,
m_CurrentPos
,
size
.
x
);
size
.
x
,
true
^
m_ImageNegative
);
break
;
case
APT_OVAL
:
Append_1_Flash_GERBER
(
dcode
,
frame
,
DC
,
m_CurrentPos
,
size
,
PAD_OVAL
);
PAD_OVAL
,
true
^
m_ImageNegative
);
break
;
case
APT_RECT
:
Append_1_Flash_GERBER
(
dcode
,
frame
,
DC
,
m_CurrentPos
,
size
,
PAD_RECT
);
PAD_RECT
,
true
^
m_ImageNegative
);
break
;
case
APT_MACRO
:
{
APERTURE_MACRO
*
macro
=
pt_Tool
->
GetMacro
();
wxPoint
curPos
=
m_CurrentPos
;
APERTURE_MACRO
*
macro
=
tool
->
GetMacro
();
wxASSERT
(
macro
);
// split the macro primitives up into multiple normal TRACK elements
for
(
AM_PRIMITIVES
::
iterator
i
=
macro
->
primitives
.
begin
();
i
!=
macro
->
primitives
.
end
();
++
i
)
for
(
AM_PRIMITIVES
::
iterator
p
=
macro
->
primitives
.
begin
();
p
!=
macro
->
primitives
.
end
();
++
p
)
{
switch
(
i
->
primitive_id
)
bool
exposure
;
switch
(
p
->
primitive_id
)
{
case
AMP_CIRCLE
:
/*
Append_1_Flash_ROND_GERBER( dcode,
frame, DC,
m_CurrentPos,
size.x );
*/
exposure
=
mapExposure
(
p
->
GetExposure
(),
m_Exposure
);
curPos
+=
mapPt
(
p
->
params
[
2
].
GetValue
(
tool
),
p
->
params
[
3
].
GetValue
(
tool
),
m_GerbMetric
);
Append_1_Flash_ROND_GERBER
(
dcode
,
frame
,
DC
,
curPos
,
scale
(
p
->
params
[
1
].
GetValue
(
tool
),
m_GerbMetric
),
// diameter
exposure
^
m_ImageNegative
);
break
;
case
AMP_LINE2
:
case
AMP_LINE20
:
break
;
case
AMP_LINE_CENTER
:
break
;
case
AMP_LINE_LOWER_LEFT
:
exposure
=
mapExposure
(
p
->
GetExposure
(),
m_Exposure
);
curPos
+=
mapPt
(
p
->
params
[
3
].
GetValue
(
tool
),
p
->
params
[
4
].
GetValue
(
tool
),
m_GerbMetric
);
size
=
mapPt
(
p
->
params
[
1
].
GetValue
(
tool
),
p
->
params
[
2
].
GetValue
(
tool
),
m_GerbMetric
);
Append_1_Flash_GERBER
(
dcode
,
frame
,
DC
,
curPos
,
size
,
PAD_RECT
,
exposure
^
m_ImageNegative
);
break
;
case
AMP_EOF
:
case
AMP_OUTLINE
:
case
AMP_POLYGON
:
...
...
@@ -908,3 +992,4 @@ bool GERBER::Execute_DCODE_Command( WinEDA_GerberFrame* frame, wxDC* DC,
return
TRUE
;
}
gerbview/rs274x.cpp
View file @
40027a46
...
...
@@ -486,6 +486,8 @@ bool GERBER::ExecuteRS274XCommand( int command, char buff[GERBER_BUFZ], char*& t
break
;
}
dcode
->
m_Shape
=
APT_MACRO
;
D
(
printf
(
"pam has %d parameters
\n
"
,
pam
->
primitives
.
size
()
);)
dcode
->
SetMacro
(
(
APERTURE_MACRO
*
)
pam
);
...
...
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