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();
72 EESCHEMA_SETTINGS* app_settings = mgr.GetAppSettings<EESCHEMA_SETTINGS>( "eeschema" );
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
126 EESCHEMA_SETTINGS* cfg = mgr.GetAppSettings<EESCHEMA_SETTINGS>( "eeschema" );
127
129
130 return true;
131}
132
133
135{
137 return true;
138}
139
140
142{
144
145 for( SCH_LAYER_ID layer = SCH_LAYER_ID_START; layer < SCH_LAYER_ID_END; ++layer )
146 {
147 if( bgcolor == m_currentSettings->GetColor( layer )
148 && layer != LAYER_SCHEMATIC_BACKGROUND && layer != LAYER_SHEET_BACKGROUND )
149 {
150 wxString msg = _( "Some items have the same color as the background\n"
151 "and they will not be seen on the screen. Are you\n"
152 "sure you want to use these colors?" );
153
154 if( wxMessageBox( msg, _( "Warning" ), wxYES_NO | wxICON_QUESTION,
155 wxGetTopLevelParent( this ) ) == wxNO )
156 return false;
157
158 break;
159 }
160 }
161
162 return true;
163}
164
165
167{
168 for( int layer : m_validLayers )
169 {
171
172 // Do not allow non-background layers to be completely white.
173 // This ensures the BW printing recognizes that the colors should be printed black.
174 if( color == COLOR4D::WHITE && layer != LAYER_SCHEMATIC_BACKGROUND
175 && layer != LAYER_SHEET_BACKGROUND )
176 {
177 color.Darken( 0.01 );
178 }
179
181 }
182
183 return PANEL_COLOR_SETTINGS::saveCurrentTheme( aValidate );
184}
185
186
188{
189 std::vector<SCH_LAYER_ID> layers;
190
192 {
193 if( g_excludedLayers.count( i ) )
194 continue;
195
196 layers.push_back( i );
197 }
198
199 std::sort( layers.begin(), layers.end(),
200 []( SCH_LAYER_ID a, SCH_LAYER_ID b )
201 {
202 return LayerName( a ) < LayerName( b );
203 } );
204
205 for( int layer : layers )
206 {
207 wxString name = LayerName( layer );
208
209 if( layer == LAYER_SCHEMATIC_GRID_AXES )
210 name += wxS( " " ) + _( "(symbol editor only)" );
211
212 createSwatch( layer, name );
213 }
214
215 // Give a minimal width to m_colorsListWindow, in order to always having
216 // a full row shown
217 int min_width = m_colorsGridSizer->GetMinSize().x;
218 const int margin = 20; // A margin around the sizer
219 m_colorsListWindow->SetMinSize( wxSize( min_width + margin, -1 ) );
220
221 m_preview = new SCH_PREVIEW_PANEL( m_panel1, wxID_ANY, wxDefaultPosition, wxSize( -1, -1 ),
223 m_preview->SetStealsFocus( false );
224 m_preview->ShowScrollbars( wxSHOW_SB_NEVER, wxSHOW_SB_NEVER );
225 m_preview->GetGAL()->SetAxesEnabled( false );
226
228 settings->m_IsSymbolEditor = true;
229
230 m_colorsMainSizer->Add( m_preview, 1, wxTOP | wxEXPAND, 1 );
231
232 m_colorsMainSizer->Layout();
233
238}
239
240
242{
244}
245
246
248{
249 KIGFX::VIEW* view = m_preview->GetView();
250
251 std::vector<DANGLING_END_ITEM> endPointsByType;
252
255 m_titleBlock->SetTitle( _( "Color Preview" ) );
256 m_titleBlock->SetDate( wxDateTime::Now().FormatDate() );
257
258 m_page->SetHeightMils( 5000 );
259 m_page->SetWidthMils( 6000 );
260
264 view->Add( m_drawingSheet );
265
266 // TODO: It would be nice to parse a schematic file here.
267
268 auto addItem = [&]( EDA_ITEM* aItem )
269 {
270 view->Add( aItem );
271 m_previewItems.push_back( aItem );
272 };
273
274 std::vector<std::pair<SCH_LAYER_ID, std::pair<VECTOR2I, VECTOR2I>>> lines = {
275 { LAYER_WIRE, { { 1950, 1500 }, { 2325, 1500 } } },
276 { LAYER_WIRE, { { 1950, 2600 }, { 2350, 2600 } } },
277 { LAYER_WIRE, { { 2150, 1700 }, { 2325, 1700 } } },
278 { LAYER_WIRE, { { 2150, 2000 }, { 2150, 1700 } } },
279 { LAYER_WIRE, { { 2925, 1600 }, { 3075, 1600 } } },
280 { LAYER_WIRE, { { 3075, 1600 }, { 3075, 2000 } } },
281 { LAYER_WIRE, { { 3075, 1600 }, { 3250, 1600 } } },
282 { LAYER_WIRE, { { 3075, 2000 }, { 2150, 2000 } } },
283 { LAYER_BUS, { { 1750, 1300 }, { 1850, 1300 } } },
284 { LAYER_BUS, { { 1850, 2500 }, { 1850, 1300 } } },
285 { LAYER_NOTES, { { 2350, 2125 }, { 2350, 2300 } } },
286 { LAYER_NOTES, { { 2350, 2125 }, { 2950, 2125 } } },
287 { LAYER_NOTES, { { 2950, 2125 }, { 2950, 2300 } } },
288 { LAYER_NOTES, { { 2950, 2300 }, { 2350, 2300 } } }
289 };
290
291 for( const std::pair<SCH_LAYER_ID, std::pair<VECTOR2I, VECTOR2I>>& line : lines )
292 {
293 SCH_LINE* wire = new SCH_LINE;
294 wire->SetLayer( line.first );
295 STROKE_PARAMS stroke = wire->GetStroke();
296 stroke.SetWidth( schIUScale.MilsToIU( 6 ) );
297
298 if( line.first != LAYER_NOTES )
299 {
300 stroke.SetLineStyle( LINE_STYLE::SOLID );
301
302 if( line.first == LAYER_BUS )
303 stroke.SetWidth( schIUScale.MilsToIU( 12 ) );
304
305 }
306
307 wire->SetStroke( stroke );
308
309 wire->SetStartPoint( VECTOR2I( schIUScale.MilsToIU( line.second.first.x ),
310 schIUScale.MilsToIU( line.second.first.y ) ) );
311 wire->SetEndPoint( VECTOR2I( schIUScale.MilsToIU( line.second.second.x ),
312 schIUScale.MilsToIU( line.second.second.y ) ) );
313 addItem( wire );
314 }
315
316#define MILS_POINT( x, y ) VECTOR2I( schIUScale.MilsToIU( x ), schIUScale.MilsToIU( y ) )
317
319 nc->SetPosition( MILS_POINT( 2350, 2600 ) );
320 addItem( nc );
321
323 e1->SetPosition( MILS_POINT( 1850, 1400 ) );
324 addItem( e1 );
325
327 e2->SetPosition( MILS_POINT( 1850, 2500 ) );
328 addItem( e2 );
329
330 SCH_TEXT* t1 = new SCH_TEXT( MILS_POINT( 2650, 2240 ), wxT( "PLAIN TEXT" ) );
331 addItem( t1 );
332
333 SCH_LABEL* t2 = new SCH_LABEL( MILS_POINT( 1975, 1500 ), wxT( "LABEL_{0}" ) );
335 t2->SetIsDangling( false );
336 addItem( t2 );
337
338 SCH_LABEL* t3 = new SCH_LABEL( MILS_POINT( 1975, 2600 ), wxT( "LABEL_{1}" ) );
340 t3->SetIsDangling( false );
341 addItem( t3 );
342
343 SCH_GLOBALLABEL* t4 = new SCH_GLOBALLABEL( MILS_POINT( 1750, 1300 ), wxT( "GLOBAL[0..3]" ) );
345 t4->SetIsDangling( false );
346 addItem( t4 );
347
348 SCH_HIERLABEL* t5 = new SCH_HIERLABEL( MILS_POINT( 3250, 1600 ), wxT( "HIER_LABEL" ) );
350 t5->SetIsDangling( false );
351 addItem( t5 );
352
353 SCH_JUNCTION* j = new SCH_JUNCTION( MILS_POINT( 3075, 1600 ) );
354 addItem( j );
355
356 t2->SetSelected();
357
358 {
359 auto mapLibItemPosition =
360 []( const VECTOR2I& aLibPosition ) -> VECTOR2I
361 {
362 // Currently, the mapping is a no-op.
363 return VECTOR2I( aLibPosition.x, aLibPosition.y );
364 };
365
366 LIB_SYMBOL* symbol = new LIB_SYMBOL( wxEmptyString );
367 VECTOR2I p( 2625, 1600 );
368
369 SCH_FIELD& ref = symbol->GetReferenceField();
370
371 ref.SetText( wxT( "U1" ) );
372 ref.SetPosition( MILS_POINT( p.x + 30, p.y - 260 ) );
374
375 SCH_FIELD& value = symbol->GetValueField();
376
377 value.SetText( wxT( "OPA604" ) );
378 value.SetPosition( MILS_POINT( p.x + 30, p.y - 180 ) );
380
381 symbol->SetShowPinNames( true );
382 symbol->SetShowPinNumbers( true );
383 symbol->SetPinNameOffset( 0 );
384
385 SCH_SHAPE* comp_body = new SCH_SHAPE( SHAPE_T::POLY, LAYER_DEVICE );
386
387 comp_body->SetParent( symbol );
388 comp_body->SetUnit( 0 );
389 comp_body->SetBodyStyle( 0 );
390 comp_body->SetStroke( STROKE_PARAMS( schIUScale.MilsToIU( 10 ), LINE_STYLE::SOLID ) );
391 comp_body->SetFillMode( FILL_T::FILLED_WITH_BG_BODYCOLOR );
392 comp_body->AddPoint( MILS_POINT( p.x - 200, p.y + 200 ) );
393 comp_body->AddPoint( MILS_POINT( p.x + 200, p.y ) );
394 comp_body->AddPoint( MILS_POINT( p.x - 200, p.y - 200 ) );
395 comp_body->AddPoint( MILS_POINT( p.x - 200, p.y + 200 ) );
396
397 addItem( comp_body );
398
399 SCH_PIN* pin = new SCH_PIN( symbol );
400
401 pin->SetPosition( MILS_POINT( p.x - 300, p.y - 100 ) );
402 pin->SetLength( schIUScale.MilsToIU( 100 ) );
403 pin->SetOrientation( PIN_ORIENTATION::PIN_RIGHT );
404 pin->SetType( ELECTRICAL_PINTYPE::PT_INPUT );
405 pin->SetNumber( wxT( "1" ) );
406 pin->SetName( wxT( "-" ) );
407 pin->SetNumberTextSize( schIUScale.MilsToIU( 50 ) );
408 pin->SetNameTextSize( schIUScale.MilsToIU( 50 ) );
409
410 endPointsByType.emplace_back( PIN_END, pin, mapLibItemPosition( pin->GetPosition() ) );
411 symbol->AddDrawItem( pin );
412
413 pin = new SCH_PIN( symbol );
414
415 pin->SetPosition( MILS_POINT( p.x - 300, p.y + 100 ) );
416 pin->SetLength( schIUScale.MilsToIU( 100 ) );
417 pin->SetOrientation( PIN_ORIENTATION::PIN_RIGHT );
418 pin->SetType( ELECTRICAL_PINTYPE::PT_INPUT );
419 pin->SetNumber( wxT( "2" ) );
420 pin->SetName( wxT( "+" ) );
421 pin->SetNumberTextSize( schIUScale.MilsToIU( 50 ) );
422 pin->SetNameTextSize( schIUScale.MilsToIU( 50 ) );
423
424 endPointsByType.emplace_back( PIN_END, pin, mapLibItemPosition( pin->GetPosition() ) );
425 symbol->AddDrawItem( pin );
426
427 pin = new SCH_PIN( symbol );
428
429 pin->SetPosition( MILS_POINT( p.x + 300, p.y ) );
430 pin->SetLength( schIUScale.MilsToIU( 100 ) );
431 pin->SetOrientation( PIN_ORIENTATION::PIN_LEFT );
432 pin->SetType( ELECTRICAL_PINTYPE::PT_OUTPUT );
433 pin->SetNumber( wxT( "3" ) );
434 pin->SetName( wxT( "OUT" ) );
435 pin->SetNumberTextSize( schIUScale.MilsToIU( 50 ) );
436 pin->SetNameTextSize( schIUScale.MilsToIU( 50 ) );
437
438 endPointsByType.emplace_back( PIN_END, pin, mapLibItemPosition( pin->GetPosition() ) );
439 symbol->AddDrawItem( pin );
440
441 addItem( symbol );
442 }
443
444 SCH_SHEET* s = new SCH_SHEET(
445 /* aParent */ nullptr,
446 /* aPosition */ MILS_POINT( 4000, 1300 ),
447 /* aSize */ VECTOR2I( schIUScale.MilsToIU( 800 ), schIUScale.MilsToIU( 1300 ) ) );
448 s->GetFields().at( SHEETNAME ).SetText( wxT( "SHEET" ) );
449 s->GetFields().at( SHEETFILENAME ).SetText( _( "/path/to/sheet" ) );
450 s->AutoplaceFields( nullptr, false );
451 addItem( s );
452
453 SCH_SHEET_PIN* sp = new SCH_SHEET_PIN( s, MILS_POINT( 4500, 1500 ), wxT( "SHEET PIN" ) );
454 addItem( sp );
455
456 for( EDA_ITEM* item : m_previewItems )
457 {
458 SCH_ITEM* sch_item = dynamic_cast<SCH_ITEM*>( item );
459
460 if( sch_item && sch_item->IsConnectable() )
461 {
462 sch_item->AutoplaceFields( nullptr, false );
463 sch_item->GetEndPoints( endPointsByType );
464 }
465 }
466
467 std::vector<DANGLING_END_ITEM> endPointsByPos = endPointsByType;
468 DANGLING_END_ITEM_HELPER::sort_dangling_end_items( endPointsByType, endPointsByPos );
469
470 for( EDA_ITEM* item : m_previewItems )
471 {
472 SCH_ITEM* sch_item = dynamic_cast<SCH_ITEM*>( item );
473
474 if( sch_item && sch_item->IsConnectable() )
475 sch_item->UpdateDanglingState( endPointsByType, endPointsByPos, nullptr );
476 }
477
479}
480
481
483{
485}
486
487
489{
492}
493
494
496{
497 if( !m_preview )
498 return;
499
500 KIGFX::VIEW* view = m_preview->GetView();
501 auto settings = static_cast<SCH_RENDER_SETTINGS*>( view->GetPainter()->GetSettings() );
502 settings->LoadColors( m_currentSettings );
503
504 m_preview->GetGAL()->SetClearColor( settings->GetBackgroundColor() );
505
507 auto rect = m_preview->GetScreenRect();
508 m_preview->Refresh( true, &rect );
509}
510
511
513{
514 if( m_preview )
515 {
516 KIGFX::VIEW* view = m_preview->GetView();
517
518 view->SetScale( 1.0 );
519 VECTOR2D screenSize = view->ToWorld( ToVECTOR2D( m_preview->GetClientSize() ), false );
520
522 double scale = view->GetScale() / std::max( fabs( psize.x / screenSize.x ),
523 fabs( psize.y / screenSize.y ) );
524
525 view->SetScale( scale * m_galDisplayOptions.m_scaleFactor * 0.8 /* margin */ );
528 }
529}
530
531
532void PANEL_EESCHEMA_COLOR_SETTINGS::OnSize( wxSizeEvent& aEvent )
533{
535 aEvent.Skip();
536}
537
538
540{
541 // If the theme is not overriding individual item colors then don't show them so that
542 // the user doesn't get seduced into thinking they'll have some effect.
545
548
549 m_colorsGridSizer->Layout();
550 m_colorsListWindow->Layout();
551}
552
553
555{
558}
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:194
wxString m_ColorTheme
Active color theme name.
Definition: app_settings.h:197
constexpr Vec Centre() const
Definition: box2.h:97
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:613
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:113
void SetHorizJustify(GR_TEXT_H_ALIGN_T aType)
Definition: eda_text.cpp:400
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:273
virtual void SetScale(double aScale, VECTOR2D aAnchor={ 0, 0 })
Set the scaling factor, zooming around a given anchor point.
Definition: view.cpp:562
virtual void Add(VIEW_ITEM *aItem, int aDrawPriority=-1)
Add a VIEW_ITEM to the view.
Definition: view.cpp:299
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:459
void UpdateAllItems(int aUpdateFlags)
Update all items in the view according to the given flags.
Definition: view.cpp:1545
PAINTER * GetPainter() const
Return the painter object used by the view for drawing #VIEW_ITEMS.
Definition: view.h:217
void SetCenter(const VECTOR2D &aCenter)
Set the center point of the VIEW (i.e.
Definition: view.cpp:588
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:808
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:259
int GetWidthIU(double aIUScale) const
Gets the page width in IU.
Definition: page_info.h:153
void SetWidthMils(double aWidthInMils)
Definition: page_info.cpp:245
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:679
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:1466
void SetText(const wxString &aText) override
Definition: sch_field.cpp:1213
void SetSpinStyle(SPIN_STYLE aSpinStyle) override
Definition: sch_label.cpp:1855
void SetSpinStyle(SPIN_STYLE aSpinStyle) override
Definition: sch_label.cpp:2031
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:297
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:579
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:666
COLOR_SETTINGS * GetColorSettings(const wxString &aName="user")
Retrieves a color settings object that applications can read colors from.
T * GetAppSettings(const wxString &aFilename)
Returns a handle to the a given settings by type If the settings have already been loaded,...
Simple container to manage line stroke parameters.
Definition: stroke_params.h:79
void SetLineStyle(LINE_STYLE aLineStyle)
Definition: stroke_params.h:93
void SetWidth(int aWidth)
Definition: stroke_params.h:90
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:31
SCH_LAYER_ID
Eeschema drawing layers.
Definition: layer_ids.h:353
@ LAYER_DANGLING
Definition: layer_ids.h:381
@ LAYER_DEVICE
Definition: layer_ids.h:370
@ LAYER_SHEET_BACKGROUND
Definition: layer_ids.h:388
@ LAYER_WIRE
Definition: layer_ids.h:356
@ LAYER_NOTES
Definition: layer_ids.h:371
@ LAYER_NET_COLOR_HIGHLIGHT
Definition: layer_ids.h:396
@ LAYER_BUS
Definition: layer_ids.h:357
@ SCH_LAYER_ID_END
Definition: layer_ids.h:406
@ SCH_LAYER_ID_START
Definition: layer_ids.h:354
@ LAYER_SCHEMATIC_DRAWINGSHEET
Definition: layer_ids.h:398
@ LAYER_SCHEMATIC_GRID_AXES
Definition: layer_ids.h:390
@ LAYER_NOTES_BACKGROUND
Definition: layer_ids.h:373
@ LAYER_SCHEMATIC_PAGE_LIMITS
Definition: layer_ids.h:399
@ LAYER_SHEET
Definition: layer_ids.h:375
@ LAYER_SCHEMATIC_BACKGROUND
Definition: layer_ids.h:391
@ 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:1060
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:691
VECTOR2D ToVECTOR2D(const wxPoint &aPoint)
Definition: vector2wx.h:40