KiCad PCB EDA Suite
Loading...
Searching...
No Matches
panel_eeschema_color_settings.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) 2020 Jon Evans <[email protected]>
5 * Copyright (C) 2020-2024 KiCad Developers, see AUTHORS.txt for contributors.
6 *
7 * This program is free software: you can redistribute it and/or modify it
8 * under the terms of the GNU General Public License as published by the
9 * Free Software Foundation, either version 3 of the License, or (at your
10 * option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License along
18 * with this program. If not, see <http://www.gnu.org/licenses/>.
19 */
20
21#include <regex>
22
23#include <eeschema_settings.h>
26#include <layer_ids.h>
27#include <sch_shape.h>
28#include <math/vector2wx.h>
29#include <page_info.h>
31#include <pgm_base.h>
32#include <sch_bus_entry.h>
33#include <sch_junction.h>
34#include <sch_line.h>
35#include <sch_no_connect.h>
36#include <sch_painter.h>
37#include <sch_preview_panel.h>
38#include <sch_sheet_pin.h>
39#include <sch_text.h>
43#include <title_block.h>
44#include <view/view.h>
46#include <sch_base_frame.h>
48#include <widgets/wx_panel.h>
49#include <wx/msgdlg.h>
50
51
52std::set<int> g_excludedLayers =
53 {
57 };
58
59
61 PANEL_COLOR_SETTINGS( aParent ),
62 m_preview( nullptr ),
63 m_page( nullptr ),
64 m_titleBlock( nullptr ),
65 m_drawingSheet( nullptr ),
66 m_previewItems()
67{
68 m_colorNamespace = "schematic";
69
71 COMMON_SETTINGS* common_settings = Pgm().GetCommonSettings();
73 COLOR_SETTINGS* current = mgr.GetColorSettings( app_settings->m_ColorTheme );
74
75 // Saved theme doesn't exist? Reset to default
76 if( current->GetFilename() != app_settings->m_ColorTheme )
77 app_settings->m_ColorTheme = current->GetFilename();
78
79 createThemeList( app_settings->m_ColorTheme );
80
81 m_optOverrideColors->SetValue( current->GetOverrideSchItemColors() );
82
83 m_currentSettings = new COLOR_SETTINGS( *current );
84
85 for( int id = SCH_LAYER_ID_START; id < SCH_LAYER_ID_END; id++ )
86 {
87 if( g_excludedLayers.count( id ) )
88 continue;
89
90 m_validLayers.push_back( id );
91 }
92
94
95 m_galDisplayOptions.ReadConfig( *common_settings, app_settings->m_Window, this );
97
98 m_galType = static_cast<EDA_DRAW_PANEL_GAL::GAL_TYPE>( app_settings->m_Graphics.canvas_type );
99}
100
101
103{
104 delete m_page;
105 delete m_titleBlock;
106 delete m_drawingSheet;
107 delete m_currentSettings;
108
109 for( EDA_ITEM* item : m_previewItems )
110 {
111 // Avoid referencing items after they are deleted (we don't control order)
112 item->SetParent( nullptr );
113 delete item;
114 }
115}
116
117
119{
121
122 if( !saveCurrentTheme( true ) )
123 return false;
124
125 SETTINGS_MANAGER& settingsMgr = Pgm().GetSettingsManager();
126 EESCHEMA_SETTINGS* app_settings = settingsMgr.GetAppSettings<EESCHEMA_SETTINGS>();
127 app_settings->m_ColorTheme = m_currentSettings->GetFilename();
128
129 return true;
130}
131
132
134{
136 return true;
137}
138
139
141{
143
144 for( SCH_LAYER_ID layer = SCH_LAYER_ID_START; layer < SCH_LAYER_ID_END; ++layer )
145 {
146 if( bgcolor == m_currentSettings->GetColor( layer )
147 && layer != LAYER_SCHEMATIC_BACKGROUND && layer != LAYER_SHEET_BACKGROUND )
148 {
149 wxString msg = _( "Some items have the same color as the background\n"
150 "and they will not be seen on the screen. Are you\n"
151 "sure you want to use these colors?" );
152
153 if( wxMessageBox( msg, _( "Warning" ), wxYES_NO | wxICON_QUESTION,
154 wxGetTopLevelParent( this ) ) == wxNO )
155 return false;
156
157 break;
158 }
159 }
160
161 return true;
162}
163
164
166{
167 for( int layer : m_validLayers )
168 {
170
171 // Do not allow non-background layers to be completely white.
172 // This ensures the BW printing recognizes that the colors should be printed black.
173 if( color == COLOR4D::WHITE && layer != LAYER_SCHEMATIC_BACKGROUND
174 && layer != LAYER_SHEET_BACKGROUND )
175 {
176 color.Darken( 0.01 );
177 }
178
180 }
181
182 return PANEL_COLOR_SETTINGS::saveCurrentTheme( aValidate );
183}
184
185
187{
188 std::vector<SCH_LAYER_ID> layers;
189
191 {
192 if( g_excludedLayers.count( i ) )
193 continue;
194
195 layers.push_back( i );
196 }
197
198 std::sort( layers.begin(), layers.end(),
199 []( SCH_LAYER_ID a, SCH_LAYER_ID b )
200 {
201 return LayerName( a ) < LayerName( b );
202 } );
203
204 for( int layer : layers )
205 {
206 wxString name = LayerName( layer );
207
208 if( layer == LAYER_SCHEMATIC_GRID_AXES )
209 name += wxS( " " ) + _( "(symbol editor only)" );
210
211 createSwatch( layer, name );
212 }
213
214 // Give a minimal width to m_colorsListWindow, in order to always having
215 // a full row shown
216 int min_width = m_colorsGridSizer->GetMinSize().x;
217 const int margin = 20; // A margin around the sizer
218 m_colorsListWindow->SetMinSize( wxSize( min_width + margin, -1 ) );
219
220 m_preview = new SCH_PREVIEW_PANEL( m_panel1, wxID_ANY, wxDefaultPosition, wxSize( -1, -1 ),
222 m_preview->SetStealsFocus( false );
223 m_preview->ShowScrollbars( wxSHOW_SB_NEVER, wxSHOW_SB_NEVER );
224 m_preview->GetGAL()->SetAxesEnabled( false );
225
227 settings->m_IsSymbolEditor = true;
228
229 m_colorsMainSizer->Add( m_preview, 1, wxTOP | wxEXPAND, 1 );
230
231 m_colorsMainSizer->Layout();
232
237}
238
239
241{
243}
244
245
247{
248 KIGFX::VIEW* view = m_preview->GetView();
249
250 std::vector<DANGLING_END_ITEM> endPointsByType;
251
254 m_titleBlock->SetTitle( _( "Color Preview" ) );
255 m_titleBlock->SetDate( wxDateTime::Now().FormatDate() );
256
257 m_page->SetHeightMils( 5000 );
258 m_page->SetWidthMils( 6000 );
259
263 view->Add( m_drawingSheet );
264
265 // TODO: It would be nice to parse a schematic file here.
266
267 auto addItem = [&]( EDA_ITEM* aItem )
268 {
269 view->Add( aItem );
270 m_previewItems.push_back( aItem );
271 };
272
273 std::vector<std::pair<SCH_LAYER_ID, std::pair<VECTOR2I, VECTOR2I>>> lines = {
274 { LAYER_WIRE, { { 1950, 1500 }, { 2325, 1500 } } },
275 { LAYER_WIRE, { { 1950, 2600 }, { 2350, 2600 } } },
276 { LAYER_WIRE, { { 2150, 1700 }, { 2325, 1700 } } },
277 { LAYER_WIRE, { { 2150, 2000 }, { 2150, 1700 } } },
278 { LAYER_WIRE, { { 2925, 1600 }, { 3075, 1600 } } },
279 { LAYER_WIRE, { { 3075, 1600 }, { 3075, 2000 } } },
280 { LAYER_WIRE, { { 3075, 1600 }, { 3250, 1600 } } },
281 { LAYER_WIRE, { { 3075, 2000 }, { 2150, 2000 } } },
282 { LAYER_BUS, { { 1750, 1300 }, { 1850, 1300 } } },
283 { LAYER_BUS, { { 1850, 2500 }, { 1850, 1300 } } },
284 { LAYER_NOTES, { { 2350, 2125 }, { 2350, 2300 } } },
285 { LAYER_NOTES, { { 2350, 2125 }, { 2950, 2125 } } },
286 { LAYER_NOTES, { { 2950, 2125 }, { 2950, 2300 } } },
287 { LAYER_NOTES, { { 2950, 2300 }, { 2350, 2300 } } }
288 };
289
290 for( const std::pair<SCH_LAYER_ID, std::pair<VECTOR2I, VECTOR2I>>& line : lines )
291 {
292 SCH_LINE* wire = new SCH_LINE;
293 wire->SetLayer( line.first );
294 STROKE_PARAMS stroke = wire->GetStroke();
295 stroke.SetWidth( schIUScale.MilsToIU( 6 ) );
296
297 if( line.first != LAYER_NOTES )
298 {
299 stroke.SetLineStyle( LINE_STYLE::SOLID );
300
301 if( line.first == LAYER_BUS )
302 stroke.SetWidth( schIUScale.MilsToIU( 12 ) );
303
304 }
305
306 wire->SetStroke( stroke );
307
308 wire->SetStartPoint( VECTOR2I( schIUScale.MilsToIU( line.second.first.x ),
309 schIUScale.MilsToIU( line.second.first.y ) ) );
310 wire->SetEndPoint( VECTOR2I( schIUScale.MilsToIU( line.second.second.x ),
311 schIUScale.MilsToIU( line.second.second.y ) ) );
312 addItem( wire );
313 }
314
315#define MILS_POINT( x, y ) VECTOR2I( schIUScale.MilsToIU( x ), schIUScale.MilsToIU( y ) )
316
318 nc->SetPosition( MILS_POINT( 2350, 2600 ) );
319 addItem( nc );
320
322 e1->SetPosition( MILS_POINT( 1850, 1400 ) );
323 addItem( e1 );
324
326 e2->SetPosition( MILS_POINT( 1850, 2500 ) );
327 addItem( e2 );
328
329 SCH_TEXT* t1 = new SCH_TEXT( MILS_POINT( 2650, 2240 ), wxT( "PLAIN TEXT" ) );
330 addItem( t1 );
331
332 SCH_LABEL* t2 = new SCH_LABEL( MILS_POINT( 1975, 1500 ), wxT( "LABEL_{0}" ) );
334 t2->SetIsDangling( false );
335 addItem( t2 );
336
337 SCH_LABEL* t3 = new SCH_LABEL( MILS_POINT( 1975, 2600 ), wxT( "LABEL_{1}" ) );
339 t3->SetIsDangling( false );
340 addItem( t3 );
341
342 SCH_GLOBALLABEL* t4 = new SCH_GLOBALLABEL( MILS_POINT( 1750, 1300 ), wxT( "GLOBAL[0..3]" ) );
344 t4->SetIsDangling( false );
345 addItem( t4 );
346
347 SCH_HIERLABEL* t5 = new SCH_HIERLABEL( MILS_POINT( 3250, 1600 ), wxT( "HIER_LABEL" ) );
349 t5->SetIsDangling( false );
350 addItem( t5 );
351
352 SCH_JUNCTION* j = new SCH_JUNCTION( MILS_POINT( 3075, 1600 ) );
353 addItem( j );
354
355 t2->SetSelected();
356
357 {
358 auto mapLibItemPosition =
359 []( const VECTOR2I& aLibPosition ) -> VECTOR2I
360 {
361 // Currently, the mapping is a no-op.
362 return VECTOR2I( aLibPosition.x, aLibPosition.y );
363 };
364
365 LIB_SYMBOL* symbol = new LIB_SYMBOL( wxEmptyString );
366 VECTOR2I p( 2625, 1600 );
367
368 SCH_FIELD& ref = symbol->GetReferenceField();
369
370 ref.SetText( wxT( "U1" ) );
371 ref.SetPosition( MILS_POINT( p.x + 30, p.y - 260 ) );
373
374 SCH_FIELD& value = symbol->GetValueField();
375
376 value.SetText( wxT( "OPA604" ) );
377 value.SetPosition( MILS_POINT( p.x + 30, p.y - 180 ) );
379
380 symbol->SetShowPinNames( true );
381 symbol->SetShowPinNumbers( true );
382 symbol->SetPinNameOffset( 0 );
383
384 SCH_SHAPE* comp_body = new SCH_SHAPE( SHAPE_T::POLY, LAYER_DEVICE );
385
386 comp_body->SetParent( symbol );
387 comp_body->SetUnit( 0 );
388 comp_body->SetBodyStyle( 0 );
389 comp_body->SetStroke( STROKE_PARAMS( schIUScale.MilsToIU( 10 ), LINE_STYLE::SOLID ) );
390 comp_body->SetFillMode( FILL_T::FILLED_WITH_BG_BODYCOLOR );
391 comp_body->AddPoint( MILS_POINT( p.x - 200, p.y + 200 ) );
392 comp_body->AddPoint( MILS_POINT( p.x + 200, p.y ) );
393 comp_body->AddPoint( MILS_POINT( p.x - 200, p.y - 200 ) );
394 comp_body->AddPoint( MILS_POINT( p.x - 200, p.y + 200 ) );
395
396 addItem( comp_body );
397
398 SCH_PIN* pin = new SCH_PIN( symbol );
399
400 pin->SetPosition( MILS_POINT( p.x - 300, p.y - 100 ) );
401 pin->SetLength( schIUScale.MilsToIU( 100 ) );
402 pin->SetOrientation( PIN_ORIENTATION::PIN_RIGHT );
403 pin->SetType( ELECTRICAL_PINTYPE::PT_INPUT );
404 pin->SetNumber( wxT( "1" ) );
405 pin->SetName( wxT( "-" ) );
406 pin->SetNumberTextSize( schIUScale.MilsToIU( 50 ) );
407 pin->SetNameTextSize( schIUScale.MilsToIU( 50 ) );
408
409 endPointsByType.emplace_back( PIN_END, pin, mapLibItemPosition( pin->GetPosition() ) );
410 symbol->AddDrawItem( pin );
411
412 pin = new SCH_PIN( symbol );
413
414 pin->SetPosition( MILS_POINT( p.x - 300, p.y + 100 ) );
415 pin->SetLength( schIUScale.MilsToIU( 100 ) );
416 pin->SetOrientation( PIN_ORIENTATION::PIN_RIGHT );
417 pin->SetType( ELECTRICAL_PINTYPE::PT_INPUT );
418 pin->SetNumber( wxT( "2" ) );
419 pin->SetName( wxT( "+" ) );
420 pin->SetNumberTextSize( schIUScale.MilsToIU( 50 ) );
421 pin->SetNameTextSize( schIUScale.MilsToIU( 50 ) );
422
423 endPointsByType.emplace_back( PIN_END, pin, mapLibItemPosition( pin->GetPosition() ) );
424 symbol->AddDrawItem( pin );
425
426 pin = new SCH_PIN( symbol );
427
428 pin->SetPosition( MILS_POINT( p.x + 300, p.y ) );
429 pin->SetLength( schIUScale.MilsToIU( 100 ) );
430 pin->SetOrientation( PIN_ORIENTATION::PIN_LEFT );
431 pin->SetType( ELECTRICAL_PINTYPE::PT_OUTPUT );
432 pin->SetNumber( wxT( "3" ) );
433 pin->SetName( wxT( "OUT" ) );
434 pin->SetNumberTextSize( schIUScale.MilsToIU( 50 ) );
435 pin->SetNameTextSize( schIUScale.MilsToIU( 50 ) );
436
437 endPointsByType.emplace_back( PIN_END, pin, mapLibItemPosition( pin->GetPosition() ) );
438 symbol->AddDrawItem( pin );
439
440 addItem( symbol );
441 }
442
443 SCH_SHEET* s = new SCH_SHEET(
444 /* aParent */ nullptr,
445 /* aPosition */ MILS_POINT( 4000, 1300 ),
446 /* aSize */ VECTOR2I( schIUScale.MilsToIU( 800 ), schIUScale.MilsToIU( 1300 ) ) );
447 s->GetFields().at( SHEETNAME ).SetText( wxT( "SHEET" ) );
448 s->GetFields().at( SHEETFILENAME ).SetText( _( "/path/to/sheet" ) );
449 s->AutoplaceFields( nullptr, false );
450 addItem( s );
451
452 SCH_SHEET_PIN* sp = new SCH_SHEET_PIN( s, MILS_POINT( 4500, 1500 ), wxT( "SHEET PIN" ) );
453 addItem( sp );
454
455 for( EDA_ITEM* item : m_previewItems )
456 {
457 SCH_ITEM* sch_item = dynamic_cast<SCH_ITEM*>( item );
458
459 if( sch_item && sch_item->IsConnectable() )
460 {
461 sch_item->AutoplaceFields( nullptr, false );
462 sch_item->GetEndPoints( endPointsByType );
463 }
464 }
465
466 std::vector<DANGLING_END_ITEM> endPointsByPos = endPointsByType;
467 DANGLING_END_ITEM_HELPER::sort_dangling_end_items( endPointsByType, endPointsByPos );
468
469 for( EDA_ITEM* item : m_previewItems )
470 {
471 SCH_ITEM* sch_item = dynamic_cast<SCH_ITEM*>( item );
472
473 if( sch_item && sch_item->IsConnectable() )
474 sch_item->UpdateDanglingState( endPointsByType, endPointsByPos, nullptr );
475 }
476
478}
479
480
482{
484}
485
486
488{
491}
492
493
495{
496 if( !m_preview )
497 return;
498
499 KIGFX::VIEW* view = m_preview->GetView();
500 auto settings = static_cast<SCH_RENDER_SETTINGS*>( view->GetPainter()->GetSettings() );
501 settings->LoadColors( m_currentSettings );
502
503 m_preview->GetGAL()->SetClearColor( settings->GetBackgroundColor() );
504
506 auto rect = m_preview->GetScreenRect();
507 m_preview->Refresh( true, &rect );
508}
509
510
512{
513 if( m_preview )
514 {
515 KIGFX::VIEW* view = m_preview->GetView();
516
517 view->SetScale( 1.0 );
518 VECTOR2D screenSize = view->ToWorld( ToVECTOR2D( m_preview->GetClientSize() ), false );
519
521 double scale = view->GetScale() / std::max( fabs( psize.x / screenSize.x ),
522 fabs( psize.y / screenSize.y ) );
523
524 view->SetScale( scale * m_galDisplayOptions.m_scaleFactor * 0.8 /* margin */ );
527 }
528}
529
530
531void PANEL_EESCHEMA_COLOR_SETTINGS::OnSize( wxSizeEvent& aEvent )
532{
534 aEvent.Skip();
535}
536
537
539{
540 // If the theme is not overriding individual item colors then don't show them so that
541 // the user doesn't get seduced into thinking they'll have some effect.
544
547
548 m_colorsGridSizer->Layout();
549 m_colorsListWindow->Layout();
550}
551
552
554{
557}
int color
Definition: DXF_plotter.cpp:58
const char * name
Definition: DXF_plotter.cpp:57
constexpr EDA_IU_SCALE schIUScale
Definition: base_units.h:110
WINDOW_SETTINGS m_Window
Definition: app_settings.h:172
wxString m_ColorTheme
Active color theme name.
Definition: app_settings.h:175
Vec Centre() const
Definition: box2.h:87
Color settings are a bit different than most of the settings objects in that there can be more than o...
void SetColor(int aLayer, const COLOR4D &aColor)
bool GetOverrideSchItemColors() const
COLOR4D GetColor(int aLayer) const
void SetOverrideSchItemColors(bool aFlag)
static void sort_dangling_end_items(std::vector< DANGLING_END_ITEM > &aItemListByType, std::vector< DANGLING_END_ITEM > &aItemListByPos)
Both contain the same information.
Definition: sch_item.cpp:615
const BOX2I ViewBBox() const override
void SetPageBorderColorLayer(int aLayerId)
Overrides the layer used to pick the color of the page border (normally LAYER_GRID)
void SetColorLayer(int aLayerId)
Can be used to override which layer ID is used for drawing sheet item colors.
virtual KIGFX::VIEW * GetView() const
Return a pointer to the #VIEW instance used in the panel.
void ForceRefresh()
Force a redraw.
KIGFX::GAL * GetGAL() const
Return a pointer to the GAL instance used in the panel.
void SetStealsFocus(bool aStealsFocus)
Set whether focus is taken on certain events (mouseover, keys, etc).
A base class for most all the KiCad significant classes used in schematics and boards.
Definition: eda_item.h:89
void SetSelected()
Definition: eda_item.h:119
virtual void SetParent(EDA_ITEM *aParent)
Definition: eda_item.h:104
void SetFillMode(FILL_T aFill)
Definition: eda_shape.h:106
void SetHorizJustify(GR_TEXT_H_ALIGN_T aType)
Definition: eda_text.cpp:298
void ReadConfig(COMMON_SETTINGS &aCommonConfig, WINDOW_SETTINGS &aWindowConfig, wxWindow *aWindow)
Read application and common configs.
wxString GetFilename() const
Definition: json_settings.h:80
A color representation with 4 components: red, green, blue, alpha.
Definition: color4d.h:104
bool m_forceDisplayCursor
The pixel scale factor (>1 for hi-DPI scaled displays)
void SetAxesEnabled(bool aAxesEnabled)
Enable drawing the axes.
void SetClearColor(const COLOR4D &aColor)
virtual RENDER_SETTINGS * GetSettings()=0
Return a pointer to current settings that are going to be used when drawing items.
Hold a (potentially large) number of VIEW_ITEMs and renders them on a graphics device provided by the...
Definition: view.h:68
double GetScale() const
Definition: view.h:277
virtual void SetScale(double aScale, VECTOR2D aAnchor={ 0, 0 })
Set the scaling factor, zooming around a given anchor point.
Definition: view.cpp:587
virtual void Add(VIEW_ITEM *aItem, int aDrawPriority=-1)
Add a VIEW_ITEM to the view.
Definition: view.cpp:317
VECTOR2D ToWorld(const VECTOR2D &aCoord, bool aAbsolute=true) const
Converts a screen space point/vector to a point/vector in world space coordinates.
Definition: view.cpp:484
void UpdateAllItems(int aUpdateFlags)
Update all items in the view according to the given flags.
Definition: view.cpp:1563
PAINTER * GetPainter() const
Return the painter object used by the view for drawing #VIEW_ITEMS.
Definition: view.h:221
void SetCenter(const VECTOR2D &aCenter)
Set the center point of the VIEW (i.e.
Definition: view.cpp:613
Define a library symbol object.
Definition: lib_symbol.h:78
SCH_FIELD & GetValueField() const
Return reference to the value field.
SCH_FIELD & GetReferenceField() const
Return reference to the reference designator field.
void AddDrawItem(SCH_ITEM *aItem, bool aSort=true)
Add a new draw aItem to the draw object list and sort according to aSort.
Definition: lib_symbol.cpp:796
Describe the page size and margins of a paper page on which to eventually print or plot.
Definition: page_info.h:59
int GetHeightIU(double aIUScale) const
Gets the page height in IU.
Definition: page_info.h:162
static const wxChar Custom[]
"User" defined page type
Definition: page_info.h:82
void SetHeightMils(double aHeightInMils)
Definition: page_info.cpp:261
int GetWidthIU(double aIUScale) const
Gets the page width in IU.
Definition: page_info.h:153
void SetWidthMils(double aWidthInMils)
Definition: page_info.cpp:247
void createThemeList(const wxString &aCurrent)
Builds the theme listbox and sets the selection to the current theme.
void createSwatch(int aLayer, const wxString &aName)
std::vector< int > m_validLayers
A list of layer IDs that are valid for the current color settings dialog.
virtual bool saveCurrentTheme(bool aValidate)
std::string m_colorNamespace
A namespace that will be passed to SETTINGS_MANAGER::SaveColorSettings.
virtual void ResetPanel() override
Reset the contents of this panel.
std::map< int, wxStaticText * > m_labels
COLOR_SETTINGS * m_currentSettings
std::map< int, COLOR_SWATCH * > m_swatches
bool saveCurrentTheme(bool aValidate) override
void onNewThemeSelected() override
Event fired when a new theme is selected that can be overridden in children.
void OnOverrideItemColorsClicked(wxCommandEvent &aEvent) override
bool validateSave(bool aQuiet=false) override
Performs a pre-save validation of the current color theme.
void ResetPanel() override
Reset the contents of this panel.
GAL_DISPLAY_OPTIONS_IMPL m_galDisplayOptions
void OnSize(wxSizeEvent &aEvent) override
EDA_DRAW_PANEL_GAL::GAL_TYPE m_galType
void onColorChanged() override
Event fired when the user changes any color.
virtual COMMON_SETTINGS * GetCommonSettings() const
Definition: pgm_base.cpp:678
virtual SETTINGS_MANAGER & GetSettingsManager() const
Definition: pgm_base.h:142
void SetPosition(const VECTOR2I &aPosition) override
Class for a wire to bus entry.
Instances are attached to a symbol or sheet and provide a place for the symbol's value,...
Definition: sch_field.h:51
void SetPosition(const VECTOR2I &aPosition) override
Definition: sch_field.cpp:1458
void SetText(const wxString &aText) override
Definition: sch_field.cpp:1205
void SetSpinStyle(SPIN_STYLE aSpinStyle) override
Definition: sch_label.cpp:1879
void SetSpinStyle(SPIN_STYLE aSpinStyle) override
Definition: sch_label.cpp:2060
Base class for any item which can be embedded within the SCHEMATIC container class,...
Definition: sch_item.h:166
virtual void SetBodyStyle(int aBodyStyle)
Definition: sch_item.h:231
virtual bool IsConnectable() const
Definition: sch_item.h:449
virtual void GetEndPoints(std::vector< DANGLING_END_ITEM > &aItemList)
Add the schematic item end points to aItemList if the item has end points.
Definition: sch_item.h:415
virtual bool UpdateDanglingState(std::vector< DANGLING_END_ITEM > &aItemListByType, std::vector< DANGLING_END_ITEM > &aItemListByPos, const SCH_SHEET_PATH *aSheet=nullptr)
Test the schematic item to aItemList to check if it's dangling state has changed.
Definition: sch_item.h:435
void SetLayer(SCH_LAYER_ID aLayer)
Definition: sch_item.h:282
virtual void SetUnit(int aUnit)
Definition: sch_item.h:228
virtual void AutoplaceFields(SCH_SCREEN *aScreen, bool aManual)
Definition: sch_item.h:566
void SetIsDangling(bool aIsDangling)
Definition: sch_label.h:325
virtual void SetSpinStyle(SPIN_STYLE aSpinStyle)
Definition: sch_label.cpp:348
Segment description base class to describe items which have 2 end points (track, wire,...
Definition: sch_line.h:41
void SetStartPoint(const VECTOR2I &aPosition)
Definition: sch_line.h:137
virtual STROKE_PARAMS GetStroke() const override
Definition: sch_line.h:184
virtual void SetStroke(const STROKE_PARAMS &aStroke) override
Definition: sch_line.h:185
void SetEndPoint(const VECTOR2I &aPosition)
Definition: sch_line.h:142
void SetPosition(const VECTOR2I &aPosition) override
void Refresh(bool aEraseBackground, const wxRect *aRect) override
SCH_RENDER_SETTINGS * GetRenderSettings() const
void LoadColors(const COLOR_SETTINGS *aSettings) override
void SetStroke(const STROKE_PARAMS &aStroke) override
Definition: sch_shape.cpp:63
void AddPoint(const VECTOR2I &aPosition)
Definition: sch_shape.cpp:576
Define a sheet pin (label) used in sheets to create hierarchical schematics.
Definition: sch_sheet_pin.h:66
Sheet symbol placed in a schematic, and is the entry point for a sub schematic.
Definition: sch_sheet.h:57
std::vector< SCH_FIELD > & GetFields()
Definition: sch_sheet.h:93
void AutoplaceFields(SCH_SCREEN *aScreen, bool aManual) override
Definition: sch_sheet.cpp:663
T * GetAppSettings()
Returns a handle to the a given settings by type If the settings have already been loaded,...
COLOR_SETTINGS * GetColorSettings(const wxString &aName="user")
Retrieves a color settings object that applications can read colors from.
Simple container to manage line stroke parameters.
Definition: stroke_params.h:81
void SetLineStyle(LINE_STYLE aLineStyle)
Definition: stroke_params.h:95
void SetWidth(int aWidth)
Definition: stroke_params.h:92
virtual void SetShowPinNumbers(bool aShow)
Set or clear the pin number visibility flag.
Definition: symbol.h:129
virtual void SetShowPinNames(bool aShow)
Set or clear the pin name visibility flag.
Definition: symbol.h:123
void SetPinNameOffset(int aOffset)
Set the offset in mils of the pin name text from the pin symbol.
Definition: symbol.h:117
Hold the information shown in the lower right corner of a plot, printout, or editing view.
Definition: title_block.h:41
void SetTitle(const wxString &aTitle)
Definition: title_block.h:58
void SetDate(const wxString &aDate)
Set the date field, and defaults to the current time and date.
Definition: title_block.h:71
#define _(s)
wxString LayerName(int aLayer)
Returns the default display name for a given layer.
Definition: layer_id.cpp:30
SCH_LAYER_ID
Eeschema drawing layers.
Definition: layer_ids.h:354
@ LAYER_DANGLING
Definition: layer_ids.h:382
@ LAYER_DEVICE
Definition: layer_ids.h:371
@ LAYER_SHEET_BACKGROUND
Definition: layer_ids.h:389
@ LAYER_WIRE
Definition: layer_ids.h:357
@ LAYER_NOTES
Definition: layer_ids.h:372
@ LAYER_NET_COLOR_HIGHLIGHT
Definition: layer_ids.h:397
@ LAYER_BUS
Definition: layer_ids.h:358
@ SCH_LAYER_ID_END
Definition: layer_ids.h:407
@ SCH_LAYER_ID_START
Definition: layer_ids.h:355
@ LAYER_SCHEMATIC_DRAWINGSHEET
Definition: layer_ids.h:399
@ LAYER_SCHEMATIC_GRID_AXES
Definition: layer_ids.h:391
@ LAYER_NOTES_BACKGROUND
Definition: layer_ids.h:374
@ LAYER_SCHEMATIC_PAGE_LIMITS
Definition: layer_ids.h:400
@ LAYER_SHEET
Definition: layer_ids.h:376
@ LAYER_SCHEMATIC_BACKGROUND
Definition: layer_ids.h:392
@ COLOR
Color has changed.
Definition: view_item.h:53
#define MILS_POINT(x, y)
std::set< int > g_excludedLayers
PGM_BASE & Pgm()
The global Program "get" accessor.
Definition: pgm_base.cpp:1059
see class PGM_BASE
@ PIN_END
Definition: sch_item.h:81
@ SHEETNAME
Definition: sch_sheet.h:45
@ SHEETFILENAME
Definition: sch_sheet.h:46
const int scale
const double IU_PER_MILS
Definition: base_units.h:77
constexpr int MilsToIU(int mils) const
Definition: base_units.h:93
@ GR_TEXT_H_ALIGN_LEFT
VECTOR2< int32_t > VECTOR2I
Definition: vector2d.h:676
VECTOR2D ToVECTOR2D(const wxPoint &aPoint)
Definition: vector2wx.h:40