KiCad PCB EDA Suite
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages Concepts
sch_junction.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) 2009 Jean-Pierre Charras, jp.charras at wanadoo.fr
5 * Copyright The 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
25#include <sch_draw_panel.h>
26#include <trigo.h>
27#include <common.h>
28#include <plotters/plotter.h>
29#include <bitmaps.h>
30#include <core/mirror.h>
31#include <geometry/shape_rect.h>
32#include <sch_painter.h>
33#include <sch_junction.h>
34#include <sch_edit_frame.h>
35#include <sch_connection.h>
36#include <schematic.h>
38#include <connection_graph.h>
39#include <string_utils.h>
40
41
42SCH_JUNCTION::SCH_JUNCTION( const VECTOR2I& aPosition, int aDiameter, SCH_LAYER_ID aLayer ) :
43 SCH_ITEM( nullptr, SCH_JUNCTION_T )
44{
45 m_pos = aPosition;
46 m_color = COLOR4D::UNSPECIFIED;
47 m_diameter = aDiameter;
48 m_layer = aLayer;
49
51 m_lastResolvedColor = COLOR4D::UNSPECIFIED;
52}
53
54
56{
57 return new SCH_JUNCTION( *this );
58}
59
60
62{
63 SCH_ITEM::SwapFlags( aItem );
64
65 wxCHECK_RET( ( aItem != nullptr ) && ( aItem->Type() == SCH_JUNCTION_T ),
66 wxT( "Cannot swap junction data with invalid item." ) );
67
68 SCH_JUNCTION* item = (SCH_JUNCTION*) aItem;
69 std::swap( m_pos, item->m_pos );
70 std::swap( m_diameter, item->m_diameter );
71 std::swap( m_color, item->m_color );
72}
73
74
75std::vector<int> SCH_JUNCTION::ViewGetLayers() const
76{
78}
79
80
82{
83 if( m_diameter != 0 )
85 else if( Schematic() )
87 else
89
90 if( m_lastResolvedDiameter != 1 ) // Diameter 1 means user doesn't want to draw junctions
91 {
92 // If we know what we're connected to, then enforce a minimum size of 170% of the
93 // connected wire width:
94 if( !IsConnectivityDirty() )
95 {
97 GetEffectiveNetClass()->GetWireWidth() * 1.7 );
98 }
99 }
100
101 return SHAPE_CIRCLE( m_pos, std::max( m_lastResolvedDiameter / 2, 1 ) );
102}
103
104
106{
107 BOX2I bbox( m_pos );
108 bbox.Inflate( getEffectiveShape().GetRadius() );
109
110 return bbox;
111}
112
113
115{
116 MIRROR( m_pos.y, aCenter );
117}
118
119
121{
122 MIRROR( m_pos.x, aCenter );
123}
124
125
126void SCH_JUNCTION::Rotate( const VECTOR2I& aCenter, bool aRotateCCW )
127{
128 RotatePoint( m_pos, aCenter, aRotateCCW ? ANGLE_90 : ANGLE_270 );
129}
130
131
132void SCH_JUNCTION::GetEndPoints( std::vector <DANGLING_END_ITEM>& aItemList )
133{
134 DANGLING_END_ITEM item( JUNCTION_END, this, m_pos );
135 aItemList.push_back( item );
136}
137
138
139std::vector<VECTOR2I> SCH_JUNCTION::GetConnectionPoints() const
140{
141 return { m_pos };
142}
143
144
145#if defined(DEBUG)
146void SCH_JUNCTION::Show( int nestLevel, std::ostream& os ) const
147{
148 // XML output:
149 wxString s = GetClass();
150
151 NestedSpace( nestLevel, os ) << '<' << s.Lower().mb_str() << m_pos << ", " << m_diameter
152 << "/>\n";
153}
154#endif
155
156
157void SCH_JUNCTION::SetDiameter( int aDiameter )
158{
159 m_diameter = aDiameter;
160 m_lastResolvedDiameter = aDiameter;
161}
162
163
165{
166 if( m_color != COLOR4D::UNSPECIFIED )
168 else if( !IsConnectivityDirty() )
169 m_lastResolvedColor = GetEffectiveNetClass()->GetSchematicColor();
170
171 return m_lastResolvedColor;
172}
173
174
175void SCH_JUNCTION::SetColor( const COLOR4D& aColor )
176{
177 m_color = aColor;
178 m_lastResolvedColor = aColor;
179}
180
181
183{
184 return getEffectiveShape().GetRadius() * 2;
185}
186
187
188bool SCH_JUNCTION::HitTest( const VECTOR2I& aPosition, int aAccuracy ) const
189{
190 if( aAccuracy >= 0 )
191 return getEffectiveShape().Collide( SEG( aPosition, aPosition ), aAccuracy );
192 else
193 return aPosition == m_pos;
194}
195
196
197bool SCH_JUNCTION::HitTest( const BOX2I& aRect, bool aContained, int aAccuracy ) const
198{
200 return false;
201
202 if( aContained )
203 {
204 BOX2I selRect( aRect );
205
206 return selRect.Inflate( aAccuracy ).Contains( GetBoundingBox() );
207 }
208 else
209 {
210 SHAPE_CIRCLE junction = getEffectiveShape();
211 SHAPE_RECT selRect( aRect.GetPosition(), aRect.GetWidth(), aRect.GetHeight() );
212
213 return selRect.Collide( &junction, aAccuracy );
214 }
215}
216
217
219 const SCH_SHEET_PATH* aInstance ) const
220{
221 // Do not compare to ourself.
222 if( aItem == this )
223 return false;
224
225 const SCH_JUNCTION* junction = dynamic_cast<const SCH_JUNCTION*>( aItem );
226
227 // Don't compare against a different SCH_ITEM.
228 wxCHECK( junction, false );
229
230 return GetPosition() != junction->GetPosition();
231}
232
233
234bool SCH_JUNCTION::doIsConnected( const VECTOR2I& aPosition ) const
235{
236 return m_pos == aPosition;
237}
238
239
240void SCH_JUNCTION::Plot( PLOTTER* aPlotter, bool aBackground, const SCH_PLOT_OPTS& aPlotOpts,
241 int aUnit, int aBodyStyle, const VECTOR2I& aOffset, bool aDimmed )
242{
243 if( aBackground )
244 return;
245
246 RENDER_SETTINGS* settings = aPlotter->RenderSettings();
248
249 if( color == COLOR4D::UNSPECIFIED )
250 color = settings->GetLayerColor( GetLayer() );
251
252 aPlotter->SetColor( color );
253
254 aPlotter->Circle( m_pos, GetEffectiveDiameter(), FILL_T::FILLED_SHAPE );
255}
256
257
259{
260 return BITMAPS::add_junction;
261}
262
263
264bool SCH_JUNCTION::operator <( const SCH_ITEM& aItem ) const
265{
266 if( Type() != aItem.Type() )
267 return Type() < aItem.Type();
268
269 if( GetLayer() != aItem.GetLayer() )
270 return GetLayer() < aItem.GetLayer();
271
272 const SCH_JUNCTION* junction = static_cast<const SCH_JUNCTION*>( &aItem );
273
274 if( GetPosition().x != junction->GetPosition().x )
275 return GetPosition().x < junction->GetPosition().x;
276
277 if( GetPosition().y != junction->GetPosition().y )
278 return GetPosition().y < junction->GetPosition().y;
279
280 if( GetDiameter() != junction->GetDiameter() )
281 return GetDiameter() < junction->GetDiameter();
282
283 return GetColor() < junction->GetColor();
284}
285
286
287void SCH_JUNCTION::GetMsgPanelInfo( EDA_DRAW_FRAME* aFrame, std::vector<MSG_PANEL_ITEM>& aList )
288{
289 aList.emplace_back( _( "Junction" ), wxEmptyString );
290
291 aList.emplace_back( _( "Size" ), aFrame->MessageTextFromValue( GetEffectiveDiameter() ) );
292
293 SCH_CONNECTION* conn = nullptr;
294
295 if( !IsConnectivityDirty() && dynamic_cast<SCH_EDIT_FRAME*>( aFrame ) )
296 conn = Connection();
297
298 if( conn )
299 {
300 conn->AppendInfoToMsgPanel( aList );
301
302 if( !conn->IsBus() )
303 {
304 aList.emplace_back( _( "Resolved Netclass" ),
305 UnescapeString( GetEffectiveNetClass()->GetHumanReadableName() ) );
306 }
307 }
308}
309
310
311bool SCH_JUNCTION::operator==( const SCH_ITEM& aOther ) const
312{
313 if( Type() != aOther.Type() )
314 return false;
315
316 const SCH_JUNCTION& other = static_cast<const SCH_JUNCTION&>( aOther );
317
318 if( m_pos != other.m_pos )
319 return false;
320
321 if( m_diameter != other.m_diameter )
322 return false;
323
324 if( m_color != other.m_color )
325 return false;
326
327 return true;
328}
329
330
331double SCH_JUNCTION::Similarity( const SCH_ITEM& aOther ) const
332{
333 if( m_Uuid == aOther.m_Uuid )
334 return 1.0;
335
336 if( aOther.Type() != Type() )
337 return 0.0;
338
339 const SCH_JUNCTION& other = static_cast<const SCH_JUNCTION&>( aOther );
340
341 double similarity = 1.0;
342
343 if( m_pos != other.m_pos )
344 similarity *= 0.9;
345
346 if( m_diameter != other.m_diameter )
347 similarity *= 0.9;
348
349 if( m_color != other.m_color )
350 similarity *= 0.9;
351
352 return similarity;
353}
354
355
356static struct SCH_JUNCTION_DESC
357{
359 {
363
364 propMgr.AddProperty( new PROPERTY<SCH_JUNCTION, int>( _HKI( "Diameter" ),
366 PROPERTY_DISPLAY::PT_SIZE ) );
367
368 propMgr.AddProperty( new PROPERTY<SCH_JUNCTION, COLOR4D>( _HKI( "Color" ),
370
371 }
int color
Definition: DXF_plotter.cpp:60
constexpr EDA_IU_SCALE schIUScale
Definition: base_units.h:110
BITMAPS
A list of all bitmap identifiers.
Definition: bitmaps_list.h:33
constexpr BOX2I KiROUND(const BOX2D &aBoxD)
Definition: box2.h:990
constexpr const Vec & GetPosition() const
Definition: box2.h:211
constexpr BOX2< Vec > & Inflate(coord_type dx, coord_type dy)
Inflates the rectangle horizontally by dx and vertically by dy.
Definition: box2.h:558
constexpr size_type GetWidth() const
Definition: box2.h:214
constexpr size_type GetHeight() const
Definition: box2.h:215
constexpr bool Contains(const Vec &aPoint) const
Definition: box2.h:168
Helper class used to store the state of schematic items that can be connected to other schematic item...
Definition: sch_item.h:96
The base class for create windows for drawing purpose.
A base class for most all the KiCad significant classes used in schematics and boards.
Definition: eda_item.h:96
const KIID m_Uuid
Definition: eda_item.h:498
KICAD_T Type() const
Returns the type of object.
Definition: eda_item.h:108
EDA_ITEM_FLAGS m_flags
Definition: eda_item.h:509
A color representation with 4 components: red, green, blue, alpha.
Definition: color4d.h:104
Container for all the knowledge about how graphical objects are drawn on any output surface/device.
const COLOR4D & GetLayerColor(int aLayer) const
Return the color used to draw a layer.
Base plotter engine class.
Definition: plotter.h:105
virtual void Circle(const VECTOR2I &pos, int diametre, FILL_T fill, int width=USE_DEFAULT_LINE_WIDTH)=0
RENDER_SETTINGS * RenderSettings()
Definition: plotter.h:136
virtual void SetColor(const COLOR4D &color)=0
Provide class metadata.Helper macro to map type hashes to names.
Definition: property_mgr.h:85
void InheritsAfter(TYPE_ID aDerived, TYPE_ID aBase)
Declare an inheritance relationship between types.
static PROPERTY_MANAGER & Instance()
Definition: property_mgr.h:87
PROPERTY_BASE & AddProperty(PROPERTY_BASE *aProperty, const wxString &aGroup=wxEmptyString)
Register a property.
SCHEMATIC_SETTINGS & Settings() const
Definition: schematic.cpp:306
Each graphical item can have a SCH_CONNECTION describing its logical connection (to a bus or net).
bool IsBus() const
void AppendInfoToMsgPanel(std::vector< MSG_PANEL_ITEM > &aList) const
Adds information about the connection object to aList.
Schematic editor (Eeschema) main window.
Base class for any item which can be embedded within the SCHEMATIC container class,...
Definition: sch_item.h:167
SCHEMATIC * Schematic() const
Search the item hierarchy to find a SCHEMATIC.
Definition: sch_item.cpp:151
std::shared_ptr< NETCLASS > GetEffectiveNetClass(const SCH_SHEET_PATH *aSheet=nullptr) const
Definition: sch_item.cpp:248
SCH_LAYER_ID GetLayer() const
Return the layer this item is on.
Definition: sch_item.h:291
bool IsConnectivityDirty() const
Definition: sch_item.h:523
void SwapFlags(SCH_ITEM *aItem)
Swap the non-temp and non-edit flags.
Definition: sch_item.cpp:371
SCH_CONNECTION * Connection(const SCH_SHEET_PATH *aSheet=nullptr) const
Retrieve the connection associated with this object in the given sheet.
Definition: sch_item.cpp:219
SCH_LAYER_ID m_layer
Definition: sch_item.h:706
void Plot(PLOTTER *aPlotter, bool aBackground, const SCH_PLOT_OPTS &aPlotOpts, int aUnit, int aBodyStyle, const VECTOR2I &aOffset, bool aDimmed) override
Plot the item to aPlotter.
VECTOR2I m_pos
Definition: sch_junction.h:148
void swapData(SCH_ITEM *aItem) override
Swap the internal data structures aItem with the schematic item.
virtual bool operator<(const SCH_ITEM &aItem) const override
int GetEffectiveDiameter() const
double Similarity(const SCH_ITEM &aOther) const override
Return a measure of how likely the other object is to represent the same object.
SHAPE_CIRCLE getEffectiveShape() const
SCH_JUNCTION(const VECTOR2I &aPosition=VECTOR2I(0, 0), int aDiameter=0, SCH_LAYER_ID aLayer=LAYER_JUNCTION)
BITMAPS GetMenuImage() const override
Return a pointer to an image to be used in menus.
COLOR4D m_lastResolvedColor
Definition: sch_junction.h:156
int m_diameter
Zero is user default.
Definition: sch_junction.h:149
bool operator==(const SCH_ITEM &aOther) const override
void SetDiameter(int aDiameter)
void GetEndPoints(std::vector< DANGLING_END_ITEM > &aItemList) override
Add the schematic item end points to aItemList if the item has end points.
COLOR4D m_color
#COLOR4D::UNSPECIFIED is user default.
Definition: sch_junction.h:150
void MirrorHorizontally(int aCenter) override
Mirror item horizontally about aCenter.
COLOR4D GetColor() const
Definition: sch_junction.h:119
int GetDiameter() const
Definition: sch_junction.h:114
COLOR4D GetJunctionColor() const
void GetMsgPanelInfo(EDA_DRAW_FRAME *aFrame, std::vector< MSG_PANEL_ITEM > &aList) override
Populate aList of MSG_PANEL_ITEM objects with it's internal state for display purposes.
bool doIsConnected(const VECTOR2I &aPosition) const override
Provide the object specific test to see if it is connected to aPosition.
std::vector< VECTOR2I > GetConnectionPoints() const override
Add all the connection points for this item to aPoints.
bool HasConnectivityChanges(const SCH_ITEM *aItem, const SCH_SHEET_PATH *aInstance=nullptr) const override
Check if aItem has connectivity changes against this object.
VECTOR2I GetPosition() const override
Definition: sch_junction.h:107
void SetColor(const COLOR4D &aColor)
void MirrorVertically(int aCenter) override
Mirror item vertically about aCenter.
void Rotate(const VECTOR2I &aCenter, bool aRotateCCW) override
Rotate the item around aCenter 90 degrees in the clockwise direction.
int m_lastResolvedDiameter
Definition: sch_junction.h:155
wxString GetClass() const override
Return the class name.
Definition: sch_junction.h:50
std::vector< int > ViewGetLayers() const override
Return the layers the item is drawn on (which may be more than its "home" layer)
EDA_ITEM * Clone() const override
Create a duplicate of this item with linked list members set to NULL.
bool HitTest(const VECTOR2I &aPosition, int aAccuracy=0) const override
Test if aPosition is inside or on the boundary of this item.
const BOX2I GetBoundingBox() const override
Return the orthogonal bounding box of this object for display purposes.
Handle access to a stack of flattened SCH_SHEET objects by way of a path for creating a flattened sch...
Definition: seg.h:42
bool Collide(const SEG &aSeg, int aClearance=0, int *aActual=nullptr, VECTOR2I *aLocation=nullptr) const override
Check if the boundary of shape (this) lies closer to the segment aSeg than aClearance,...
Definition: shape_circle.h:77
int GetRadius() const
Definition: shape_circle.h:118
bool Collide(const SHAPE *aShape, int aClearance, VECTOR2I *aMTV) const override
Check if the boundary of shape (this) lies closer to the shape aShape than aClearance,...
Definition: shape_rect.h:142
wxString MessageTextFromValue(double aValue, bool aAddUnitLabel=true, EDA_DATA_TYPE aType=EDA_DATA_TYPE::DISTANCE) const
A lower-precision version of StringFromValue().
The common library.
#define DEFAULT_JUNCTION_DIAM
The default bus and wire entry size in mils.
#define DEFAULT_WIRE_WIDTH_MILS
The default bus width in mils. (can be changed in preference menu)
#define _HKI(x)
#define _(s)
static constexpr EDA_ANGLE ANGLE_90
Definition: eda_angle.h:403
static constexpr EDA_ANGLE ANGLE_270
Definition: eda_angle.h:406
#define STRUCT_DELETED
flag indication structures to be erased
#define SKIP_STRUCT
flag indicating that the structure should be ignored
SCH_LAYER_ID
Eeschema drawing layers.
Definition: layer_ids.h:438
@ LAYER_SELECTION_SHADOWS
Definition: layer_ids.h:483
constexpr void MIRROR(T &aPoint, const T &aMirrorRef)
Updates aPoint with the mirror of aPoint relative to the aMirrorRef.
Definition: mirror.h:45
#define TYPE_HASH(x)
Definition: property.h:71
#define REGISTER_TYPE(x)
Definition: property_mgr.h:371
@ JUNCTION_END
Definition: sch_item.h:81
static struct SCH_JUNCTION_DESC _SCH_JUNCTION_DESC
wxString UnescapeString(const wxString &aSource)
constexpr int MilsToIU(int mils) const
Definition: base_units.h:93
void RotatePoint(int *pX, int *pY, const EDA_ANGLE &aAngle)
Calculate the new point of coord coord pX, pY, for a rotation center 0, 0.
Definition: trigo.cpp:229
@ SCH_JUNCTION_T
Definition: typeinfo.h:159