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
4a739403
Commit
4a739403
authored
Feb 27, 2012
by
Wayne Stambaugh
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Minor Eeschema LIB_ITEM object improvements.
parent
07e5eee1
Changes
19
Show whitespace changes
Inline
Side-by-side
Showing
19 changed files
with
620 additions
and
290 deletions
+620
-290
dialog_edit_one_field.cpp
eeschema/dialogs/dialog_edit_one_field.cpp
+1
-1
lib_arc.cpp
eeschema/lib_arc.cpp
+9
-10
lib_arc.h
eeschema/lib_arc.h
+60
-15
lib_bezier.cpp
eeschema/lib_bezier.cpp
+10
-11
lib_bezier.h
eeschema/lib_bezier.h
+61
-17
lib_circle.cpp
eeschema/lib_circle.cpp
+9
-10
lib_circle.h
eeschema/lib_circle.h
+60
-16
lib_draw_item.cpp
eeschema/lib_draw_item.cpp
+3
-3
lib_draw_item.h
eeschema/lib_draw_item.h
+57
-73
lib_field.cpp
eeschema/lib_field.cpp
+10
-11
lib_field.h
eeschema/lib_field.h
+60
-16
lib_pin.cpp
eeschema/lib_pin.cpp
+11
-12
lib_pin.h
eeschema/lib_pin.h
+60
-15
lib_polyline.cpp
eeschema/lib_polyline.cpp
+10
-11
lib_polyline.h
eeschema/lib_polyline.h
+60
-16
lib_rectangle.cpp
eeschema/lib_rectangle.cpp
+9
-10
lib_rectangle.h
eeschema/lib_rectangle.h
+60
-16
lib_text.cpp
eeschema/lib_text.cpp
+10
-11
lib_text.h
eeschema/lib_text.h
+60
-16
No files found.
eeschema/dialogs/dialog_edit_one_field.cpp
View file @
4a739403
/**
/**
* @file dialog_
lib_
edit_one_field.cpp
* @file dialog_edit_one_field.cpp
* @brief dialog to editing a field ( not a graphic text) in current component.
* @brief dialog to editing a field ( not a graphic text) in current component.
*/
*/
...
...
eeschema/lib_arc.cpp
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -228,7 +227,7 @@ EDA_ITEM* LIB_ARC::doClone() const
...
@@ -228,7 +227,7 @@ EDA_ITEM* LIB_ARC::doClone() const
}
}
int
LIB_ARC
::
DoC
ompare
(
const
LIB_ITEM
&
aOther
)
const
int
LIB_ARC
::
c
ompare
(
const
LIB_ITEM
&
aOther
)
const
{
{
wxASSERT
(
aOther
.
Type
()
==
LIB_ARC_T
);
wxASSERT
(
aOther
.
Type
()
==
LIB_ARC_T
);
...
@@ -250,7 +249,7 @@ int LIB_ARC::DoCompare( const LIB_ITEM& aOther ) const
...
@@ -250,7 +249,7 @@ int LIB_ARC::DoCompare( const LIB_ITEM& aOther ) const
}
}
void
LIB_ARC
::
Do
Offset
(
const
wxPoint
&
aOffset
)
void
LIB_ARC
::
Set
Offset
(
const
wxPoint
&
aOffset
)
{
{
m_Pos
+=
aOffset
;
m_Pos
+=
aOffset
;
m_ArcStart
+=
aOffset
;
m_ArcStart
+=
aOffset
;
...
@@ -258,14 +257,14 @@ void LIB_ARC::DoOffset( const wxPoint& aOffset )
...
@@ -258,14 +257,14 @@ void LIB_ARC::DoOffset( const wxPoint& aOffset )
}
}
bool
LIB_ARC
::
DoTest
Inside
(
EDA_RECT
&
aRect
)
const
bool
LIB_ARC
::
Inside
(
EDA_RECT
&
aRect
)
const
{
{
return
aRect
.
Contains
(
m_ArcStart
.
x
,
-
m_ArcStart
.
y
)
return
aRect
.
Contains
(
m_ArcStart
.
x
,
-
m_ArcStart
.
y
)
||
aRect
.
Contains
(
m_ArcEnd
.
x
,
-
m_ArcEnd
.
y
);
||
aRect
.
Contains
(
m_ArcEnd
.
x
,
-
m_ArcEnd
.
y
);
}
}
void
LIB_ARC
::
Do
Move
(
const
wxPoint
&
aPosition
)
void
LIB_ARC
::
Move
(
const
wxPoint
&
aPosition
)
{
{
wxPoint
offset
=
aPosition
-
m_Pos
;
wxPoint
offset
=
aPosition
-
m_Pos
;
m_Pos
=
aPosition
;
m_Pos
=
aPosition
;
...
@@ -274,7 +273,7 @@ void LIB_ARC::DoMove( const wxPoint& aPosition )
...
@@ -274,7 +273,7 @@ void LIB_ARC::DoMove( const wxPoint& aPosition )
}
}
void
LIB_ARC
::
Do
MirrorHorizontal
(
const
wxPoint
&
aCenter
)
void
LIB_ARC
::
MirrorHorizontal
(
const
wxPoint
&
aCenter
)
{
{
m_Pos
.
x
-=
aCenter
.
x
;
m_Pos
.
x
-=
aCenter
.
x
;
m_Pos
.
x
*=
-
1
;
m_Pos
.
x
*=
-
1
;
...
@@ -288,7 +287,7 @@ void LIB_ARC::DoMirrorHorizontal( const wxPoint& aCenter )
...
@@ -288,7 +287,7 @@ void LIB_ARC::DoMirrorHorizontal( const wxPoint& aCenter )
EXCHG
(
m_ArcStart
,
m_ArcEnd
);
EXCHG
(
m_ArcStart
,
m_ArcEnd
);
}
}
void
LIB_ARC
::
Do
MirrorVertical
(
const
wxPoint
&
aCenter
)
void
LIB_ARC
::
MirrorVertical
(
const
wxPoint
&
aCenter
)
{
{
m_Pos
.
y
-=
aCenter
.
y
;
m_Pos
.
y
-=
aCenter
.
y
;
m_Pos
.
y
*=
-
1
;
m_Pos
.
y
*=
-
1
;
...
@@ -302,7 +301,7 @@ void LIB_ARC::DoMirrorVertical( const wxPoint& aCenter )
...
@@ -302,7 +301,7 @@ void LIB_ARC::DoMirrorVertical( const wxPoint& aCenter )
EXCHG
(
m_ArcStart
,
m_ArcEnd
);
EXCHG
(
m_ArcStart
,
m_ArcEnd
);
}
}
void
LIB_ARC
::
Do
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
)
void
LIB_ARC
::
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
)
{
{
int
rot_angle
=
aRotateCCW
?
-
900
:
900
;
int
rot_angle
=
aRotateCCW
?
-
900
:
900
;
RotatePoint
(
&
m_Pos
,
aCenter
,
rot_angle
);
RotatePoint
(
&
m_Pos
,
aCenter
,
rot_angle
);
...
@@ -312,7 +311,7 @@ void LIB_ARC::DoRotate( const wxPoint& aCenter, bool aRotateCCW )
...
@@ -312,7 +311,7 @@ void LIB_ARC::DoRotate( const wxPoint& aCenter, bool aRotateCCW )
void
LIB_ARC
::
Do
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
void
LIB_ARC
::
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
)
const
TRANSFORM
&
aTransform
)
{
{
wxASSERT
(
aPlotter
!=
NULL
);
wxASSERT
(
aPlotter
!=
NULL
);
...
...
eeschema/lib_arc.h
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -148,34 +147,80 @@ public:
...
@@ -148,34 +147,80 @@ public:
*/
*/
void
EndEdit
(
const
wxPoint
&
aPosition
,
bool
aAbort
=
false
);
void
EndEdit
(
const
wxPoint
&
aPosition
,
bool
aAbort
=
false
);
/**
* @copydoc LIB_ITEM::SetOffset(const wxPoint&)
*/
virtual
void
SetOffset
(
const
wxPoint
&
aOffset
);
/**
* @copydoc LIB_ITEM::Inside()
*/
virtual
bool
Inside
(
EDA_RECT
&
aRect
)
const
;
/**
* @copydoc LIB_ITEM::Move()
*/
virtual
void
Move
(
const
wxPoint
&
aPosition
);
/**
* @copydoc LIB_ITEM::GetPosition()
*/
virtual
wxPoint
GetPosition
()
const
{
return
m_Pos
;
}
/**
* @copydoc LIB_ITEM::MirrorHorizontal()
*/
virtual
void
MirrorHorizontal
(
const
wxPoint
&
aCenter
);
/**
* @copydoc LIB_ITEM::MirrorVertical()
*/
virtual
void
MirrorVertical
(
const
wxPoint
&
aCenter
);
/**
* @copydoc LIB_ITEM::Rotate(const wxPoint&,bool)
*/
virtual
void
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
);
/**
* @copydoc LIB_ITEM::Plot()
*/
virtual
void
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
);
/**
* @copydoc LIB_ITEM::GetWidth()
*/
virtual
int
GetWidth
()
const
{
return
m_Width
;
}
/**
* @copydoc LIB_ITEM::SetWidth()
*/
virtual
void
SetWidth
(
int
aWidth
)
{
m_Width
=
aWidth
;
}
virtual
wxString
GetSelectMenuText
()
const
;
virtual
wxString
GetSelectMenuText
()
const
;
virtual
BITMAP_DEF
GetMenuImage
()
const
{
return
add_arc_xpm
;
}
virtual
BITMAP_DEF
GetMenuImage
()
const
{
return
add_arc_xpm
;
}
pr
otected
:
pr
ivate
:
virtual
EDA_ITEM
*
doClone
()
const
;
virtual
EDA_ITEM
*
doClone
()
const
;
/**
/**
* Provide the arc draw object specific comparison.
* Function compare
* provides the arc draw object specific comparison.
*
*
* The sort order is as follows:
* The sort order is as follows:
* - Arc horizontal (X) position.
* - Arc horizontal (X) position.
* - Arc vertical (Y) position.
* - Arc vertical (Y) position.
* - Arc start angle.
* - Arc start angle.
* - Arc end angle.
* - Arc end angle.
*
* @param aOther A reference to the other #LIB_ITEM to compare the arc against.
* @return An integer value less than 0 if the arc is less than \a aOther, zero
* if the arc is equal to \a aOther, or greater than 0 if the arc is
* greater than \a aOther.
*/
*/
virtual
int
DoCompare
(
const
LIB_ITEM
&
aOther
)
const
;
virtual
int
compare
(
const
LIB_ITEM
&
aOther
)
const
;
virtual
void
DoOffset
(
const
wxPoint
&
aOffset
);
virtual
bool
DoTestInside
(
EDA_RECT
&
aRect
)
const
;
virtual
void
DoMove
(
const
wxPoint
&
aPosition
);
virtual
wxPoint
DoGetPosition
()
const
{
return
m_Pos
;
}
virtual
void
DoMirrorHorizontal
(
const
wxPoint
&
aCenter
);
virtual
void
DoMirrorVertical
(
const
wxPoint
&
aCenter
);
virtual
void
DoRotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
);
virtual
void
DoPlot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
);
virtual
int
DoGetWidth
()
const
{
return
m_Width
;
}
virtual
void
DoSetWidth
(
int
aWidth
)
{
m_Width
=
aWidth
;
}
};
};
...
...
eeschema/lib_bezier.cpp
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -139,7 +138,7 @@ EDA_ITEM* LIB_BEZIER::doClone() const
...
@@ -139,7 +138,7 @@ EDA_ITEM* LIB_BEZIER::doClone() const
}
}
int
LIB_BEZIER
::
DoC
ompare
(
const
LIB_ITEM
&
aOther
)
const
int
LIB_BEZIER
::
c
ompare
(
const
LIB_ITEM
&
aOther
)
const
{
{
wxASSERT
(
aOther
.
Type
()
==
LIB_BEZIER_T
);
wxASSERT
(
aOther
.
Type
()
==
LIB_BEZIER_T
);
...
@@ -161,7 +160,7 @@ int LIB_BEZIER::DoCompare( const LIB_ITEM& aOther ) const
...
@@ -161,7 +160,7 @@ int LIB_BEZIER::DoCompare( const LIB_ITEM& aOther ) const
}
}
void
LIB_BEZIER
::
Do
Offset
(
const
wxPoint
&
aOffset
)
void
LIB_BEZIER
::
Set
Offset
(
const
wxPoint
&
aOffset
)
{
{
size_t
i
;
size_t
i
;
...
@@ -173,7 +172,7 @@ void LIB_BEZIER::DoOffset( const wxPoint& aOffset )
...
@@ -173,7 +172,7 @@ void LIB_BEZIER::DoOffset( const wxPoint& aOffset )
}
}
bool
LIB_BEZIER
::
DoTest
Inside
(
EDA_RECT
&
aRect
)
const
bool
LIB_BEZIER
::
Inside
(
EDA_RECT
&
aRect
)
const
{
{
for
(
size_t
i
=
0
;
i
<
m_PolyPoints
.
size
();
i
++
)
for
(
size_t
i
=
0
;
i
<
m_PolyPoints
.
size
();
i
++
)
{
{
...
@@ -185,13 +184,13 @@ bool LIB_BEZIER::DoTestInside( EDA_RECT& aRect ) const
...
@@ -185,13 +184,13 @@ bool LIB_BEZIER::DoTestInside( EDA_RECT& aRect ) const
}
}
void
LIB_BEZIER
::
Do
Move
(
const
wxPoint
&
aPosition
)
void
LIB_BEZIER
::
Move
(
const
wxPoint
&
aPosition
)
{
{
Do
Offset
(
aPosition
-
m_PolyPoints
[
0
]
);
Set
Offset
(
aPosition
-
m_PolyPoints
[
0
]
);
}
}
void
LIB_BEZIER
::
Do
MirrorHorizontal
(
const
wxPoint
&
aCenter
)
void
LIB_BEZIER
::
MirrorHorizontal
(
const
wxPoint
&
aCenter
)
{
{
size_t
i
,
imax
=
m_PolyPoints
.
size
();
size_t
i
,
imax
=
m_PolyPoints
.
size
();
...
@@ -212,7 +211,7 @@ void LIB_BEZIER::DoMirrorHorizontal( const wxPoint& aCenter )
...
@@ -212,7 +211,7 @@ void LIB_BEZIER::DoMirrorHorizontal( const wxPoint& aCenter )
}
}
}
}
void
LIB_BEZIER
::
Do
MirrorVertical
(
const
wxPoint
&
aCenter
)
void
LIB_BEZIER
::
MirrorVertical
(
const
wxPoint
&
aCenter
)
{
{
size_t
i
,
imax
=
m_PolyPoints
.
size
();
size_t
i
,
imax
=
m_PolyPoints
.
size
();
...
@@ -233,7 +232,7 @@ void LIB_BEZIER::DoMirrorVertical( const wxPoint& aCenter )
...
@@ -233,7 +232,7 @@ void LIB_BEZIER::DoMirrorVertical( const wxPoint& aCenter )
}
}
}
}
void
LIB_BEZIER
::
Do
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
)
void
LIB_BEZIER
::
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
)
{
{
int
rot_angle
=
aRotateCCW
?
-
900
:
900
;
int
rot_angle
=
aRotateCCW
?
-
900
:
900
;
...
@@ -253,7 +252,7 @@ void LIB_BEZIER::DoRotate( const wxPoint& aCenter, bool aRotateCCW )
...
@@ -253,7 +252,7 @@ void LIB_BEZIER::DoRotate( const wxPoint& aCenter, bool aRotateCCW )
}
}
void
LIB_BEZIER
::
Do
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
void
LIB_BEZIER
::
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
)
const
TRANSFORM
&
aTransform
)
{
{
wxASSERT
(
aPlotter
!=
NULL
);
wxASSERT
(
aPlotter
!=
NULL
);
...
...
eeschema/lib_bezier.h
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -75,6 +74,11 @@ public:
...
@@ -75,6 +74,11 @@ public:
void
AddPoint
(
const
wxPoint
&
aPoint
);
void
AddPoint
(
const
wxPoint
&
aPoint
);
/**
* @copydoc LIB_ITEM::SetOffset(const wxPoint&)
*/
virtual
void
SetOffset
(
const
wxPoint
&
aOffset
);
/**
/**
* @return the number of corners
* @return the number of corners
*/
*/
...
@@ -102,6 +106,52 @@ public:
...
@@ -102,6 +106,52 @@ public:
*/
*/
virtual
EDA_RECT
GetBoundingBox
()
const
;
virtual
EDA_RECT
GetBoundingBox
()
const
;
/**
* @copydoc LIB_ITEM::Inside()
*/
virtual
bool
Inside
(
EDA_RECT
&
aRect
)
const
;
/**
* @copydoc LIB_ITEM::Move()
*/
virtual
void
Move
(
const
wxPoint
&
aPosition
);
/**
* @copydoc LIB_ITEM::GetPosition()
*/
virtual
wxPoint
GetPosition
()
const
{
return
m_PolyPoints
[
0
];
}
/**
* @copydoc LIB_ITEM::MirrorHorizontal()
*/
virtual
void
MirrorHorizontal
(
const
wxPoint
&
aCenter
);
/**
* @copydoc LIB_ITEM::MirrorVertical()
*/
virtual
void
MirrorVertical
(
const
wxPoint
&
aCenter
);
/**
* @copydoc LIB_ITEM::Rotate(const wxPoint&,bool)
*/
virtual
void
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
);
/**
* @copydoc LIB_ITEM::Plot()
*/
virtual
void
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
);
/**
* @copydoc LIB_ITEM::GetWidth()
*/
virtual
int
GetWidth
()
const
{
return
m_Width
;
}
/**
* @copydoc LIB_ITEM::SetWidth()
*/
virtual
void
SetWidth
(
int
aWidth
)
{
m_Width
=
aWidth
;
}
/**
/**
* Function GetPenSize
* Function GetPenSize
* @return the size of the "pen" that be used to draw or plot this item
* @return the size of the "pen" that be used to draw or plot this item
...
@@ -110,29 +160,23 @@ public:
...
@@ -110,29 +160,23 @@ public:
virtual
void
DisplayInfo
(
EDA_DRAW_FRAME
*
aFrame
);
virtual
void
DisplayInfo
(
EDA_DRAW_FRAME
*
aFrame
);
pr
otected
:
pr
ivate
:
virtual
EDA_ITEM
*
doClone
()
const
;
virtual
EDA_ITEM
*
doClone
()
const
;
/**
/**
* Provide the bezier curve draw object specific comparison.
* Function compare
* provides the bezier curve draw object specific comparison.
*
*
* The sort order for each bezier curve segment point is as follows:
* The sort order for each bezier curve segment point is as follows:
* - Bezier point horizontal (X) point position.
* - Bezier point horizontal (X) point position.
* - Bezier point vertical (Y) point position.
* - Bezier point vertical (Y) point position.
*
* @param aOther A reference to the other #LIB_ITEM to compare the bezier curve against.
* @return An integer value less than 0 if the bezier curve is less than \a aOther, zero
* if the bezier curve is equal to \a aOther, or greater than 0 if the bezier
* curve is greater than \a aOther.
*/
*/
virtual
int
DoCompare
(
const
LIB_ITEM
&
aOther
)
const
;
virtual
int
compare
(
const
LIB_ITEM
&
aOther
)
const
;
virtual
void
DoOffset
(
const
wxPoint
&
aOffset
);
virtual
bool
DoTestInside
(
EDA_RECT
&
aRect
)
const
;
virtual
void
DoMove
(
const
wxPoint
&
aPosition
);
virtual
wxPoint
DoGetPosition
()
const
{
return
m_PolyPoints
[
0
];
}
virtual
void
DoMirrorHorizontal
(
const
wxPoint
&
aCenter
);
virtual
void
DoMirrorVertical
(
const
wxPoint
&
aCenter
);
virtual
void
DoRotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
);
virtual
void
DoPlot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
);
virtual
int
DoGetWidth
()
const
{
return
m_Width
;
}
virtual
void
DoSetWidth
(
int
aWidth
)
{
m_Width
=
aWidth
;
}
};
};
...
...
eeschema/lib_circle.cpp
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -121,7 +120,7 @@ EDA_ITEM* LIB_CIRCLE::doClone() const
...
@@ -121,7 +120,7 @@ EDA_ITEM* LIB_CIRCLE::doClone() const
}
}
int
LIB_CIRCLE
::
DoC
ompare
(
const
LIB_ITEM
&
aOther
)
const
int
LIB_CIRCLE
::
c
ompare
(
const
LIB_ITEM
&
aOther
)
const
{
{
wxASSERT
(
aOther
.
Type
()
==
LIB_CIRCLE_T
);
wxASSERT
(
aOther
.
Type
()
==
LIB_CIRCLE_T
);
...
@@ -140,13 +139,13 @@ int LIB_CIRCLE::DoCompare( const LIB_ITEM& aOther ) const
...
@@ -140,13 +139,13 @@ int LIB_CIRCLE::DoCompare( const LIB_ITEM& aOther ) const
}
}
void
LIB_CIRCLE
::
Do
Offset
(
const
wxPoint
&
aOffset
)
void
LIB_CIRCLE
::
Set
Offset
(
const
wxPoint
&
aOffset
)
{
{
m_Pos
+=
aOffset
;
m_Pos
+=
aOffset
;
}
}
bool
LIB_CIRCLE
::
DoTest
Inside
(
EDA_RECT
&
aRect
)
const
bool
LIB_CIRCLE
::
Inside
(
EDA_RECT
&
aRect
)
const
{
{
/*
/*
* FIXME: This fails to take into account the radius around the center
* FIXME: This fails to take into account the radius around the center
...
@@ -156,13 +155,13 @@ bool LIB_CIRCLE::DoTestInside( EDA_RECT& aRect ) const
...
@@ -156,13 +155,13 @@ bool LIB_CIRCLE::DoTestInside( EDA_RECT& aRect ) const
}
}
void
LIB_CIRCLE
::
Do
Move
(
const
wxPoint
&
aPosition
)
void
LIB_CIRCLE
::
Move
(
const
wxPoint
&
aPosition
)
{
{
m_Pos
=
aPosition
;
m_Pos
=
aPosition
;
}
}
void
LIB_CIRCLE
::
Do
MirrorHorizontal
(
const
wxPoint
&
aCenter
)
void
LIB_CIRCLE
::
MirrorHorizontal
(
const
wxPoint
&
aCenter
)
{
{
m_Pos
.
x
-=
aCenter
.
x
;
m_Pos
.
x
-=
aCenter
.
x
;
m_Pos
.
x
*=
-
1
;
m_Pos
.
x
*=
-
1
;
...
@@ -170,7 +169,7 @@ void LIB_CIRCLE::DoMirrorHorizontal( const wxPoint& aCenter )
...
@@ -170,7 +169,7 @@ void LIB_CIRCLE::DoMirrorHorizontal( const wxPoint& aCenter )
}
}
void
LIB_CIRCLE
::
Do
MirrorVertical
(
const
wxPoint
&
aCenter
)
void
LIB_CIRCLE
::
MirrorVertical
(
const
wxPoint
&
aCenter
)
{
{
m_Pos
.
y
-=
aCenter
.
y
;
m_Pos
.
y
-=
aCenter
.
y
;
m_Pos
.
y
*=
-
1
;
m_Pos
.
y
*=
-
1
;
...
@@ -178,7 +177,7 @@ void LIB_CIRCLE::DoMirrorVertical( const wxPoint& aCenter )
...
@@ -178,7 +177,7 @@ void LIB_CIRCLE::DoMirrorVertical( const wxPoint& aCenter )
}
}
void
LIB_CIRCLE
::
Do
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
)
void
LIB_CIRCLE
::
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
)
{
{
int
rot_angle
=
aRotateCCW
?
-
900
:
900
;
int
rot_angle
=
aRotateCCW
?
-
900
:
900
;
...
@@ -186,7 +185,7 @@ void LIB_CIRCLE::DoRotate( const wxPoint& aCenter, bool aRotateCCW )
...
@@ -186,7 +185,7 @@ void LIB_CIRCLE::DoRotate( const wxPoint& aCenter, bool aRotateCCW )
}
}
void
LIB_CIRCLE
::
Do
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
void
LIB_CIRCLE
::
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
)
const
TRANSFORM
&
aTransform
)
{
{
wxPoint
pos
=
aTransform
.
TransformCoordinate
(
m_Pos
)
+
aOffset
;
wxPoint
pos
=
aTransform
.
TransformCoordinate
(
m_Pos
)
+
aOffset
;
...
...
eeschema/lib_circle.h
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -118,34 +117,79 @@ public:
...
@@ -118,34 +117,79 @@ public:
*/
*/
void
EndEdit
(
const
wxPoint
&
aPosition
,
bool
aAbort
=
false
);
void
EndEdit
(
const
wxPoint
&
aPosition
,
bool
aAbort
=
false
);
/**
* @copydoc LIB_ITEM::SetOffset(const wxPoint&)
*/
virtual
void
SetOffset
(
const
wxPoint
&
aOffset
);
/**
* @copydoc LIB_ITEM::Inside()
*/
virtual
bool
Inside
(
EDA_RECT
&
aRect
)
const
;
/**
* @copydoc LIB_ITEM::Move()
*/
virtual
void
Move
(
const
wxPoint
&
aPosition
);
/**
* @copydoc LIB_ITEM::GetPosition()
*/
virtual
wxPoint
GetPosition
()
const
{
return
m_Pos
;
}
/**
* @copydoc LIB_ITEM::MirrorHorizontal()
*/
virtual
void
MirrorHorizontal
(
const
wxPoint
&
aCenter
);
/**
* @copydoc LIB_ITEM::MirrorVertical()
*/
virtual
void
MirrorVertical
(
const
wxPoint
&
aCenter
);
/**
* @copydoc LIB_ITEM::Rotate(const wxPoint&,bool)
*/
virtual
void
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
);
/**
* @copydoc LIB_ITEM::Plot()
*/
virtual
void
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
);
/**
* @copydoc LIB_ITEM::GetWidth()
*/
virtual
int
GetWidth
()
const
{
return
m_Width
;
}
/**
* @copydoc LIB_ITEM::SetWidth()
*/
virtual
void
SetWidth
(
int
aWidth
)
{
m_Width
=
aWidth
;
}
virtual
wxString
GetSelectMenuText
()
const
;
virtual
wxString
GetSelectMenuText
()
const
;
virtual
BITMAP_DEF
GetMenuImage
()
const
{
return
add_circle_xpm
;
}
virtual
BITMAP_DEF
GetMenuImage
()
const
{
return
add_circle_xpm
;
}
pr
otected
:
pr
ivate
:
virtual
EDA_ITEM
*
doClone
()
const
;
virtual
EDA_ITEM
*
doClone
()
const
;
/**
/**
* Provide the circle draw object specific comparison.
* Function compare
* provides the circle draw object specific comparison.
*
*
* The sort order is as follows:
* The sort order is as follows:
* - Circle horizontal (X) position.
* - Circle horizontal (X) position.
* - Circle vertical (Y) position.
* - Circle vertical (Y) position.
* - Circle radius.
* - Circle radius.
*
* @param aOther A reference to the other #LIB_ITEM to compare the circle against.
* @return An integer value less than 0 if the circle is less than \a aOther, zero
* if the circle is equal to \a aOther, or greater than 0 if the circle is
* greater than \a aOther.
*/
*/
virtual
int
DoCompare
(
const
LIB_ITEM
&
aOther
)
const
;
virtual
int
compare
(
const
LIB_ITEM
&
aOther
)
const
;
virtual
void
DoOffset
(
const
wxPoint
&
aOffset
);
virtual
bool
DoTestInside
(
EDA_RECT
&
aRect
)
const
;
virtual
void
DoMove
(
const
wxPoint
&
aPosition
);
virtual
wxPoint
DoGetPosition
()
const
{
return
m_Pos
;
}
virtual
void
DoMirrorHorizontal
(
const
wxPoint
&
aCenter
);
virtual
void
DoMirrorVertical
(
const
wxPoint
&
aCenter
);
virtual
void
DoRotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
);
virtual
void
DoPlot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
);
virtual
int
DoGetWidth
()
const
{
return
m_Width
;
}
virtual
void
DoSetWidth
(
int
aWidth
)
{
m_Width
=
aWidth
;
}
};
};
...
...
eeschema/lib_draw_item.cpp
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -90,7 +89,7 @@ bool LIB_ITEM::operator==( const LIB_ITEM& aOther ) const
...
@@ -90,7 +89,7 @@ bool LIB_ITEM::operator==( const LIB_ITEM& aOther ) const
return
(
(
Type
()
==
aOther
.
Type
()
)
return
(
(
Type
()
==
aOther
.
Type
()
)
&&
(
m_Unit
==
aOther
.
m_Unit
)
&&
(
m_Unit
==
aOther
.
m_Unit
)
&&
(
m_Convert
==
aOther
.
m_Convert
)
&&
(
m_Convert
==
aOther
.
m_Convert
)
&&
DoC
ompare
(
aOther
)
==
0
);
&&
c
ompare
(
aOther
)
==
0
);
}
}
...
@@ -111,7 +110,7 @@ bool LIB_ITEM::operator<( const LIB_ITEM& aOther ) const
...
@@ -111,7 +110,7 @@ bool LIB_ITEM::operator<( const LIB_ITEM& aOther ) const
if
(
result
!=
0
)
if
(
result
!=
0
)
return
result
<
0
;
return
result
<
0
;
return
(
DoC
ompare
(
aOther
)
<
0
);
return
(
c
ompare
(
aOther
)
<
0
);
}
}
...
@@ -125,6 +124,7 @@ void LIB_ITEM::Draw( EDA_DRAW_PANEL* aPanel, wxDC* aDC, const wxPoint& aOffset,
...
@@ -125,6 +124,7 @@ void LIB_ITEM::Draw( EDA_DRAW_PANEL* aPanel, wxDC* aDC, const wxPoint& aOffset,
int
color
=
GetDefaultColor
();
int
color
=
GetDefaultColor
();
m_Fill
=
NO_FILL
;
m_Fill
=
NO_FILL
;
#ifndef USE_WX_OVERLAY
#ifndef USE_WX_OVERLAY
// Erase the old items using the previous attributes.
// Erase the old items using the previous attributes.
if
(
m_eraseLastDrawItem
)
if
(
m_eraseLastDrawItem
)
...
...
eeschema/lib_draw_item.h
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -67,14 +66,9 @@ typedef boost::ptr_vector< LIB_ITEM > LIB_ITEMS;
...
@@ -67,14 +66,9 @@ typedef boost::ptr_vector< LIB_ITEM > LIB_ITEMS;
typedef
std
::
vector
<
LIB_PIN
*
>
LIB_PINS
;
typedef
std
::
vector
<
LIB_PIN
*
>
LIB_PINS
;
/****************************************************************************/
/* Classes for handle the body items of a component: pins add graphic items */
/****************************************************************************/
/**
/**
*
Base class for drawable items used in library components.
*
Class LIB_ITEM
*
(graphic shapes, texts, fields, pins)
*
is the base class for drawable items used by schematic library components.
*/
*/
class
LIB_ITEM
:
public
EDA_ITEM
class
LIB_ITEM
:
public
EDA_ITEM
{
{
...
@@ -135,6 +129,9 @@ protected:
...
@@ -135,6 +129,9 @@ protected:
wxPoint
m_initialPos
;
///< Temporary position when moving an existing item.
wxPoint
m_initialPos
;
///< Temporary position when moving an existing item.
wxPoint
m_initialCursorPos
;
///< Initial cursor position at the beginning of a move.
wxPoint
m_initialCursorPos
;
///< Initial cursor position at the beginning of a move.
/** Flag to indicate if draw item is fillable. Default is false. */
bool
m_isFillable
;
public
:
public
:
LIB_ITEM
(
KICAD_T
aType
,
LIB_ITEM
(
KICAD_T
aType
,
...
@@ -217,7 +214,7 @@ public:
...
@@ -217,7 +214,7 @@ public:
* Function Save
* Function Save
* writes draw item object to \a aFormatter in component library "*.lib" format.
* writes draw item object to \a aFormatter in component library "*.lib" format.
*
*
* @param aFormatter A referenc
t
to an #OUTPUTFORMATTER object to write the
* @param aFormatter A referenc
e
to an #OUTPUTFORMATTER object to write the
* component library item to.
* component library item to.
* @return True if success writing else false.
* @return True if success writing else false.
*/
*/
...
@@ -294,68 +291,64 @@ public:
...
@@ -294,68 +291,64 @@ public:
bool
operator
<
(
const
LIB_ITEM
&
aOther
)
const
;
bool
operator
<
(
const
LIB_ITEM
&
aOther
)
const
;
/**
/**
* Set drawing object offset from the current position.
* Function Offset
* sets the drawing object by \a aOffset from the current position.
*
*
* @param aOffset
- Coordinates to offset
position.
* @param aOffset
Coordinates to offset the item
position.
*/
*/
v
oid
SetOffset
(
const
wxPoint
&
aOffset
)
{
DoOffset
(
aOffset
);
}
v
irtual
void
SetOffset
(
const
wxPoint
&
aOffset
)
=
0
;
/**
/**
* Test if any part of the draw object is inside rectangle bounds.
* Function Inside
*
* tests if any part of the draw object is inside rectangle bounds of \a aRect.
* This is used for block selection. The real work is done by the
* DoTestInside method for each derived object type.
*
*
* @param aRect
-
Rectangle to check against.
* @param aRect Rectangle to check against.
* @return
-
True if object is inside rectangle.
* @return True if object is inside rectangle.
*/
*/
bool
Inside
(
EDA_RECT
&
aRect
)
const
{
return
DoTestInside
(
aRect
);
}
virtual
bool
Inside
(
EDA_RECT
&
aRect
)
const
=
0
;
/**
/**
* Move a draw object to a new \a aPosition.
* Function Move
*
* moves a draw object to \a aPosition.
* The real work is done by the DoMove method for each derived object type.
*
*
* @param aPosition
-
Position to move draw item to.
* @param aPosition Position to move draw item to.
*/
*/
v
oid
Move
(
const
wxPoint
&
aPosition
)
{
DoMove
(
aPosition
);
}
v
irtual
void
Move
(
const
wxPoint
&
aPosition
)
=
0
;
/**
/**
* Return the current draw object start position.
* Function GetPosition
* returns the current draw object position.
*
* @return A wxPoint object containing the position of the object.
*/
*/
wxPoint
GetPosition
()
const
{
return
DoGetPosition
();
}
virtual
wxPoint
GetPosition
()
const
=
0
;
void
SetPosition
(
const
wxPoint
&
aPosition
)
{
Do
Move
(
aPosition
);
}
void
SetPosition
(
const
wxPoint
&
aPosition
)
{
Move
(
aPosition
);
}
/**
/**
* Mirror the draw object along the horizontal (X) axis about a point.
* Function MirrorHorizontal
* mirrors the draw object along the horizontal (X) axis about \a aCenter point.
*
*
* @param aCenter
-
Point to mirror around.
* @param aCenter Point to mirror around.
*/
*/
void
MirrorHorizontal
(
const
wxPoint
&
aCenter
)
virtual
void
MirrorHorizontal
(
const
wxPoint
&
aCenter
)
=
0
;
{
DoMirrorHorizontal
(
aCenter
);
}
/**
/**
* Mirror the draw object along the MirrorVertical (Y) axis about a point.
* Function MirrorVertical
* mirrors the draw object along the MirrorVertical (Y) axis about \a aCenter point.
*
*
* @param aCenter
-
Point to mirror around.
* @param aCenter Point to mirror around.
*/
*/
void
MirrorVertical
(
const
wxPoint
&
aCenter
)
virtual
void
MirrorVertical
(
const
wxPoint
&
aCenter
)
=
0
;
{
DoMirrorVertical
(
aCenter
);
}
/**
/**
* Rotate about a point.
* Function Rotate
* rotates the object about \a aCenter point.
*
*
* @param aCenter - Point to rotate around.
* @param aCenter Point to rotate around.
* @param aRotateCCW True to rotate counter clockwise. False to rotate clockwise.
*/
*/
void
Rotate
(
const
wxPoint
&
aCenter
)
virtual
void
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
)
=
0
;
{
DoRotate
(
aCenter
);
}
/**
/**
* Rotate the draw item.
* Rotate the draw item.
...
@@ -365,23 +358,27 @@ public:
...
@@ -365,23 +358,27 @@ public:
/**
/**
* Plot the draw item using the plot object.
* Plot the draw item using the plot object.
*
*
* @param aPlotter
-
The plot object to plot to.
* @param aPlotter The plot object to plot to.
* @param aOffset
-
Plot offset position.
* @param aOffset Plot offset position.
* @param aFill
-
Flag to indicate whether or not the object is filled.
* @param aFill Flag to indicate whether or not the object is filled.
* @param aTransform
-
The plot transform.
* @param aTransform The plot transform.
*/
*/
void
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
)
virtual
void
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
{
const
TRANSFORM
&
aTransform
)
=
0
;
DoPlot
(
aPlotter
,
aOffset
,
aFill
,
aTransform
);
}
/**
/**
* Return the width of the draw item.
* Function GetWidth
* return the width of the draw item.
*
*
* @return Width of draw object.
* @return Width of draw object.
*/
*/
int
GetWidth
()
const
{
return
DoGetWidth
();
}
virtual
int
GetWidth
()
const
=
0
;
void
SetWidth
(
int
aWidth
)
{
DoSetWidth
(
aWidth
);
}
/**
* Function SetWidth
* sets the width of the draw item to \a aWidth.
*/
virtual
void
SetWidth
(
int
aWidth
)
=
0
;
/**
/**
* Check if draw object can be filled.
* Check if draw object can be filled.
...
@@ -420,10 +417,11 @@ public:
...
@@ -420,10 +417,11 @@ public:
void
Show
(
int
nestLevel
,
std
::
ostream
&
os
)
const
{
ShowDummy
(
os
);
}
// override
void
Show
(
int
nestLevel
,
std
::
ostream
&
os
)
const
{
ShowDummy
(
os
);
}
// override
#endif
#endif
pr
otected
:
pr
ivate
:
/**
/**
* Provide the draw object specific comparison.
* Function compare
* provides the draw object specific comparison.
*
*
* This is called by the == and < operators.
* This is called by the == and < operators.
*
*
...
@@ -433,21 +431,7 @@ protected:
...
@@ -433,21 +431,7 @@ protected:
* - KICAD_T enum value.
* - KICAD_T enum value.
* - Result of derived classes comparison.
* - Result of derived classes comparison.
*/
*/
virtual
int
DoCompare
(
const
LIB_ITEM
&
aOther
)
const
=
0
;
virtual
int
compare
(
const
LIB_ITEM
&
aOther
)
const
=
0
;
virtual
void
DoOffset
(
const
wxPoint
&
aOffset
)
=
0
;
virtual
bool
DoTestInside
(
EDA_RECT
&
aRect
)
const
=
0
;
virtual
void
DoMove
(
const
wxPoint
&
aPosition
)
=
0
;
virtual
wxPoint
DoGetPosition
()
const
=
0
;
virtual
void
DoMirrorHorizontal
(
const
wxPoint
&
aCenter
)
=
0
;
virtual
void
DoMirrorVertical
(
const
wxPoint
&
aCenter
)
=
0
;
virtual
void
DoRotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
)
=
0
;
virtual
void
DoPlot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
)
=
0
;
virtual
int
DoGetWidth
()
const
=
0
;
virtual
void
DoSetWidth
(
int
aWidth
)
=
0
;
/** Flag to indicate if draw item is fillable. Default is false. */
bool
m_isFillable
;
};
};
...
...
eeschema/lib_field.cpp
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -397,7 +396,7 @@ void LIB_FIELD::Copy( LIB_FIELD* aTarget ) const
...
@@ -397,7 +396,7 @@ void LIB_FIELD::Copy( LIB_FIELD* aTarget ) const
}
}
int
LIB_FIELD
::
DoC
ompare
(
const
LIB_ITEM
&
other
)
const
int
LIB_FIELD
::
c
ompare
(
const
LIB_ITEM
&
other
)
const
{
{
wxASSERT
(
other
.
Type
()
==
LIB_FIELD_T
);
wxASSERT
(
other
.
Type
()
==
LIB_FIELD_T
);
...
@@ -427,13 +426,13 @@ int LIB_FIELD::DoCompare( const LIB_ITEM& other ) const
...
@@ -427,13 +426,13 @@ int LIB_FIELD::DoCompare( const LIB_ITEM& other ) const
}
}
void
LIB_FIELD
::
DoOffset
(
const
wxPoint
&
o
ffset
)
void
LIB_FIELD
::
SetOffset
(
const
wxPoint
&
aO
ffset
)
{
{
m_Pos
+=
o
ffset
;
m_Pos
+=
aO
ffset
;
}
}
bool
LIB_FIELD
::
DoTest
Inside
(
EDA_RECT
&
rect
)
const
bool
LIB_FIELD
::
Inside
(
EDA_RECT
&
rect
)
const
{
{
/*
/*
* FIXME: This fails to take into account the size and/or orientation of
* FIXME: This fails to take into account the size and/or orientation of
...
@@ -443,27 +442,27 @@ bool LIB_FIELD::DoTestInside( EDA_RECT& rect ) const
...
@@ -443,27 +442,27 @@ bool LIB_FIELD::DoTestInside( EDA_RECT& rect ) const
}
}
void
LIB_FIELD
::
Do
Move
(
const
wxPoint
&
newPosition
)
void
LIB_FIELD
::
Move
(
const
wxPoint
&
newPosition
)
{
{
m_Pos
=
newPosition
;
m_Pos
=
newPosition
;
}
}
void
LIB_FIELD
::
Do
MirrorHorizontal
(
const
wxPoint
&
center
)
void
LIB_FIELD
::
MirrorHorizontal
(
const
wxPoint
&
center
)
{
{
m_Pos
.
x
-=
center
.
x
;
m_Pos
.
x
-=
center
.
x
;
m_Pos
.
x
*=
-
1
;
m_Pos
.
x
*=
-
1
;
m_Pos
.
x
+=
center
.
x
;
m_Pos
.
x
+=
center
.
x
;
}
}
void
LIB_FIELD
::
Do
MirrorVertical
(
const
wxPoint
&
center
)
void
LIB_FIELD
::
MirrorVertical
(
const
wxPoint
&
center
)
{
{
m_Pos
.
y
-=
center
.
y
;
m_Pos
.
y
-=
center
.
y
;
m_Pos
.
y
*=
-
1
;
m_Pos
.
y
*=
-
1
;
m_Pos
.
y
+=
center
.
y
;
m_Pos
.
y
+=
center
.
y
;
}
}
void
LIB_FIELD
::
Do
Rotate
(
const
wxPoint
&
center
,
bool
aRotateCCW
)
void
LIB_FIELD
::
Rotate
(
const
wxPoint
&
center
,
bool
aRotateCCW
)
{
{
int
rot_angle
=
aRotateCCW
?
-
900
:
900
;
int
rot_angle
=
aRotateCCW
?
-
900
:
900
;
RotatePoint
(
&
m_Pos
,
center
,
rot_angle
);
RotatePoint
(
&
m_Pos
,
center
,
rot_angle
);
...
@@ -471,7 +470,7 @@ void LIB_FIELD::DoRotate( const wxPoint& center, bool aRotateCCW )
...
@@ -471,7 +470,7 @@ void LIB_FIELD::DoRotate( const wxPoint& center, bool aRotateCCW )
}
}
void
LIB_FIELD
::
Do
Plot
(
PLOTTER
*
plotter
,
const
wxPoint
&
offset
,
bool
fill
,
void
LIB_FIELD
::
Plot
(
PLOTTER
*
plotter
,
const
wxPoint
&
offset
,
bool
fill
,
const
TRANSFORM
&
aTransform
)
const
TRANSFORM
&
aTransform
)
{
{
}
}
...
...
eeschema/lib_field.h
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -269,15 +268,67 @@ public:
...
@@ -269,15 +268,67 @@ public:
*/
*/
void
SetText
(
const
wxString
&
aText
);
void
SetText
(
const
wxString
&
aText
);
/**
* @copydoc LIB_ITEM::SetOffset(const wxPoint&)
*/
virtual
void
SetOffset
(
const
wxPoint
&
aOffset
);
/**
* @copydoc LIB_ITEM::Inside()
*/
virtual
bool
Inside
(
EDA_RECT
&
aRect
)
const
;
/**
* @copydoc LIB_ITEM::Move()
*/
virtual
void
Move
(
const
wxPoint
&
aPosition
);
/**
* @copydoc LIB_ITEM::GetPosition()
*/
virtual
wxPoint
GetPosition
()
const
{
return
m_Pos
;
}
/**
* @copydoc LIB_ITEM::MirrorHorizontal()
*/
virtual
void
MirrorHorizontal
(
const
wxPoint
&
aCenter
);
/**
* @copydoc LIB_ITEM::MirrorVertical()
*/
virtual
void
MirrorVertical
(
const
wxPoint
&
aCenter
);
/**
* @copydoc LIB_ITEM::Rotate(const wxPoint&,bool)
*/
virtual
void
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
);
/**
* @copydoc LIB_ITEM::Plot()
*/
virtual
void
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
);
/**
* @copydoc LIB_ITEM::GetWidth()
*/
virtual
int
GetWidth
()
const
{
return
m_Thickness
;
}
/**
* @copydoc LIB_ITEM::SetWidth()
*/
virtual
void
SetWidth
(
int
aWidth
)
{
m_Thickness
=
aWidth
;
}
virtual
wxString
GetSelectMenuText
()
const
;
virtual
wxString
GetSelectMenuText
()
const
;
virtual
BITMAP_DEF
GetMenuImage
()
const
{
return
move_field_xpm
;
}
virtual
BITMAP_DEF
GetMenuImage
()
const
{
return
move_field_xpm
;
}
pr
otected
:
pr
ivate
:
virtual
EDA_ITEM
*
doClone
()
const
;
virtual
EDA_ITEM
*
doClone
()
const
;
/**
/**
* Provide the field draw object specific comparison.
* Function compare
* provides the field draw object specific comparison.
*
*
* The sort order for field is as follows:
* The sort order for field is as follows:
*
*
...
@@ -287,20 +338,13 @@ protected:
...
@@ -287,20 +338,13 @@ protected:
* - Field vertical (Y) position.
* - Field vertical (Y) position.
* - Field width.
* - Field width.
* - Field height.
* - Field height.
*
* @param aOther A reference to the other #LIB_ITEM to compare the field against.
* @return An integer value less than 0 if the field is less than \a aOther, zero
* if the field is equal to \a aOther, or greater than 0 if the field is
* greater than \a aOther.
*/
*/
virtual
int
DoCompare
(
const
LIB_ITEM
&
other
)
const
;
virtual
int
compare
(
const
LIB_ITEM
&
aOther
)
const
;
virtual
void
DoOffset
(
const
wxPoint
&
offset
);
virtual
bool
DoTestInside
(
EDA_RECT
&
rect
)
const
;
virtual
void
DoMove
(
const
wxPoint
&
newPosition
);
virtual
wxPoint
DoGetPosition
(
void
)
const
{
return
m_Pos
;
}
virtual
void
DoMirrorHorizontal
(
const
wxPoint
&
center
);
virtual
void
DoMirrorVertical
(
const
wxPoint
&
aCenter
);
virtual
void
DoRotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
);
virtual
void
DoPlot
(
PLOTTER
*
plotter
,
const
wxPoint
&
offset
,
bool
fill
,
const
TRANSFORM
&
aTransform
);
virtual
int
DoGetWidth
(
void
)
const
{
return
m_Thickness
;
}
virtual
void
DoSetWidth
(
int
width
)
{
m_Thickness
=
width
;
}
};
};
typedef
std
::
vector
<
LIB_FIELD
>
LIB_FIELDS
;
typedef
std
::
vector
<
LIB_FIELD
>
LIB_FIELDS
;
...
...
eeschema/lib_pin.cpp
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2009 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2009 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2009 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 1992-2011 KiCad Developers, see AUTHORS.txt for contributors.
* Copyright (C) 1992-2011 KiCad Developers, see AUTHORS.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -1677,7 +1676,7 @@ EDA_ITEM* LIB_PIN::doClone() const
...
@@ -1677,7 +1676,7 @@ EDA_ITEM* LIB_PIN::doClone() const
}
}
int
LIB_PIN
::
DoC
ompare
(
const
LIB_ITEM
&
other
)
const
int
LIB_PIN
::
c
ompare
(
const
LIB_ITEM
&
other
)
const
{
{
wxASSERT
(
other
.
Type
()
==
LIB_PIN_T
);
wxASSERT
(
other
.
Type
()
==
LIB_PIN_T
);
...
@@ -1701,13 +1700,13 @@ int LIB_PIN::DoCompare( const LIB_ITEM& other ) const
...
@@ -1701,13 +1700,13 @@ int LIB_PIN::DoCompare( const LIB_ITEM& other ) const
}
}
void
LIB_PIN
::
DoOffset
(
const
wxPoint
&
o
ffset
)
void
LIB_PIN
::
SetOffset
(
const
wxPoint
&
aO
ffset
)
{
{
m_position
+=
o
ffset
;
m_position
+=
aO
ffset
;
}
}
bool
LIB_PIN
::
DoTest
Inside
(
EDA_RECT
&
rect
)
const
bool
LIB_PIN
::
Inside
(
EDA_RECT
&
rect
)
const
{
{
wxPoint
end
=
ReturnPinEndPoint
();
wxPoint
end
=
ReturnPinEndPoint
();
...
@@ -1715,7 +1714,7 @@ bool LIB_PIN::DoTestInside( EDA_RECT& rect ) const
...
@@ -1715,7 +1714,7 @@ bool LIB_PIN::DoTestInside( EDA_RECT& rect ) const
}
}
void
LIB_PIN
::
Do
Move
(
const
wxPoint
&
newPosition
)
void
LIB_PIN
::
Move
(
const
wxPoint
&
newPosition
)
{
{
if
(
m_position
!=
newPosition
)
if
(
m_position
!=
newPosition
)
{
{
...
@@ -1725,7 +1724,7 @@ void LIB_PIN::DoMove( const wxPoint& newPosition )
...
@@ -1725,7 +1724,7 @@ void LIB_PIN::DoMove( const wxPoint& newPosition )
}
}
void
LIB_PIN
::
Do
MirrorHorizontal
(
const
wxPoint
&
center
)
void
LIB_PIN
::
MirrorHorizontal
(
const
wxPoint
&
center
)
{
{
m_position
.
x
-=
center
.
x
;
m_position
.
x
-=
center
.
x
;
m_position
.
x
*=
-
1
;
m_position
.
x
*=
-
1
;
...
@@ -1737,7 +1736,7 @@ void LIB_PIN::DoMirrorHorizontal( const wxPoint& center )
...
@@ -1737,7 +1736,7 @@ void LIB_PIN::DoMirrorHorizontal( const wxPoint& center )
m_orientation
=
PIN_RIGHT
;
m_orientation
=
PIN_RIGHT
;
}
}
void
LIB_PIN
::
Do
MirrorVertical
(
const
wxPoint
&
center
)
void
LIB_PIN
::
MirrorVertical
(
const
wxPoint
&
center
)
{
{
m_position
.
y
-=
center
.
y
;
m_position
.
y
-=
center
.
y
;
m_position
.
y
*=
-
1
;
m_position
.
y
*=
-
1
;
...
@@ -1749,7 +1748,7 @@ void LIB_PIN::DoMirrorVertical( const wxPoint& center )
...
@@ -1749,7 +1748,7 @@ void LIB_PIN::DoMirrorVertical( const wxPoint& center )
m_orientation
=
PIN_UP
;
m_orientation
=
PIN_UP
;
}
}
void
LIB_PIN
::
Do
Rotate
(
const
wxPoint
&
center
,
bool
aRotateCCW
)
void
LIB_PIN
::
Rotate
(
const
wxPoint
&
center
,
bool
aRotateCCW
)
{
{
int
rot_angle
=
aRotateCCW
?
-
900
:
900
;
int
rot_angle
=
aRotateCCW
?
-
900
:
900
;
...
@@ -1798,7 +1797,7 @@ void LIB_PIN::DoRotate( const wxPoint& center, bool aRotateCCW )
...
@@ -1798,7 +1797,7 @@ void LIB_PIN::DoRotate( const wxPoint& center, bool aRotateCCW )
}
}
void
LIB_PIN
::
Do
Plot
(
PLOTTER
*
plotter
,
const
wxPoint
&
offset
,
bool
fill
,
void
LIB_PIN
::
Plot
(
PLOTTER
*
plotter
,
const
wxPoint
&
offset
,
bool
fill
,
const
TRANSFORM
&
aTransform
)
const
TRANSFORM
&
aTransform
)
{
{
if
(
!
IsVisible
()
)
if
(
!
IsVisible
()
)
...
@@ -1816,7 +1815,7 @@ void LIB_PIN::DoPlot( PLOTTER* plotter, const wxPoint& offset, bool fill,
...
@@ -1816,7 +1815,7 @@ void LIB_PIN::DoPlot( PLOTTER* plotter, const wxPoint& offset, bool fill,
}
}
void
LIB_PIN
::
Do
SetWidth
(
int
aWidth
)
void
LIB_PIN
::
SetWidth
(
int
aWidth
)
{
{
if
(
m_width
!=
aWidth
)
if
(
m_width
!=
aWidth
)
{
{
...
...
eeschema/lib_pin.h
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -519,34 +518,80 @@ public:
...
@@ -519,34 +518,80 @@ public:
*/
*/
static
const
BITMAP_DEF
*
GetElectricalTypeSymbols
();
static
const
BITMAP_DEF
*
GetElectricalTypeSymbols
();
/**
* @copydoc LIB_ITEM::SetOffset(const wxPoint&)
*/
virtual
void
SetOffset
(
const
wxPoint
&
aOffset
);
/**
* @copydoc LIB_ITEM::Inside()
*/
virtual
bool
Inside
(
EDA_RECT
&
aRect
)
const
;
/**
* @copydoc LIB_ITEM::Move()
*/
virtual
void
Move
(
const
wxPoint
&
aPosition
);
/**
* @copydoc LIB_ITEM::GetPosition()
*/
virtual
wxPoint
GetPosition
()
const
{
return
m_position
;
}
/**
* @copydoc LIB_ITEM::MirrorHorizontal()
*/
virtual
void
MirrorHorizontal
(
const
wxPoint
&
aCenter
);
/**
* @copydoc LIB_ITEM::MirrorVertical()
*/
virtual
void
MirrorVertical
(
const
wxPoint
&
aCenter
);
/**
* @copydoc LIB_ITEM::Rotate(const wxPoint&,bool)
*/
virtual
void
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
);
/**
* @copydoc LIB_ITEM::Plot()
*/
virtual
void
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
);
/**
* @copydoc LIB_ITEM::GetWidth()
*/
virtual
int
GetWidth
()
const
{
return
m_width
;
}
/**
* @copydoc LIB_ITEM::SetWidth()
*/
virtual
void
SetWidth
(
int
aWidth
);
virtual
BITMAP_DEF
GetMenuImage
()
const
;
virtual
BITMAP_DEF
GetMenuImage
()
const
;
virtual
wxString
GetSelectMenuText
()
const
;
virtual
wxString
GetSelectMenuText
()
const
;
pr
otected
:
pr
ivate
:
virtual
EDA_ITEM
*
doClone
()
const
;
virtual
EDA_ITEM
*
doClone
()
const
;
/**
/**
* Provide the pin draw object specific comparison.
* Function compare
* provides the pin draw object specific comparison.
*
*
* The sort order is as follows:
* The sort order is as follows:
* - Pin number.
* - Pin number.
* - Pin name, case insensitive compare.
* - Pin name, case insensitive compare.
* - Pin horizontal (X) position.
* - Pin horizontal (X) position.
* - Pin vertical (Y) position.
* - Pin vertical (Y) position.
*
* @param aOther A reference to the other #LIB_ITEM to compare the pin against.
* @return An integer value less than 0 if the pin is less than \a aOther, zero
* if the pin is equal to \a aOther, or greater than 0 if the pin is
* greater than \a aOther.
*/
*/
virtual
int
DoCompare
(
const
LIB_ITEM
&
aOther
)
const
;
virtual
int
compare
(
const
LIB_ITEM
&
aOther
)
const
;
virtual
void
DoOffset
(
const
wxPoint
&
aOffset
);
virtual
bool
DoTestInside
(
EDA_RECT
&
aRect
)
const
;
virtual
void
DoMove
(
const
wxPoint
&
aPosition
);
virtual
wxPoint
DoGetPosition
()
const
{
return
m_position
;
}
virtual
void
DoMirrorHorizontal
(
const
wxPoint
&
aCenter
);
virtual
void
DoMirrorVertical
(
const
wxPoint
&
aCenter
);
virtual
void
DoRotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
);
virtual
void
DoPlot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
);
virtual
int
DoGetWidth
()
const
{
return
m_width
;
}
virtual
void
DoSetWidth
(
int
aWidth
);
};
};
...
...
eeschema/lib_polyline.cpp
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -140,7 +139,7 @@ EDA_ITEM* LIB_POLYLINE::doClone() const
...
@@ -140,7 +139,7 @@ EDA_ITEM* LIB_POLYLINE::doClone() const
}
}
int
LIB_POLYLINE
::
DoC
ompare
(
const
LIB_ITEM
&
aOther
)
const
int
LIB_POLYLINE
::
c
ompare
(
const
LIB_ITEM
&
aOther
)
const
{
{
wxASSERT
(
aOther
.
Type
()
==
LIB_POLYLINE_T
);
wxASSERT
(
aOther
.
Type
()
==
LIB_POLYLINE_T
);
...
@@ -162,14 +161,14 @@ int LIB_POLYLINE::DoCompare( const LIB_ITEM& aOther ) const
...
@@ -162,14 +161,14 @@ int LIB_POLYLINE::DoCompare( const LIB_ITEM& aOther ) const
}
}
void
LIB_POLYLINE
::
Do
Offset
(
const
wxPoint
&
aOffset
)
void
LIB_POLYLINE
::
Set
Offset
(
const
wxPoint
&
aOffset
)
{
{
for
(
size_t
i
=
0
;
i
<
m_PolyPoints
.
size
();
i
++
)
for
(
size_t
i
=
0
;
i
<
m_PolyPoints
.
size
();
i
++
)
m_PolyPoints
[
i
]
+=
aOffset
;
m_PolyPoints
[
i
]
+=
aOffset
;
}
}
bool
LIB_POLYLINE
::
DoTest
Inside
(
EDA_RECT
&
aRect
)
const
bool
LIB_POLYLINE
::
Inside
(
EDA_RECT
&
aRect
)
const
{
{
for
(
size_t
i
=
0
;
i
<
m_PolyPoints
.
size
();
i
++
)
for
(
size_t
i
=
0
;
i
<
m_PolyPoints
.
size
();
i
++
)
{
{
...
@@ -181,13 +180,13 @@ bool LIB_POLYLINE::DoTestInside( EDA_RECT& aRect ) const
...
@@ -181,13 +180,13 @@ bool LIB_POLYLINE::DoTestInside( EDA_RECT& aRect ) const
}
}
void
LIB_POLYLINE
::
Do
Move
(
const
wxPoint
&
aPosition
)
void
LIB_POLYLINE
::
Move
(
const
wxPoint
&
aPosition
)
{
{
Do
Offset
(
aPosition
-
m_PolyPoints
[
0
]
);
Set
Offset
(
aPosition
-
m_PolyPoints
[
0
]
);
}
}
void
LIB_POLYLINE
::
Do
MirrorHorizontal
(
const
wxPoint
&
aCenter
)
void
LIB_POLYLINE
::
MirrorHorizontal
(
const
wxPoint
&
aCenter
)
{
{
size_t
i
,
imax
=
m_PolyPoints
.
size
();
size_t
i
,
imax
=
m_PolyPoints
.
size
();
...
@@ -199,7 +198,7 @@ void LIB_POLYLINE::DoMirrorHorizontal( const wxPoint& aCenter )
...
@@ -199,7 +198,7 @@ void LIB_POLYLINE::DoMirrorHorizontal( const wxPoint& aCenter )
}
}
}
}
void
LIB_POLYLINE
::
Do
MirrorVertical
(
const
wxPoint
&
aCenter
)
void
LIB_POLYLINE
::
MirrorVertical
(
const
wxPoint
&
aCenter
)
{
{
size_t
i
,
imax
=
m_PolyPoints
.
size
();
size_t
i
,
imax
=
m_PolyPoints
.
size
();
...
@@ -211,7 +210,7 @@ void LIB_POLYLINE::DoMirrorVertical( const wxPoint& aCenter )
...
@@ -211,7 +210,7 @@ void LIB_POLYLINE::DoMirrorVertical( const wxPoint& aCenter )
}
}
}
}
void
LIB_POLYLINE
::
Do
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
)
void
LIB_POLYLINE
::
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
)
{
{
int
rot_angle
=
aRotateCCW
?
-
900
:
900
;
int
rot_angle
=
aRotateCCW
?
-
900
:
900
;
...
@@ -224,7 +223,7 @@ void LIB_POLYLINE::DoRotate( const wxPoint& aCenter, bool aRotateCCW )
...
@@ -224,7 +223,7 @@ void LIB_POLYLINE::DoRotate( const wxPoint& aCenter, bool aRotateCCW )
}
}
void
LIB_POLYLINE
::
Do
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
void
LIB_POLYLINE
::
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
)
const
TRANSFORM
&
aTransform
)
{
{
wxASSERT
(
aPlotter
!=
NULL
);
wxASSERT
(
aPlotter
!=
NULL
);
...
...
eeschema/lib_polyline.h
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -134,33 +133,78 @@ public:
...
@@ -134,33 +133,78 @@ public:
*/
*/
void
EndEdit
(
const
wxPoint
&
aPosition
,
bool
aAbort
=
false
);
void
EndEdit
(
const
wxPoint
&
aPosition
,
bool
aAbort
=
false
);
/**
* @copydoc LIB_ITEM::SetOffset(const wxPoint&)
*/
virtual
void
SetOffset
(
const
wxPoint
&
aOffset
);
/**
* @copydoc LIB_ITEM::Inside()
*/
virtual
bool
Inside
(
EDA_RECT
&
aRect
)
const
;
/**
* @copydoc LIB_ITEM::Move()
*/
virtual
void
Move
(
const
wxPoint
&
aPosition
);
/**
* @copydoc LIB_ITEM::GetPosition()
*/
virtual
wxPoint
GetPosition
()
const
{
return
m_PolyPoints
[
0
];
}
/**
* @copydoc LIB_ITEM::MirrorHorizontal()
*/
virtual
void
MirrorHorizontal
(
const
wxPoint
&
aCenter
);
/**
* @copydoc LIB_ITEM::MirrorVertical()
*/
virtual
void
MirrorVertical
(
const
wxPoint
&
aCenter
);
/**
* @copydoc LIB_ITEM::Rotate(const wxPoint&,bool)
*/
virtual
void
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
);
/**
* @copydoc LIB_ITEM::Plot()
*/
virtual
void
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
);
/**
* @copydoc LIB_ITEM::GetWidth()
*/
virtual
int
GetWidth
()
const
{
return
m_Width
;
}
/**
* @copydoc LIB_ITEM::SetWidth()
*/
virtual
void
SetWidth
(
int
aWidth
)
{
m_Width
=
aWidth
;
}
virtual
wxString
GetSelectMenuText
()
const
;
virtual
wxString
GetSelectMenuText
()
const
;
virtual
BITMAP_DEF
GetMenuImage
()
const
{
return
add_polygon_xpm
;
}
virtual
BITMAP_DEF
GetMenuImage
()
const
{
return
add_polygon_xpm
;
}
pr
otected
:
pr
ivate
:
virtual
EDA_ITEM
*
doClone
()
const
;
virtual
EDA_ITEM
*
doClone
()
const
;
/**
/**
* Provide the polyline segment draw object specific comparison.
* Function compare
* provides the polyline segment draw object specific comparison.
*
*
* The sort order for each polyline segment point is as follows:
* The sort order for each polyline segment point is as follows:
* - Line segment point horizontal (X) position.
* - Line segment point horizontal (X) position.
* - Line segment point vertical (Y) position.
* - Line segment point vertical (Y) position.
*
* @param aOther A reference to the other #LIB_ITEM to compare the polyline against.
* @return An integer value less than 0 if the polyline is less than \a aOther, zero
* if the polyline is equal to \a aOther, or greater than 0 if the polyline
* is greater than \a aOther.
*/
*/
virtual
int
DoCompare
(
const
LIB_ITEM
&
aOther
)
const
;
virtual
int
compare
(
const
LIB_ITEM
&
aOther
)
const
;
virtual
void
DoOffset
(
const
wxPoint
&
aOffset
);
virtual
bool
DoTestInside
(
EDA_RECT
&
aRect
)
const
;
virtual
void
DoMove
(
const
wxPoint
&
aPosition
);
virtual
wxPoint
DoGetPosition
()
const
{
return
m_PolyPoints
[
0
];
}
virtual
void
DoMirrorHorizontal
(
const
wxPoint
&
aCenter
);
virtual
void
DoMirrorVertical
(
const
wxPoint
&
aCenter
);
virtual
void
DoRotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
);
virtual
void
DoPlot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
);
virtual
int
DoGetWidth
()
const
{
return
m_Width
;
}
virtual
void
DoSetWidth
(
int
aWidth
)
{
m_Width
=
aWidth
;
}
};
};
...
...
eeschema/lib_rectangle.cpp
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -95,7 +94,7 @@ EDA_ITEM* LIB_RECTANGLE::doClone() const
...
@@ -95,7 +94,7 @@ EDA_ITEM* LIB_RECTANGLE::doClone() const
}
}
int
LIB_RECTANGLE
::
DoC
ompare
(
const
LIB_ITEM
&
aOther
)
const
int
LIB_RECTANGLE
::
c
ompare
(
const
LIB_ITEM
&
aOther
)
const
{
{
wxASSERT
(
aOther
.
Type
()
==
LIB_RECTANGLE_T
);
wxASSERT
(
aOther
.
Type
()
==
LIB_RECTANGLE_T
);
...
@@ -117,20 +116,20 @@ int LIB_RECTANGLE::DoCompare( const LIB_ITEM& aOther ) const
...
@@ -117,20 +116,20 @@ int LIB_RECTANGLE::DoCompare( const LIB_ITEM& aOther ) const
}
}
void
LIB_RECTANGLE
::
Do
Offset
(
const
wxPoint
&
aOffset
)
void
LIB_RECTANGLE
::
Set
Offset
(
const
wxPoint
&
aOffset
)
{
{
m_Pos
+=
aOffset
;
m_Pos
+=
aOffset
;
m_End
+=
aOffset
;
m_End
+=
aOffset
;
}
}
bool
LIB_RECTANGLE
::
DoTest
Inside
(
EDA_RECT
&
aRect
)
const
bool
LIB_RECTANGLE
::
Inside
(
EDA_RECT
&
aRect
)
const
{
{
return
aRect
.
Contains
(
m_Pos
.
x
,
-
m_Pos
.
y
)
||
aRect
.
Contains
(
m_End
.
x
,
-
m_End
.
y
);
return
aRect
.
Contains
(
m_Pos
.
x
,
-
m_Pos
.
y
)
||
aRect
.
Contains
(
m_End
.
x
,
-
m_End
.
y
);
}
}
void
LIB_RECTANGLE
::
Do
Move
(
const
wxPoint
&
aPosition
)
void
LIB_RECTANGLE
::
Move
(
const
wxPoint
&
aPosition
)
{
{
wxPoint
size
=
m_End
-
m_Pos
;
wxPoint
size
=
m_End
-
m_Pos
;
m_Pos
=
aPosition
;
m_Pos
=
aPosition
;
...
@@ -138,7 +137,7 @@ void LIB_RECTANGLE::DoMove( const wxPoint& aPosition )
...
@@ -138,7 +137,7 @@ void LIB_RECTANGLE::DoMove( const wxPoint& aPosition )
}
}
void
LIB_RECTANGLE
::
Do
MirrorHorizontal
(
const
wxPoint
&
aCenter
)
void
LIB_RECTANGLE
::
MirrorHorizontal
(
const
wxPoint
&
aCenter
)
{
{
m_Pos
.
x
-=
aCenter
.
x
;
m_Pos
.
x
-=
aCenter
.
x
;
m_Pos
.
x
*=
-
1
;
m_Pos
.
x
*=
-
1
;
...
@@ -149,7 +148,7 @@ void LIB_RECTANGLE::DoMirrorHorizontal( const wxPoint& aCenter )
...
@@ -149,7 +148,7 @@ void LIB_RECTANGLE::DoMirrorHorizontal( const wxPoint& aCenter )
}
}
void
LIB_RECTANGLE
::
Do
MirrorVertical
(
const
wxPoint
&
aCenter
)
void
LIB_RECTANGLE
::
MirrorVertical
(
const
wxPoint
&
aCenter
)
{
{
m_Pos
.
y
-=
aCenter
.
y
;
m_Pos
.
y
-=
aCenter
.
y
;
m_Pos
.
y
*=
-
1
;
m_Pos
.
y
*=
-
1
;
...
@@ -160,7 +159,7 @@ void LIB_RECTANGLE::DoMirrorVertical( const wxPoint& aCenter )
...
@@ -160,7 +159,7 @@ void LIB_RECTANGLE::DoMirrorVertical( const wxPoint& aCenter )
}
}
void
LIB_RECTANGLE
::
Do
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
)
void
LIB_RECTANGLE
::
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
)
{
{
int
rot_angle
=
aRotateCCW
?
-
900
:
900
;
int
rot_angle
=
aRotateCCW
?
-
900
:
900
;
RotatePoint
(
&
m_Pos
,
aCenter
,
rot_angle
);
RotatePoint
(
&
m_Pos
,
aCenter
,
rot_angle
);
...
@@ -168,7 +167,7 @@ void LIB_RECTANGLE::DoRotate( const wxPoint& aCenter, bool aRotateCCW )
...
@@ -168,7 +167,7 @@ void LIB_RECTANGLE::DoRotate( const wxPoint& aCenter, bool aRotateCCW )
}
}
void
LIB_RECTANGLE
::
Do
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
void
LIB_RECTANGLE
::
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
)
const
TRANSFORM
&
aTransform
)
{
{
wxASSERT
(
aPlotter
!=
NULL
);
wxASSERT
(
aPlotter
!=
NULL
);
...
...
eeschema/lib_rectangle.h
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -122,35 +121,80 @@ public:
...
@@ -122,35 +121,80 @@ public:
*/
*/
void
EndEdit
(
const
wxPoint
&
aPosition
,
bool
aAbort
=
false
);
void
EndEdit
(
const
wxPoint
&
aPosition
,
bool
aAbort
=
false
);
/**
* @copydoc LIB_ITEM::SetOffset(const wxPoint&)
*/
virtual
void
SetOffset
(
const
wxPoint
&
aOffset
);
/**
* @copydoc LIB_ITEM::Inside()
*/
virtual
bool
Inside
(
EDA_RECT
&
aRect
)
const
;
/**
* @copydoc LIB_ITEM::Move()
*/
virtual
void
Move
(
const
wxPoint
&
aPosition
);
/**
* @copydoc LIB_ITEM::GetPosition()
*/
virtual
wxPoint
GetPosition
()
const
{
return
m_Pos
;
}
/**
* @copydoc LIB_ITEM::MirrorHorizontal()
*/
virtual
void
MirrorHorizontal
(
const
wxPoint
&
aCenter
);
/**
* @copydoc LIB_ITEM::MirrorVertical()
*/
virtual
void
MirrorVertical
(
const
wxPoint
&
aCenter
);
/**
* @copydoc LIB_ITEM::Rotate(const wxPoint&,bool)
*/
virtual
void
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
);
/**
* @copydoc LIB_ITEM::Plot()
*/
virtual
void
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
);
/**
* @copydoc LIB_ITEM::GetWidth()
*/
virtual
int
GetWidth
()
const
{
return
m_Width
;
}
/**
* @copydoc LIB_ITEM::SetWidth()
*/
virtual
void
SetWidth
(
int
aWidth
)
{
m_Width
=
aWidth
;
}
virtual
wxString
GetSelectMenuText
()
const
;
virtual
wxString
GetSelectMenuText
()
const
;
virtual
BITMAP_DEF
GetMenuImage
()
const
{
return
add_rectangle_xpm
;
}
virtual
BITMAP_DEF
GetMenuImage
()
const
{
return
add_rectangle_xpm
;
}
pr
otected
:
pr
ivate
:
virtual
EDA_ITEM
*
doClone
()
const
;
virtual
EDA_ITEM
*
doClone
()
const
;
/**
/**
* Provide the rectangle draw object specific comparison.
* Function compare
* provides the rectangle draw object specific comparison.
*
*
* The sort order is as follows:
* The sort order is as follows:
* - Rectangle horizontal (X) start position.
* - Rectangle horizontal (X) start position.
* - Rectangle vertical (Y) start position.
* - Rectangle vertical (Y) start position.
* - Rectangle horizontal (X) end position.
* - Rectangle horizontal (X) end position.
* - Rectangle vertical (Y) end position.
* - Rectangle vertical (Y) end position.
*
* @param aOther A reference to the other #LIB_ITEM to compare the rectangle against.
* @return An integer value less than 0 if the rectangle is less than \a aOther, zero
* if the rectangle is equal to \a aOther, or greater than 0 if the rectangle
* is greater than \a aOther.
*/
*/
virtual
int
DoCompare
(
const
LIB_ITEM
&
aOther
)
const
;
virtual
int
compare
(
const
LIB_ITEM
&
aOther
)
const
;
virtual
void
DoOffset
(
const
wxPoint
&
aOffset
);
virtual
bool
DoTestInside
(
EDA_RECT
&
aRect
)
const
;
virtual
void
DoMove
(
const
wxPoint
&
aPosition
);
virtual
wxPoint
DoGetPosition
()
const
{
return
m_Pos
;
}
virtual
void
DoMirrorHorizontal
(
const
wxPoint
&
aCenter
);
virtual
void
DoMirrorVertical
(
const
wxPoint
&
aCenter
);
virtual
void
DoRotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
);
virtual
void
DoPlot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
);
virtual
int
DoGetWidth
()
const
{
return
m_Width
;
}
virtual
void
DoSetWidth
(
int
aWidth
)
{
m_Width
=
aWidth
;
}
};
};
...
...
eeschema/lib_text.cpp
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -236,7 +235,7 @@ EDA_ITEM* LIB_TEXT::doClone() const
...
@@ -236,7 +235,7 @@ EDA_ITEM* LIB_TEXT::doClone() const
}
}
int
LIB_TEXT
::
DoC
ompare
(
const
LIB_ITEM
&
other
)
const
int
LIB_TEXT
::
c
ompare
(
const
LIB_ITEM
&
other
)
const
{
{
wxASSERT
(
other
.
Type
()
==
LIB_TEXT_T
);
wxASSERT
(
other
.
Type
()
==
LIB_TEXT_T
);
...
@@ -263,13 +262,13 @@ int LIB_TEXT::DoCompare( const LIB_ITEM& other ) const
...
@@ -263,13 +262,13 @@ int LIB_TEXT::DoCompare( const LIB_ITEM& other ) const
}
}
void
LIB_TEXT
::
DoOffset
(
const
wxPoint
&
o
ffset
)
void
LIB_TEXT
::
SetOffset
(
const
wxPoint
&
aO
ffset
)
{
{
m_Pos
+=
o
ffset
;
m_Pos
+=
aO
ffset
;
}
}
bool
LIB_TEXT
::
DoTest
Inside
(
EDA_RECT
&
rect
)
const
bool
LIB_TEXT
::
Inside
(
EDA_RECT
&
rect
)
const
{
{
/*
/*
* FIXME: This should calculate the text size and justification and
* FIXME: This should calculate the text size and justification and
...
@@ -279,27 +278,27 @@ bool LIB_TEXT::DoTestInside( EDA_RECT& rect ) const
...
@@ -279,27 +278,27 @@ bool LIB_TEXT::DoTestInside( EDA_RECT& rect ) const
}
}
void
LIB_TEXT
::
Do
Move
(
const
wxPoint
&
newPosition
)
void
LIB_TEXT
::
Move
(
const
wxPoint
&
newPosition
)
{
{
m_Pos
=
newPosition
;
m_Pos
=
newPosition
;
}
}
void
LIB_TEXT
::
Do
MirrorHorizontal
(
const
wxPoint
&
center
)
void
LIB_TEXT
::
MirrorHorizontal
(
const
wxPoint
&
center
)
{
{
m_Pos
.
x
-=
center
.
x
;
m_Pos
.
x
-=
center
.
x
;
m_Pos
.
x
*=
-
1
;
m_Pos
.
x
*=
-
1
;
m_Pos
.
x
+=
center
.
x
;
m_Pos
.
x
+=
center
.
x
;
}
}
void
LIB_TEXT
::
Do
MirrorVertical
(
const
wxPoint
&
center
)
void
LIB_TEXT
::
MirrorVertical
(
const
wxPoint
&
center
)
{
{
m_Pos
.
y
-=
center
.
y
;
m_Pos
.
y
-=
center
.
y
;
m_Pos
.
y
*=
-
1
;
m_Pos
.
y
*=
-
1
;
m_Pos
.
y
+=
center
.
y
;
m_Pos
.
y
+=
center
.
y
;
}
}
void
LIB_TEXT
::
Do
Rotate
(
const
wxPoint
&
center
,
bool
aRotateCCW
)
void
LIB_TEXT
::
Rotate
(
const
wxPoint
&
center
,
bool
aRotateCCW
)
{
{
int
rot_angle
=
aRotateCCW
?
-
900
:
900
;
int
rot_angle
=
aRotateCCW
?
-
900
:
900
;
...
@@ -308,7 +307,7 @@ void LIB_TEXT::DoRotate( const wxPoint& center, bool aRotateCCW )
...
@@ -308,7 +307,7 @@ void LIB_TEXT::DoRotate( const wxPoint& center, bool aRotateCCW )
}
}
void
LIB_TEXT
::
Do
Plot
(
PLOTTER
*
plotter
,
const
wxPoint
&
offset
,
bool
fill
,
void
LIB_TEXT
::
Plot
(
PLOTTER
*
plotter
,
const
wxPoint
&
offset
,
bool
fill
,
const
TRANSFORM
&
aTransform
)
const
TRANSFORM
&
aTransform
)
{
{
wxASSERT
(
plotter
!=
NULL
);
wxASSERT
(
plotter
!=
NULL
);
...
...
eeschema/lib_text.h
View file @
4a739403
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
* This program source code file is part of KiCad, a free EDA CAD application.
* This program source code file is part of KiCad, a free EDA CAD application.
*
*
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
* Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
* Copyright (C) 2004-2011 KiCad Developers, see change_log.txt for contributors.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -154,15 +153,67 @@ public:
...
@@ -154,15 +153,67 @@ public:
*/
*/
void
EndEdit
(
const
wxPoint
&
aPosition
,
bool
aAbort
=
false
);
void
EndEdit
(
const
wxPoint
&
aPosition
,
bool
aAbort
=
false
);
/**
* @copydoc LIB_ITEM::SetOffset(const wxPoint&)
*/
virtual
void
SetOffset
(
const
wxPoint
&
aOffset
);
/**
* @copydoc LIB_ITEM::Inside()
*/
virtual
bool
Inside
(
EDA_RECT
&
aRect
)
const
;
/**
* @copydoc LIB_ITEM::Move()
*/
virtual
void
Move
(
const
wxPoint
&
aPosition
);
/**
* @copydoc LIB_ITEM::GetPosition()
*/
virtual
wxPoint
GetPosition
()
const
{
return
m_Pos
;
}
/**
* @copydoc LIB_ITEM::MirrorHorizontal()
*/
virtual
void
MirrorHorizontal
(
const
wxPoint
&
aCenter
);
/**
* @copydoc LIB_ITEM::MirrorVertical()
*/
virtual
void
MirrorVertical
(
const
wxPoint
&
aCenter
);
/**
* @copydoc LIB_ITEM::Rotate(const wxPoint&,bool)
*/
virtual
void
Rotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
);
/**
* @copydoc LIB_ITEM::Plot()
*/
virtual
void
Plot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
);
/**
* @copydoc LIB_ITEM::GetWidth()
*/
virtual
int
GetWidth
()
const
{
return
m_Thickness
;
}
/**
* @copydoc LIB_ITEM::SetWidth()
*/
virtual
void
SetWidth
(
int
aWidth
)
{
m_Thickness
=
aWidth
;
}
virtual
wxString
GetSelectMenuText
()
const
;
virtual
wxString
GetSelectMenuText
()
const
;
virtual
BITMAP_DEF
GetMenuImage
()
const
{
return
add_text_xpm
;
}
virtual
BITMAP_DEF
GetMenuImage
()
const
{
return
add_text_xpm
;
}
pr
otected
:
pr
ivate
:
virtual
EDA_ITEM
*
doClone
()
const
;
virtual
EDA_ITEM
*
doClone
()
const
;
/**
/**
* Provide the text draw object specific comparison.
* Function compare
* provides the text draw object specific comparison.
*
*
* The sort order is as follows:
* The sort order is as follows:
* - Text string, case insensitive compare.
* - Text string, case insensitive compare.
...
@@ -170,20 +221,13 @@ protected:
...
@@ -170,20 +221,13 @@ protected:
* - Text vertical (Y) position.
* - Text vertical (Y) position.
* - Text width.
* - Text width.
* - Text height.
* - Text height.
*
* @param aOther A reference to the other #LIB_ITEM to compare the text against.
* @return An integer value less than 0 if the text is less than \a aOther, zero
* if the text is equal to \a aOther, or greater than 0 if the text is
* greater than \a aOther.
*/
*/
virtual
int
DoCompare
(
const
LIB_ITEM
&
aOther
)
const
;
virtual
int
compare
(
const
LIB_ITEM
&
aOther
)
const
;
virtual
void
DoOffset
(
const
wxPoint
&
aOffset
);
virtual
bool
DoTestInside
(
EDA_RECT
&
aRect
)
const
;
virtual
void
DoMove
(
const
wxPoint
&
aPosition
);
virtual
wxPoint
DoGetPosition
()
const
{
return
m_Pos
;
}
virtual
void
DoMirrorHorizontal
(
const
wxPoint
&
aCenter
);
virtual
void
DoMirrorVertical
(
const
wxPoint
&
aCenter
);
virtual
void
DoRotate
(
const
wxPoint
&
aCenter
,
bool
aRotateCCW
=
true
);
virtual
void
DoPlot
(
PLOTTER
*
aPlotter
,
const
wxPoint
&
aOffset
,
bool
aFill
,
const
TRANSFORM
&
aTransform
);
virtual
int
DoGetWidth
()
const
{
return
m_Thickness
;
}
virtual
void
DoSetWidth
(
int
aWidth
)
{
m_Thickness
=
aWidth
;
}
};
};
...
...
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