KiCad PCB EDA Suite
sch_no_connect.cpp
Go to the documentation of this file.
1 /*
2  * This program source code file is part of KiCad, a free EDA CAD application.
3  *
4  * Copyright (C) 2015 Jean-Pierre Charras, jp.charras at wanoadoo.fr
5  * Copyright (C) 1992-2019 KiCad Developers, see AUTHORS.txt for contributors.
6  *
7  * This program is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU General Public License
9  * as published by the Free Software Foundation; either version 2
10  * of the License, or (at your option) any later version.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program; if not, you may find one here:
19  * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
20  * or you may search the http://www.gnu.org website for the version 2 license,
21  * or you may write to the Free Software Foundation, Inc.,
22  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
23  */
24 
30 #include <fctsys.h>
31 #include <gr_basic.h>
32 #include <macros.h>
33 #include <sch_draw_panel.h>
34 #include <common.h>
35 #include <plotter.h>
36 #include <bitmaps.h>
37 
38 #include <general.h>
39 #include <sch_no_connect.h>
40 #include <netlist_object.h>
41 
42 
43 SCH_NO_CONNECT::SCH_NO_CONNECT( const wxPoint& pos ) :
44  SCH_ITEM( NULL, SCH_NO_CONNECT_T )
45 {
46  m_pos = pos;
47  m_size = 48;
48 
50 }
51 
52 
54 {
55  return new SCH_NO_CONNECT( *this );
56 }
57 
58 
60 {
61  wxCHECK_RET( (aItem != NULL) && (aItem->Type() == SCH_NO_CONNECT_T),
62  wxT( "Cannot swap no connect data with invalid item." ) );
63 
64  SCH_NO_CONNECT* item = (SCH_NO_CONNECT*)aItem;
65  std::swap( m_pos, item->m_pos );
66  std::swap( m_size, item->m_size );
67 }
68 
69 
71 {
72  int delta = ( GetPenSize() + GetSize() ) / 2;
73  EDA_RECT box;
74 
75  box.SetOrigin( m_pos );
76  box.Inflate( delta );
77 
78  return box;
79 }
80 
81 
82 void SCH_NO_CONNECT::ViewGetLayers( int aLayers[], int& aCount ) const
83 {
84  aLayers[0] = LAYER_NOCONNECT;
85  aCount = 1;
86 }
87 
88 
89 void SCH_NO_CONNECT::GetEndPoints( std::vector< DANGLING_END_ITEM >& aItemList )
90 {
91  DANGLING_END_ITEM item( NO_CONNECT_END, this, m_pos );
92  aItemList.push_back( item );
93 }
94 
95 
97 {
98  return GetDefaultLineThickness();
99 }
100 
101 
102 void SCH_NO_CONNECT::Draw( EDA_DRAW_PANEL* aPanel, wxDC* aDC, const wxPoint& aOffset )
103 {
104  int pX, pY;
105  int half = GetSize() / 2;
106  int width = GetDefaultLineThickness();
107 
108  pX = m_pos.x + aOffset.x;
109  pY = m_pos.y + aOffset.y;
110 
112 
113  GRLine( aPanel->GetClipBox(), aDC, pX - half, pY - half, pX + half, pY + half, width, color );
114  GRLine( aPanel->GetClipBox(), aDC, pX + half, pY - half, pX - half, pY + half, width, color );
115 }
116 
117 
118 void SCH_NO_CONNECT::MirrorX( int aXaxis_position )
119 {
120  MIRROR( m_pos.y, aXaxis_position );
121 }
122 
123 
124 void SCH_NO_CONNECT::MirrorY( int aYaxis_position )
125 {
126  MIRROR( m_pos.x, aYaxis_position );
127 }
128 
129 
130 void SCH_NO_CONNECT::Rotate( wxPoint aPosition )
131 {
132  RotatePoint( &m_pos, aPosition, 900 );
133 }
134 
135 
136 void SCH_NO_CONNECT::GetConnectionPoints( std::vector< wxPoint >& aPoints ) const
137 {
138  aPoints.push_back( m_pos );
139 }
140 
141 
143  SCH_SHEET_PATH* aSheetPath )
144 {
145  NETLIST_OBJECT* item = new NETLIST_OBJECT();
146 
147  item->m_SheetPath = *aSheetPath;
148  item->m_SheetPathInclude = *aSheetPath;
149  item->m_Comp = this;
150  item->m_Type = NET_NOCONNECT;
151  item->m_Start = item->m_End = m_pos;
152 
153  aNetListItems.push_back( item );
154 }
155 
156 
157 bool SCH_NO_CONNECT::doIsConnected( const wxPoint& aPosition ) const
158 {
159  return m_pos == aPosition;
160 }
161 
162 bool SCH_NO_CONNECT::HitTest( const wxPoint& aPosition, int aAccuracy ) const
163 {
164  int delta = ( ( GetSize() + GetDefaultLineThickness() ) / 2 ) + aAccuracy;
165 
166  wxPoint dist = aPosition - m_pos;
167 
168  if( ( std::abs( dist.x ) <= delta ) && ( std::abs( dist.y ) <= delta ) )
169  return true;
170 
171  return false;
172 }
173 
174 
175 bool SCH_NO_CONNECT::HitTest( const EDA_RECT& aRect, bool aContained, int aAccuracy ) const
176 {
177  EDA_RECT rect = aRect;
178 
179  rect.Inflate( aAccuracy );
180 
181  if( aContained )
182  return rect.Contains( GetBoundingBox() );
183 
184  return rect.Intersects( GetBoundingBox() );
185 }
186 
187 
188 void SCH_NO_CONNECT::Plot( PLOTTER* aPlotter )
189 {
190  int delta = GetSize() / 2;
191  int pX, pY;
192 
193  pX = m_pos.x;
194  pY = m_pos.y;
195 
196  aPlotter->SetCurrentLineWidth( GetPenSize() );
197  aPlotter->SetColor( GetLayerColor( GetLayer() ) );
198  aPlotter->MoveTo( wxPoint( pX - delta, pY - delta ) );
199  aPlotter->FinishTo( wxPoint( pX + delta, pY + delta ) );
200  aPlotter->MoveTo( wxPoint( pX + delta, pY - delta ) );
201  aPlotter->FinishTo( wxPoint( pX - delta, pY + delta ) );
202 }
203 
204 
206 {
207  return noconn_xpm;
208 }
void FinishTo(const wxPoint &pos)
Definition: plotter.h:251
void MirrorY(int aYaxis_position) override
Function MirrorY mirrors item relative to the Y axis about aYaxis_position.
static const int dist[10][10]
Definition: ar_matrix.cpp:320
BITMAP_DEF GetMenuImage() const override
Function GetMenuImage returns a pointer to an image to be used in menus.
SCH_SHEET_PATH m_SheetPathInclude
virtual void SetColor(COLOR4D color)=0
wxPoint m_pos
Position of the no connect object.
int color
Definition: DXF_plotter.cpp:62
int GetDefaultLineThickness()
Default line thickness used to draw/plot items having a default thickness line value (i....
void MirrorX(int aXaxis_position) override
Function MirrorX mirrors item relative to the X axis about aXaxis_position.
void GetConnectionPoints(std::vector< wxPoint > &aPoints) const override
Function GetConnectionPoints add all the connection points for this item to aPoints.
void GetNetListItem(NETLIST_OBJECT_LIST &aNetListItems, SCH_SHEET_PATH *aSheetPath) override
Function GetNetListItem creates a new NETLIST_OBJECT for the schematic object and adds it to aNetList...
void SetOrigin(const wxPoint &pos)
Definition: eda_rect.h:124
void GetEndPoints(std::vector< DANGLING_END_ITEM > &aItemList) override
Function GetEndPoints adds the schematic item end points to aItemList if the item has end points.
SCH_SHEET_PATH m_SheetPath
virtual EDA_RECT * GetClipBox()
void RotatePoint(int *pX, int *pY, double angle)
Definition: trigo.cpp:216
NETLIST_ITEM_T m_Type
COLOR4D GetLayerColor(SCH_LAYER_ID aLayer)
Definition: eeschema.cpp:174
EDA_ITEM * m_Comp
#define abs(a)
Definition: auxiliary.h:84
SCH_NO_CONNECT(const wxPoint &pos=wxPoint(0, 0))
bool Contains(const wxPoint &aPoint) const
Function Contains.
static const int delta[8][2]
Definition: solve.cpp:112
void SwapData(SCH_ITEM *aItem) override
Function SwapData swap the internal data structures aItem with the schematic item.
This file contains miscellaneous commonly used macros and functions.
Class NETLIST_OBJECT_LIST is a container holding and owning NETLIST_OBJECTs, which are connected item...
void Draw(EDA_DRAW_PANEL *aPanel, wxDC *aDC, const wxPoint &aOffset) override
Function Draw Draw a schematic item.
void MIRROR(T &aPoint, const T &aMirrorRef)
Definition: macros.h:122
bool HitTest(const wxPoint &aPosition, int aAccuracy=0) const override
Function HitTest tests if aPosition is contained within or on the bounding box of an item.
void SetLayer(SCH_LAYER_ID aLayer)
Function SetLayer sets the layer this item is on.
Definition: sch_item.h:200
int GetSize() const
Class SCH_SHEET_PATH.
void GRLine(EDA_RECT *ClipBox, wxDC *DC, int x1, int y1, int x2, int y2, int width, COLOR4D Color, wxPenStyle aStyle)
Definition: gr_basic.cpp:285
void Plot(PLOTTER *aPlotter) override
Function Plot plots the schematic item to aPlotter.
const EDA_RECT GetBoundingBox() const override
Function GetBoundingBox returns the orthogonal, bounding box of this object for display purposes.
SCH_LAYER_ID GetLayer() const
Function GetLayer returns the layer this item is on.
Definition: sch_item.h:193
void MoveTo(const wxPoint &pos)
Definition: plotter.h:241
Base plotter engine class.
Definition: plotter.h:97
Class EDA_RECT handles the component boundary box.
Definition: eda_rect.h:44
Class EDA_ITEM is a base class for most all the KiCad significant classes, used in schematics and boa...
Definition: base_struct.h:157
The common library.
void ViewGetLayers(int aLayers[], int &aCount) const override
Function ViewGetLayers returns the layers the item is drawn on (which may be more than its "home" lay...
bool Intersects(const EDA_RECT &aRect) const
Function Intersects tests for a common area between rectangles.
void Rotate(wxPoint aPosition) override
Function Rotate rotates the item around aPosition 90 degrees in the clockwise direction.
Class DANGLING_END_ITEM is a helper class used to store the state of schematic items that can be conn...
Definition: sch_item.h:67
int GetPenSize() const override
Function GetPenSize virtual pure.
Definition of the NETLIST_OBJECT class.
EDA_ITEM * Clone() const override
Function Clone creates a duplicate of this item with linked list members set to NULL.
Class SCH_ITEM is a base class for any item which can be embedded within the SCHEMATIC container clas...
Definition: sch_item.h:114
bool doIsConnected(const wxPoint &aPosition) const override
Function doIsConnected provides the object specific test to see if it is connected to aPosition.
EDA_RECT & Inflate(wxCoord dx, wxCoord dy)
Function Inflate inflates the rectangle horizontally by dx and vertically by dy.
int m_size
Size of the no connect object.
KICAD_T Type() const
Function Type()
Definition: base_struct.h:204
virtual void SetCurrentLineWidth(int width, void *aData=NULL)=0
Set the line width for the next drawing.
Class COLOR4D is the color representation with 4 components: red, green, blue, alpha.
Definition: color4d.h:39