KiCad PCB EDA Suite
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages Concepts
pcb_base_frame.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) 2018 Jean-Pierre Charras, jean-pierre.charras@ujf-grenoble.fr
5 * Copyright (C) 2012 SoftPLC Corporation, Dick Hollenbeck <dick@softplc.com>
6 * Copyright (C) 2011 Wayne Stambaugh <stambaughw@gmail.com>
7 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
8 * Copyright (C) 2022 CERN
9 *
10 * This program is free software; you can redistribute it and/or
11 * modify it under the terms of the GNU General Public License
12 * as published by the Free Software Foundation; either version 2
13 * of the License, or (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, you may find one here:
22 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
23 * or you may search the http://www.gnu.org website for the version 2 license,
24 * or you may write to the Free Software Foundation, Inc.,
25 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
26 */
27
30#include <boost/version.hpp>
31
32#if BOOST_VERSION >= 106700
33#include <boost/uuid/entropy_error.hpp>
34#endif
35
36#include <3d_viewer/eda_3d_viewer_frame.h> // To include VIEWER3D_FRAMENAME
37#include <advanced_config.h>
38#include <base_units.h>
39#include <board.h>
40#include <cleanup_item.h>
41#include <collectors.h>
42#include <confirm.h>
43#include <footprint.h>
45#include <fp_lib_table.h>
46#include <lset.h>
47#include <kiface_base.h>
48#include <pcb_painter.h>
49#include <pcbnew_id.h>
50#include <pcbnew_settings.h>
51#include <pcb_base_frame.h>
52#include <pcb_draw_panel_gal.h>
53#include <pgm_base.h>
54#include <project_pcb.h>
56#include <zoom_defines.h>
57
58#include <math/vector2d.h>
59#include <math/vector2wx.h>
60#include <widgets/msgpanel.h>
61#include <wx/fswatcher.h>
62
65#include <tool/tool_manager.h>
67#include <tools/pcb_actions.h>
68#include <tool/grid_menu.h>
70
72
75
76wxDEFINE_EVENT( EDA_EVT_BOARD_CHANGED, wxCommandEvent );
77
78PCB_BASE_FRAME::PCB_BASE_FRAME( KIWAY* aKiway, wxWindow* aParent, FRAME_T aFrameType,
79 const wxString& aTitle, const wxPoint& aPos, const wxSize& aSize,
80 long aStyle, const wxString& aFrameName ) :
81 EDA_DRAW_FRAME( aKiway, aParent, aFrameType, aTitle, aPos, aSize, aStyle, aFrameName,
82 pcbIUScale ),
83 m_pcb( nullptr ),
84 m_originTransforms( *this )
85{
87}
88
89
91{
92 // Ensure m_canvasType is up to date, to save it in config
93 if( GetCanvas() )
95
96 delete m_pcb;
97 m_pcb = nullptr;
98}
99
100
101bool PCB_BASE_FRAME::canCloseWindow( wxCloseEvent& aEvent )
102{
103 // Close modeless dialogs. They're trouble when they get destroyed after the frame and/or
104 // board.
105 wxWindow* viewer3D = Get3DViewerFrame();
106
107 if( viewer3D )
108 viewer3D->Close( true );
109
110 // Similarly, wxConvBrokenFileNames uses some statically allocated variables that make it
111 // crash when run later from a d'tor.
113
114 return true;
115}
116
117
118void PCB_BASE_FRAME::handleActivateEvent( wxActivateEvent& aEvent )
119{
121
122 if( m_spaceMouse )
123 m_spaceMouse->SetFocus( aEvent.GetActive() );
124}
125
126
127void PCB_BASE_FRAME::handleIconizeEvent( wxIconizeEvent& aEvent )
128{
130
131 if( m_spaceMouse && aEvent.IsIconized() )
132 m_spaceMouse->SetFocus( false );
133}
134
135
137{
138 wxWindow* frame = FindWindowByName( QUALIFIED_VIEWER3D_FRAMENAME( this ) );
139 return dynamic_cast<EDA_3D_VIEWER_FRAME*>( frame );
140}
141
142
143void PCB_BASE_FRAME::Update3DView( bool aMarkDirty, bool aRefresh, const wxString* aTitle )
144{
145 EDA_3D_VIEWER_FRAME* draw3DFrame = Get3DViewerFrame();
146
147 if( draw3DFrame )
148 {
149 if( aTitle )
150 draw3DFrame->SetTitle( *aTitle );
151
152 if( aMarkDirty )
153 draw3DFrame->ReloadRequest();
154
155 if( aRefresh )
156 draw3DFrame->Redraw();
157 }
158}
159
160
162{
163 if( m_pcb != aBoard )
164 {
165 delete m_pcb;
166 m_pcb = aBoard;
167
168 if( GetBoard() )
170
171 if( GetBoard() && GetCanvas() )
172 {
174
175 if( rs )
176 {
177 rs->SetDashLengthRatio( GetBoard()->GetPlotOptions().GetDashedLineDashRatio() );
178 rs->SetGapLengthRatio( GetBoard()->GetPlotOptions().GetDashedLineGapRatio() );
179 }
180 }
181
182 wxCommandEvent e( EDA_EVT_BOARD_CHANGED );
183 ProcessEventLocally( e );
184
185 for( wxEvtHandler* listener : m_boardChangeListeners )
186 {
187 wxCHECK2( listener, continue );
188
189 // Use the windows variant when handling event messages in case there is any special
190 // event handler pre and/or post processing specific to windows.
191 wxWindow* win = dynamic_cast<wxWindow*>( listener );
192
193 if( win )
194 win->HandleWindowEvent( e );
195 else
196 listener->SafelyProcessEvent( e );
197 }
198 }
199}
200
201
202void PCB_BASE_FRAME::AddBoardChangeListener( wxEvtHandler* aListener )
203{
204 auto it = std::find( m_boardChangeListeners.begin(), m_boardChangeListeners.end(), aListener );
205
206 // Don't add duplicate listeners.
207 if( it == m_boardChangeListeners.end() )
208 m_boardChangeListeners.push_back( aListener );
209}
210
211
212void PCB_BASE_FRAME::RemoveBoardChangeListener( wxEvtHandler* aListener )
213{
214 auto it = std::find( m_boardChangeListeners.begin(), m_boardChangeListeners.end(), aListener );
215
216 // Don't add duplicate listeners.
217 if( it != m_boardChangeListeners.end() )
218 m_boardChangeListeners.erase( it );
219}
220
221
223{
224 if( aFootprint )
225 {
226 GetBoard()->Add( aFootprint, ADD_MODE::APPEND );
227
228 aFootprint->SetFlags( IS_NEW );
229 aFootprint->SetPosition( VECTOR2I( 0, 0 ) ); // cursor in GAL may not be initialized yet
230
231 // Put it on FRONT layer (note that it might be stored flipped if the lib is an archive
232 // built from a board)
233 if( aFootprint->IsFlipped() )
234 aFootprint->Flip( aFootprint->GetPosition(), GetPcbNewSettings()->m_FlipDirection );
235
236 // Place it in orientation 0 even if it is not saved with orientation 0 in lib (note that
237 // it might be stored in another orientation if the lib is an archive built from a board)
238 aFootprint->SetOrientation( ANGLE_0 );
239
240 GetBoard()->UpdateUserUnits( aFootprint, GetCanvas()->GetView() );
241 }
242}
243
244
246{
247 return GetBoard()->GetItem( aId );
248}
249
251{
252 // nullptr will clear the current focus
253 if( aItem != nullptr && !aItem->IsBOARD_ITEM() )
254 return;
255
256 FocusOnItem( static_cast<BOARD_ITEM*>( aItem ), UNDEFINED_LAYER );
257}
258
260{
261 std::vector<BOARD_ITEM*> items;
262
263 if( aItem )
264 items.push_back( aItem );
265
266 FocusOnItems( items, aLayer );
267}
268
269
270void PCB_BASE_FRAME::FocusOnItems( std::vector<BOARD_ITEM*> aItems, PCB_LAYER_ID aLayer )
271{
272 static std::vector<KIID> lastBrightenedItemIDs;
273
274 BOARD_ITEM* lastItem = nullptr;
275
276 for( KIID lastBrightenedItemID : lastBrightenedItemIDs )
277 {
280 #if BOOST_VERSION >= 106700
281 try
282 {
283 lastItem = GetBoard()->GetItem( lastBrightenedItemID );
284 }
285 catch( const boost::uuids::entropy_error& )
286 {
287 wxLogError( wxT( "A Boost UUID entropy exception was thrown in %s:%s." ),
288 __FILE__, __FUNCTION__ );
289 }
290 #else
291 lastItem = GetBoard()->GetItem( lastBrightenedItemID );
292 #endif
293
294 if( lastItem && lastItem != DELETED_BOARD_ITEM::GetInstance() )
295 {
296 lastItem->ClearBrightened();
297
298 lastItem->RunOnChildren(
299 [&]( BOARD_ITEM* child )
300 {
301 child->ClearBrightened();
302 },
303 RECURSE_MODE::RECURSE );
304
305 GetCanvas()->GetView()->Update( lastItem );
306 lastBrightenedItemID = niluuid;
307 GetCanvas()->Refresh();
308 }
309 }
310
311 lastBrightenedItemIDs.clear();
312
313 if( aItems.empty() )
314 return;
315
316 VECTOR2I focusPt;
317 KIGFX::VIEW* view = GetCanvas()->GetView();
318 SHAPE_POLY_SET viewportPoly( view->GetViewport() );
319
320 for( wxWindow* dialog : findDialogs() )
321 {
322 wxPoint dialogPos = GetCanvas()->ScreenToClient( dialog->GetScreenPosition() );
323 SHAPE_POLY_SET dialogPoly( BOX2D( view->ToWorld( ToVECTOR2D( dialogPos ), true ),
324 view->ToWorld( ToVECTOR2D( dialog->GetSize() ), false ) ) );
325
326 try
327 {
328 viewportPoly.BooleanSubtract( dialogPoly );
329 }
330 catch( const std::exception& e )
331 {
332 wxFAIL_MSG( wxString::Format( wxT( "Clipper exception occurred: %s" ), e.what() ) );
333 }
334 }
335
336 SHAPE_POLY_SET itemPoly, clippedPoly;
337
338 for( BOARD_ITEM* item : aItems )
339 {
340 if( item && item != DELETED_BOARD_ITEM::GetInstance() )
341 {
342 item->SetBrightened();
343
344 item->RunOnChildren(
345 [&]( BOARD_ITEM* child )
346 {
347 child->SetBrightened();
348 },
349 RECURSE_MODE::RECURSE );
350
351 GetCanvas()->GetView()->Update( item );
352 lastBrightenedItemIDs.push_back( item->m_Uuid );
353
354 // Focus on the object's location. Prefer a visible part of the object to its anchor
355 // in order to keep from scrolling around.
356
357 focusPt = item->GetPosition();
358
359 if( aLayer == UNDEFINED_LAYER && item->GetLayerSet().any() )
360 aLayer = item->GetLayerSet().Seq()[0];
361
362 switch( item->Type() )
363 {
364 case PCB_FOOTPRINT_T:
365 try
366 {
367 itemPoly = static_cast<FOOTPRINT*>( item )->GetBoundingHull();
368 }
369 catch( const std::exception& e )
370 {
371 wxFAIL_MSG( wxString::Format( wxT( "Clipper exception occurred: %s" ),
372 e.what() ) );
373 }
374
375 break;
376
377 case PCB_PAD_T:
378 case PCB_MARKER_T:
379 case PCB_VIA_T:
380 FocusOnLocation( item->GetFocusPosition() );
381 GetCanvas()->Refresh();
382 return;
383
384 case PCB_SHAPE_T:
385 case PCB_FIELD_T:
386 case PCB_TEXT_T:
387 case PCB_TEXTBOX_T:
388 case PCB_TRACE_T:
389 case PCB_ARC_T:
391 case PCB_DIM_LEADER_T:
392 case PCB_DIM_CENTER_T:
393 case PCB_DIM_RADIAL_T:
395 item->TransformShapeToPolygon( itemPoly, aLayer, 0, pcbIUScale.mmToIU( 0.1 ),
396 ERROR_INSIDE );
397 break;
398
399 case PCB_ZONE_T:
400 {
401 ZONE* zone = static_cast<ZONE*>( item );
402 #if 0
403 // Using the filled area shapes to find a Focus point can give good results, but
404 // unfortunately the calculations are highly time consuming, even for not very
405 // large areas (can be easily a few minutes for large areas).
406 // so we used only the zone outline that usually do not have too many vertices.
407 zone->TransformShapeToPolygon( itemPoly, aLayer, 0, pcbIUScale.mmToIU( 0.1 ),
408 ERROR_INSIDE );
409
410 if( itemPoly.IsEmpty() )
411 itemPoly = *zone->Outline();
412 #else
413 // much faster calculation time when using only the zone outlines
414 itemPoly = *zone->Outline();
415 #endif
416
417 break;
418 }
419
420 default:
421 {
422 BOX2I item_bbox = item->GetBoundingBox();
423 itemPoly.NewOutline();
424 itemPoly.Append( item_bbox.GetOrigin() );
425 itemPoly.Append( item_bbox.GetOrigin() + VECTOR2I( item_bbox.GetWidth(), 0 ) );
426 itemPoly.Append( item_bbox.GetOrigin() + VECTOR2I( 0, item_bbox.GetHeight() ) );
427 itemPoly.Append( item_bbox.GetOrigin() + VECTOR2I( item_bbox.GetWidth(),
428 item_bbox.GetHeight() ) );
429 break;
430 }
431 }
432
433 try
434 {
435 clippedPoly.BooleanIntersection( itemPoly, viewportPoly );
436 }
437 catch( const std::exception& e )
438 {
439 wxFAIL_MSG( wxString::Format( wxT( "Clipper exception occurred: %s" ), e.what() ) );
440 }
441
442 if( !clippedPoly.IsEmpty() )
443 itemPoly = clippedPoly;
444 }
445 }
446
447 /*
448 * Perform a step-wise deflate to find the visual-center-of-mass
449 */
450
451 BOX2I bbox = itemPoly.BBox();
452 int step = std::min( bbox.GetWidth(), bbox.GetHeight() ) / 10;
453
454 while( !itemPoly.IsEmpty() )
455 {
456 focusPt = itemPoly.BBox().Centre();
457
458 try
459 {
460 itemPoly.Deflate( step, CORNER_STRATEGY::ALLOW_ACUTE_CORNERS, ARC_LOW_DEF );
461 }
462 catch( const std::exception& e )
463 {
464 wxFAIL_MSG( wxString::Format( wxT( "Clipper exception occurred: %s" ), e.what() ) );
465 }
466 }
467
468 FocusOnLocation( focusPt );
469
470 GetCanvas()->Refresh();
471}
472
473
475{
476 KIGFX::PCB_VIEW* view = GetCanvas()->GetView();
477
478 if( view && GetBoard()->m_SolderMaskBridges && view->HasItem( GetBoard()->m_SolderMaskBridges ) )
479 view->Remove( GetBoard()->m_SolderMaskBridges );
480}
481
482
484{
485 KIGFX::PCB_VIEW* view = GetCanvas()->GetView();
486
487 if( view && GetBoard()->m_SolderMaskBridges )
488 {
489 if( view->HasItem( GetBoard()->m_SolderMaskBridges ) )
490 view->Remove( GetBoard()->m_SolderMaskBridges );
491
492 view->Add( GetBoard()->m_SolderMaskBridges );
493 }
494}
495
496
497void PCB_BASE_FRAME::SetPageSettings( const PAGE_INFO& aPageSettings )
498{
499 m_pcb->SetPageSettings( aPageSettings );
500
501 if( GetScreen() )
503}
504
505
507{
508 return m_pcb->GetPageSettings();
509}
510
511
513{
514 // this function is only needed because EDA_DRAW_FRAME is not compiled
515 // with either -DPCBNEW or -DEESCHEMA, so the virtual is used to route
516 // into an application specific source file.
518}
519
520
522{
524}
525
526
528{
530}
531
532
534{
536}
537
538
540{
541 VECTOR2I origin( 0, 0 );
542
543 switch( GetPcbNewSettings()->m_Display.m_DisplayOrigin )
544 {
545 case PCB_DISPLAY_ORIGIN::PCB_ORIGIN_PAGE: break;
546 case PCB_DISPLAY_ORIGIN::PCB_ORIGIN_AUX: origin = GetAuxOrigin(); break;
547 case PCB_DISPLAY_ORIGIN::PCB_ORIGIN_GRID: origin = GetGridOrigin(); break;
548 default: wxASSERT( false ); break;
549 }
550
551 return origin;
552}
553
555{
556 return m_originTransforms;
557}
558
559
561{
562 return m_pcb->GetTitleBlock();
563}
564
565
567{
568 m_pcb->SetTitleBlock( aTitleBlock );
569}
570
571
573{
574 return m_pcb->GetDesignSettings();
575}
576
577
579{
580 m_drawBgColor= aColor;
581 m_auimgr.Update();
582}
583
584
586{
587 return m_pcb->GetPlotOptions();
588}
589
590
592{
593 m_pcb->SetPlotOptions( aSettings );
594
595 // Plot Settings can also change the "tent vias" setting, which can affect the solder mask.
596 LSET visibleLayers = GetBoard()->GetVisibleLayers();
597
598 if( visibleLayers.test( F_Mask ) || visibleLayers.test( B_Mask ) )
599 {
601 [&]( KIGFX::VIEW_ITEM* aItem ) -> int
602 {
603 BOARD_ITEM* item = nullptr;
604
605 if( aItem->IsBOARD_ITEM() )
606 item = static_cast<BOARD_ITEM*>( aItem );
607
608 // Note: KIGFX::REPAINT isn't enough for things that go from invisible to
609 // visible as they won't be found in the view layer's itemset for re-painting.
610 if( item && item->Type() == PCB_VIA_T )
611 return KIGFX::ALL;
612
613 return 0;
614 } );
615
616 GetCanvas()->Refresh();
617 }
618}
619
620
621BOX2I PCB_BASE_FRAME::GetBoardBoundingBox( bool aBoardEdgesOnly ) const
622{
623 BOX2I area = aBoardEdgesOnly ? m_pcb->GetBoardEdgesBoundingBox() : m_pcb->GetBoundingBox();
624
625 if( area.GetWidth() == 0 && area.GetHeight() == 0 )
626 {
627 VECTOR2I pageSize = GetPageSizeIU();
628
630 {
631 area.SetOrigin( 0, 0 );
632 area.SetEnd( pageSize.x, pageSize.y );
633 }
634 else
635 {
636 area.SetOrigin( -pageSize.x / 2, -pageSize.y / 2 );
637 area.SetEnd( pageSize.x / 2, pageSize.y / 2 );
638 }
639 }
640
641 return area;
642}
643
644
645const BOX2I PCB_BASE_FRAME::GetDocumentExtents( bool aIncludeAllVisible ) const
646{
647 /* "Zoom to Fit" calls this with "aIncludeAllVisible" as true. Since that feature
648 * always ignored the page and border, this function returns a bbox without them
649 * as well when passed true. This technically is not all things visible, but it
650 * keeps behavior consistent.
651 *
652 * When passed false, this function returns a bbox of just the board edge. This
653 * allows things like fabrication text or anything else outside the board edge to
654 * be ignored, and just zooms up to the board itself.
655 *
656 * Calling "GetBoardBoundingBox(true)" when edge cuts are turned off will return
657 * the entire page and border, so we call "GetBoardBoundingBox(false)" instead.
658 */
659 if( aIncludeAllVisible || !m_pcb->IsLayerVisible( Edge_Cuts ) )
660 return GetBoardBoundingBox( false );
661 else
662 return GetBoardBoundingBox( true );
663}
664
665
666// Virtual function
668{
669}
670
671
673{
674 // call my base class
676
677 // tooltips in toolbars
679
681
682 if( viewer3D )
683 viewer3D->ShowChangedLanguage();
684}
685
686
688{
689 EDA_3D_VIEWER_FRAME* draw3DFrame = Get3DViewerFrame();
690
691 if( !draw3DFrame )
692 draw3DFrame = new EDA_3D_VIEWER_FRAME( &Kiway(), this, _( "3D Viewer" ) );
693
694 // Raising the window does not show the window on Windows if iconized. This should work
695 // on any platform.
696 if( draw3DFrame->IsIconized() )
697 draw3DFrame->Iconize( false );
698
699 draw3DFrame->Raise();
700 draw3DFrame->Show( true );
701
702 // Raising the window does not set the focus on Linux. This should work on any platform.
703 if( wxWindow::FindFocus() != draw3DFrame )
704 draw3DFrame->SetFocus();
705
706 // Allocate a slice of time to display the 3D frame
707 // a call to wxSafeYield() should be enough (and better), but on Linux we need
708 // to call wxYield()
709 // otherwise the activity messages are not displayed during the first board loading
710 wxYield();
711
712 // Note, the caller is responsible to load/update the board 3D view.
713 // after frame creation the board is not automatically created.
714
715 return draw3DFrame;
716}
717
718
720{
721 PCB_LAYER_ID preslayer = GetActiveLayer();
722 auto& displ_opts = GetDisplayOptions();
723
724 // Check if the specified layer matches the present layer
725 if( layer == preslayer )
726 return;
727
728 // Copper layers cannot be selected unconditionally; how many of those layers are
729 // currently enabled needs to be checked.
730 if( IsCopperLayer( layer ) )
731 {
732 if( layer > m_pcb->GetCopperLayerStackMaxId() )
733 return;
734 }
735
736 // Is yet more checking required? E.g. when the layer to be selected is a non-copper
737 // layer, or when switching between a copper layer and a non-copper layer, or vice-versa?
738 // ...
739
740 SetActiveLayer( layer );
741
742 if( displ_opts.m_ContrastModeDisplay != HIGH_CONTRAST_MODE::NORMAL )
743 GetCanvas()->Refresh();
744}
745
746
748{
750 GetCanvas()->GetView() );
751
752 // account for the globals
764
765 return guide;
766}
767
768
770{
772
773 BASE_SCREEN* screen = GetScreen();
774
775 if( !screen )
776 return;
777
778 wxString line;
780
781 if( GetShowPolarCoords() ) // display polar coordinates
782 {
783 double dx = cursorPos.x - screen->m_LocalOrigin.x;
784 double dy = cursorPos.y - screen->m_LocalOrigin.y;
785 double theta = RAD2DEG( atan2( -dy, dx ) );
786 double ro = hypot( dx, dy );
787
788 line.Printf( wxT( "r %s theta %.3f" ),
789 MessageTextFromValue( ro, false ),
790 theta );
791
792 SetStatusText( line, 3 );
793 }
794
795 // Transform absolute coordinates for user origin preferences
796 double userXpos = m_originTransforms.ToDisplayAbsX( static_cast<double>( cursorPos.x ) );
797 double userYpos = m_originTransforms.ToDisplayAbsY( static_cast<double>( cursorPos.y ) );
798
799 // Display absolute coordinates:
800 line.Printf( wxT( "X %s Y %s" ),
801 MessageTextFromValue( userXpos, false ),
802 MessageTextFromValue( userYpos, false ) );
803 SetStatusText( line, 2 );
804
805 if( !GetShowPolarCoords() ) // display relative cartesian coordinates
806 {
807 // Calculate relative coordinates
808 double relXpos = cursorPos.x - screen->m_LocalOrigin.x;
809 double relYpos = cursorPos.y - screen->m_LocalOrigin.y;
810
811 // Transform relative coordinates for user origin preferences
812 userXpos = m_originTransforms.ToDisplayRelX( relXpos );
813 userYpos = m_originTransforms.ToDisplayRelY( relYpos );
814
815 line.Printf( wxT( "dx %s dy %s dist %s" ),
816 MessageTextFromValue( userXpos, false ),
817 MessageTextFromValue( userYpos, false ),
818 MessageTextFromValue( hypot( userXpos, userYpos ), false ) );
819 SetStatusText( line, 3 );
820 }
821
823}
824
825
827{
828 EDA_DRAW_FRAME::unitsChangeRefresh(); // Update the status bar.
829
830 if( GetBoard() )
832
834}
835
836
838{
840
841 if( aCfg->m_Window.grid.grids.empty() )
842 aCfg->m_Window.grid.grids = aCfg->DefaultGridSizeList();
843
844 // Move legacy user grids to grid list
845 if( !aCfg->m_Window.grid.user_grid_x.empty() )
846 {
847 aCfg->m_Window.grid.grids.emplace_back( GRID{ "User Grid", aCfg->m_Window.grid.user_grid_x,
848 aCfg->m_Window.grid.user_grid_y } );
849 aCfg->m_Window.grid.user_grid_x = wxEmptyString;
850 aCfg->m_Window.grid.user_grid_y = wxEmptyString;
851 }
852
853 // Currently values read from config file are not used because the user cannot
854 // change this config
855 // if( aCfg->m_Window.zoom_factors.empty() )
856 {
857 if( ADVANCED_CFG::GetCfg().m_HyperZoom )
859 else
861 }
862
863 // Some, but not all, derived classes have a PCBNEW_SETTINGS.
864 if( PCBNEW_SETTINGS* pcbnew_cfg = dynamic_cast<PCBNEW_SETTINGS*>( aCfg ) )
865 m_polarCoords = pcbnew_cfg->m_PolarCoords;
866
867 wxASSERT( GetCanvas() );
868
869 if( GetCanvas() )
870 {
872
873 if( rs )
874 {
877 rs->SetDefaultFont( wxEmptyString ); // Always the KiCad font for PCBs
878 }
879 }
880}
881
882
884{
885 if( aErrorCode >= CLEANUP_FIRST )
886 return RPT_SEVERITY_ACTION;
887
889
890 return bds.m_DRCSeverities[ aErrorCode ];
891}
892
893
895{
897
898 // Some, but not all derived classes have a PCBNEW_SETTINGS.
899 PCBNEW_SETTINGS* cfg = dynamic_cast<PCBNEW_SETTINGS*>( aCfg );
900
901 if( cfg )
903}
904
905
907{
909}
910
911
913{
915}
916
917
919{
920 switch( GetFrameType() )
921 {
922 case FRAME_PCB_EDITOR:
924 default:
926
930
934 case FRAME_CVPCB:
937 }
938}
939
940
942{
944}
945
946
948{
950
951 KIGFX::VIEW* view = GetCanvas()->GetView();
952 KIGFX::PCB_PAINTER* painter = static_cast<KIGFX::PCB_PAINTER*>( view->GetPainter() );
953 PCB_RENDER_SETTINGS* settings = painter->GetSettings();
954
955 settings->LoadColors( GetColorSettings( true ) );
958
959 if( aFlags & TEXTVARS_CHANGED )
961
962 // Note: KIGFX::REPAINT isn't enough for things that go from invisible to visible as
963 // they won't be found in the view layer's itemset for re-painting.
965 [&]( KIGFX::VIEW_ITEM* aItem ) -> int
966 {
967 if( dynamic_cast<RATSNEST_VIEW_ITEM*>( aItem ) )
968 {
969 return KIGFX::ALL; // ratsnest display
970 }
971 else if( dynamic_cast<PCB_TRACK*>( aItem ) )
972 {
973 return KIGFX::REPAINT; // track, arc & via clearance display
974 }
975 else if( dynamic_cast<PAD*>( aItem ) )
976 {
977 return KIGFX::REPAINT; // pad clearance display
978 }
979 else if( EDA_TEXT* text = dynamic_cast<EDA_TEXT*>( aItem ) )
980 {
981 if( text->HasTextVars() )
982 {
983 text->ClearRenderCache();
984 text->ClearBoundingBoxCache();
985 return KIGFX::GEOMETRY | KIGFX::REPAINT;
986 }
987 }
988
989 return 0;
990 } );
991
993
995
996 // The 3D viewer isn't in the Kiway, so send its update manually
998
999 if( viewer )
1000 viewer->CommonSettingsChanged( aFlags );
1001}
1002
1003
1005{
1007
1010
1011 if( m_isClosing )
1012 return;
1013
1016}
1017
1018
1020{
1024}
1025
1026
1028{
1029 return static_cast<PCB_DRAW_PANEL_GAL*>( EDA_DRAW_FRAME::GetCanvas() );
1030}
1031
1032
1034{
1036
1037 EDA_DRAW_PANEL_GAL* canvas = GetCanvas();
1038 KIGFX::VIEW* view = canvas->GetView();
1039
1040 if( m_toolManager )
1041 {
1042 m_toolManager->SetEnvironment( m_pcb, view, canvas->GetViewControls(), config(), this );
1043
1045 }
1046
1047 KIGFX::PCB_PAINTER* painter = static_cast<KIGFX::PCB_PAINTER*>( view->GetPainter() );
1048 KIGFX::PCB_RENDER_SETTINGS* settings = painter->GetSettings();
1049 const PCB_DISPLAY_OPTIONS& displ_opts = GetDisplayOptions();
1050
1051 settings->LoadDisplayOptions( displ_opts );
1052 settings->LoadColors( GetColorSettings() );
1054
1055 view->RecacheAllItems();
1057 canvas->StartDrawing();
1058
1059 try
1060
1061 {
1062 if( !m_spaceMouse )
1063 {
1064 m_spaceMouse = std::make_unique<NL_PCBNEW_PLUGIN>( GetCanvas() );
1065 }
1066 }
1067 catch( const std::system_error& e )
1068 {
1069 wxLogTrace( wxT( "KI_TRACE_NAVLIB" ), e.what() );
1070 }
1071}
1072
1073
1074void PCB_BASE_FRAME::SetDisplayOptions( const PCB_DISPLAY_OPTIONS& aOptions, bool aRefresh )
1075{
1077 bool hcVisChanged = m_displayOptions.m_ContrastModeDisplay == HIGH_CONTRAST_MODE::HIDDEN
1078 || aOptions.m_ContrastModeDisplay == HIGH_CONTRAST_MODE::HIDDEN;
1079 m_displayOptions = aOptions;
1080
1081 EDA_DRAW_PANEL_GAL* canvas = GetCanvas();
1082 KIGFX::PCB_VIEW* view = static_cast<KIGFX::PCB_VIEW*>( canvas->GetView() );
1083
1084 view->UpdateDisplayOptions( aOptions );
1087
1088 // Vias on a restricted layer set must be redrawn when high contrast mode is changed
1089 if( hcChanged )
1090 {
1091 bool showNetNames = false;
1092
1093 if( PCBNEW_SETTINGS* config = dynamic_cast<PCBNEW_SETTINGS*>( Kiface().KifaceSettings() ) )
1094 showNetNames = config->m_Display.m_NetNames > 0;
1095
1096 // Note: KIGFX::REPAINT isn't enough for things that go from invisible to visible as
1097 // they won't be found in the view layer's itemset for re-painting.
1099 [&]( KIGFX::VIEW_ITEM* aItem ) -> int
1100 {
1101 if( PCB_VIA* via = dynamic_cast<PCB_VIA*>( aItem ) )
1102 {
1103 if( via->GetViaType() != VIATYPE::THROUGH
1104 || via->GetRemoveUnconnected()
1105 || showNetNames )
1106 {
1107 return hcVisChanged ? KIGFX::ALL : KIGFX::REPAINT;
1108 }
1109 }
1110 else if( PAD* pad = dynamic_cast<PAD*>( aItem ) )
1111 {
1112 if( pad->GetRemoveUnconnected()
1113 || showNetNames )
1114 {
1115 return hcVisChanged ? KIGFX::ALL : KIGFX::REPAINT;
1116 }
1117 }
1118
1119 return 0;
1120 } );
1121 }
1122
1123 if( aRefresh )
1124 canvas->Refresh();
1125}
1126
1127
1129{
1130 wxLogTrace( "KICAD_LIB_WATCH", "setFPWatcher" );
1131
1132 Unbind( wxEVT_FSWATCHER, &PCB_BASE_FRAME::OnFPChange, this );
1133
1134 if( m_watcher )
1135 {
1136 wxLogTrace( "KICAD_LIB_WATCH", "Remove watch" );
1137 m_watcher->RemoveAll();
1138 m_watcher->SetOwner( nullptr );
1139 m_watcher.reset();
1140 }
1141
1142 wxString libfullname;
1144
1145 if( !aFootprint || !tbl )
1146 return;
1147
1148 try
1149 {
1150 const FP_LIB_TABLE_ROW* row = tbl->FindRow( aFootprint->GetFPID().GetLibNickname() );
1151
1152 if( !row )
1153 return;
1154
1155 libfullname = row->GetFullURI( true );
1156 }
1157 catch( const std::exception& e )
1158 {
1159 DisplayInfoMessage( this, e.what() );
1160 return;
1161 }
1162 catch( const IO_ERROR& error )
1163 {
1164 wxLogTrace( "KICAD_LIB_WATCH", "Error: %s", error.What() );
1165 return;
1166 }
1167
1168 m_watcherFileName.Assign( libfullname, aFootprint->GetFPID().GetLibItemName(),
1170
1171 if( !m_watcherFileName.FileExists() )
1172 return;
1173
1174 m_watcherLastModified = m_watcherFileName.GetModificationTime();
1175
1176 Bind( wxEVT_FSWATCHER, &PCB_BASE_FRAME::OnFPChange, this );
1177 m_watcher = std::make_unique<wxFileSystemWatcher>();
1178 m_watcher->SetOwner( this );
1179
1180 wxFileName fn;
1181 fn.AssignDir( m_watcherFileName.GetPath() );
1182 fn.DontFollowLink();
1183
1184 wxLogTrace( "KICAD_LIB_WATCH", "Add watch: %s", fn.GetPath() );
1185
1186 {
1187 // Silence OS errors that come from the watcher
1188 wxLogNull silence;
1189 m_watcher->Add( fn );
1190 }
1191}
1192
1193
1194void PCB_BASE_FRAME::OnFPChange( wxFileSystemWatcherEvent& aEvent )
1195{
1196 if( aEvent.GetPath() != m_watcherFileName.GetFullPath() )
1197 return;
1198
1199 // Start the debounce timer (set to 1 second)
1200 if( !m_watcherDebounceTimer.StartOnce( 1000 ) )
1201 {
1202 wxLogTrace( "KICAD_LIB_WATCH", "Failed to start the debounce timer" );
1203 return;
1204 }
1205}
1206
1207
1209{
1210 wxLogTrace( "KICAD_LIB_WATCH", "OnFpChangeDebounceTimer" );
1211
1212 // Disable logging to avoid spurious messages and check if the file has changed
1213 wxLog::EnableLogging( false );
1214 wxDateTime lastModified = m_watcherFileName.GetModificationTime();
1215 wxLog::EnableLogging( true );
1216
1217 if( lastModified == m_watcherLastModified || !lastModified.IsValid() )
1218 return;
1219
1220 m_watcherLastModified = lastModified;
1221
1224
1225 // When loading a footprint from a library in the footprint editor
1226 // the items UUIDs must be keep and not reinitialized
1227 bool keepUUID = IsType( FRAME_FOOTPRINT_EDITOR );
1228
1229 if( !fp || !tbl )
1230 return;
1231
1233 || IsOK( this, _( "The library containing the current footprint has changed.\n"
1234 "Do you want to reload the footprint?" ) ) )
1235 {
1236 wxString fpname = fp->GetFPID().GetLibItemName();
1237 wxString nickname = fp->GetFPID().GetLibNickname();
1238
1239 try
1240 {
1241 FOOTPRINT* newfp = tbl->FootprintLoad( nickname, fpname, keepUUID );
1242
1243 if( newfp )
1244 {
1245 std::vector<KIID> selectedItems;
1246
1247 for( const EDA_ITEM* item : GetCurrentSelection() )
1248 {
1249 wxString uuidStr = item->m_Uuid.AsString();
1250 selectedItems.emplace_back( item->m_Uuid );
1251 }
1252
1254
1255 ReloadFootprint( newfp );
1256
1257 newfp->ClearAllNets();
1261
1262 std::vector<EDA_ITEM*> sel;
1263
1264 for( const KIID& uuid : selectedItems )
1265 {
1266 BOARD_ITEM* item = GetBoard()->GetItem( uuid );
1267
1268 if( item != DELETED_BOARD_ITEM::GetInstance() )
1269 sel.push_back( item );
1270 }
1271
1272 if( !sel.empty() )
1274 }
1275 }
1276 catch( const IO_ERROR& ioe )
1277 {
1278 DisplayError( this, ioe.What() );
1279 }
1280 }
1281}
@ ERROR_INSIDE
Definition: approximation.h:34
constexpr EDA_IU_SCALE pcbIUScale
Definition: base_units.h:108
constexpr int ARC_LOW_DEF
Definition: base_units.h:119
KIFACE_BASE & Kiface()
Global KIFACE_BASE "get" accessor.
BOX2< VECTOR2D > BOX2D
Definition: box2.h:923
static TOOL_ACTION selectItems
Select a list of items (specified as the event parameter)
Definition: actions.h:228
static const ADVANCED_CFG & GetCfg()
Get the singleton instance's config, which is shared by all consumers.
APP_SETTINGS_BASE is a settings class that should be derived for each standalone KiCad application.
Definition: app_settings.h:92
WINDOW_SETTINGS m_Window
Definition: app_settings.h:213
const std::vector< GRID > DefaultGridSizeList() const
Handles how to draw a screen (a board, a schematic ...)
Definition: base_screen.h:41
VECTOR2D m_LocalOrigin
Relative Screen cursor coordinate (on grid) in user units.
Definition: base_screen.h:90
void SetContentModified(bool aModified=true)
Definition: base_screen.h:59
void InitDataPoints(const VECTOR2I &aPageSizeInternalUnits)
Definition: base_screen.cpp:46
Container for design settings for a BOARD object.
std::map< int, SEVERITY > m_DRCSeverities
void SetGridOrigin(const VECTOR2I &aOrigin)
const VECTOR2I & GetGridOrigin() const
const VECTOR2I & GetAuxOrigin() const
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
Definition: board_item.h:78
virtual void RunOnChildren(const std::function< void(BOARD_ITEM *)> &aFunction, RECURSE_MODE aMode) const
Invoke a function on all children.
Definition: board_item.h:205
Information pertinent to a Pcbnew printed circuit board.
Definition: board.h:297
void SetPlotOptions(const PCB_PLOT_PARAMS &aOptions)
Definition: board.h:719
PCB_LAYER_ID GetCopperLayerStackMaxId() const
Definition: board.cpp:804
LSET GetVisibleLayers() const
A proxy function that calls the correspondent function in m_BoardSettings.
Definition: board.cpp:843
void Add(BOARD_ITEM *aItem, ADD_MODE aMode=ADD_MODE::INSERT, bool aSkipConnectivity=false) override
Removes an item from the container.
Definition: board.cpp:1060
const BOX2I GetBoardEdgesBoundingBox() const
Return the board bounding box calculated using exclusively the board edges (graphics on Edge....
Definition: board.h:955
const BOX2I GetBoundingBox() const override
Return the orthogonal bounding box of this object for display purposes.
Definition: board.h:941
bool IsElementVisible(GAL_LAYER_ID aLayer) const
Test whether a given element category is visible.
Definition: board.cpp:895
const PAGE_INFO & GetPageSettings() const
Definition: board.h:715
void UpdateUserUnits(BOARD_ITEM *aItem, KIGFX::VIEW *aView)
Update any references within aItem (or its descendants) to the user units.
Definition: board.cpp:1413
BOARD_ITEM * GetItem(const KIID &aID) const
Definition: board.cpp:1501
bool BuildConnectivity(PROGRESS_REPORTER *aReporter=nullptr)
Build or rebuild the board connectivity database for the board, especially the list of connected item...
Definition: board.cpp:185
FOOTPRINT * GetFirstFootprint() const
Get the first footprint on the board or nullptr.
Definition: board.h:463
TITLE_BLOCK & GetTitleBlock()
Definition: board.h:721
void IncrementTimeStamp()
Definition: board.cpp:253
void SetPageSettings(const PAGE_INFO &aPageSettings)
Definition: board.h:716
const PCB_PLOT_PARAMS & GetPlotOptions() const
Definition: board.h:718
bool IsLayerVisible(PCB_LAYER_ID aLayer) const
A proxy function that calls the correspondent function in m_BoardSettings tests whether a given layer...
Definition: board.cpp:835
BOARD_DESIGN_SETTINGS & GetDesignSettings() const
Definition: board.cpp:946
void SynchronizeProperties()
Copy the current project's text variables into the boards property cache.
Definition: board.cpp:2135
void SetTitleBlock(const TITLE_BLOCK &aTitleBlock)
Definition: board.h:723
void SetUserUnits(EDA_UNITS aUnits)
Definition: board.h:728
constexpr void SetOrigin(const Vec &pos)
Definition: box2.h:237
constexpr size_type GetWidth() const
Definition: box2.h:214
constexpr Vec Centre() const
Definition: box2.h:97
constexpr size_type GetHeight() const
Definition: box2.h:215
constexpr const Vec & GetOrigin() const
Definition: box2.h:210
constexpr void SetEnd(coord_type x, coord_type y)
Definition: box2.h:297
static DELETED_BOARD_ITEM * GetInstance()
Definition: board_item.h:482
Create and handle a window for the 3d viewer connected to a Kiway and a pcbboard.
void CommonSettingsChanged(int aFlags) override
Notification that common settings are updated.
void ShowChangedLanguage() override
void ReloadRequest()
Request reloading the 3D view.
FRAME_T GetFrameType() const
virtual APP_SETTINGS_BASE * config() const
Return the settings object used in SaveSettings(), and is overloaded in KICAD_MANAGER_FRAME.
virtual void handleIconizeEvent(wxIconizeEvent &aEvent)
Handle a window iconize event.
virtual void OnModify()
Must be called after a model change in order to set the "modify" flag and do other frame-specific pro...
wxAuiManager m_auimgr
virtual bool IsContentModified() const
Get if the contents of the frame have been modified since the last save.
virtual void RecreateToolbars()
bool m_isClosing
Set by the close window event handler after frames are asked if they can close.
bool IsType(FRAME_T aType) const
The base class for create windows for drawing purpose.
virtual void ActivateGalCanvas()
Use to start up the GAL drawing canvas.
void SaveSettings(APP_SETTINGS_BASE *aCfg) override
Save common frame parameters to a configuration data file.
EDA_DRAW_PANEL_GAL::GAL_TYPE m_canvasType
The current canvas type.
void UpdateGridSelectBox()
Rebuild the grid combobox to respond to any changes in the GUI (units, user grid changes,...
void LoadSettings(APP_SETTINGS_BASE *aCfg) override
Load common frame parameters from a configuration file.
void FocusOnLocation(const VECTOR2I &aPos)
Useful to focus on a particular location, in find functions.
COLOR4D m_drawBgColor
virtual void handleActivateEvent(wxActivateEvent &aEvent)
Handle a window activation event.
virtual void UpdateMsgPanel()
Redraw the message panel.
void UpdateStatusBar() override
Update the status bar information.
void ShowChangedLanguage() override
Redraw the menus and what not in current language.
virtual EDA_DRAW_PANEL_GAL * GetCanvas() const
Return a pointer to GAL-based canvas of given EDA draw frame.
void unitsChangeRefresh() override
Called when when the units setting has changed to allow for any derived classes to handle refreshing ...
std::vector< wxWindow * > findDialogs()
virtual void DisplayGridMsg()
Display current grid size in the status bar.
void CommonSettingsChanged(int aFlags) override
Notification event that some of the common (suite-wide) settings have changed.
bool m_showBorderAndTitleBlock
bool GetShowPolarCoords() const
For those frames that support polar coordinates.
GAL_TYPE GetBackend() const
Return the type of backend currently used by GAL canvas.
virtual void SetHighContrastLayer(int aLayer)
Take care of display settings for the given layer to be displayed in high contrast mode.
KIGFX::VIEW_CONTROLS * GetViewControls() const
Return a pointer to the #VIEW_CONTROLS instance used in the panel.
virtual KIGFX::VIEW * GetView() const
Return a pointer to the #VIEW instance used in the panel.
virtual void Refresh(bool aEraseBackground=true, const wxRect *aRect=nullptr) override
void SetEventDispatcher(TOOL_DISPATCHER *aEventDispatcher)
Set a dispatcher that processes events and forwards them to tools.
void StartDrawing()
Begin drawing if it was stopped previously.
A base class for most all the KiCad significant classes used in schematics and boards.
Definition: eda_item.h:96
void SetFlags(EDA_ITEM_FLAGS aMask)
Definition: eda_item.h:135
const KIID m_Uuid
Definition: eda_item.h:498
KICAD_T Type() const
Returns the type of object.
Definition: eda_item.h:108
void ClearBrightened()
Definition: eda_item.h:131
void SetBrightened()
Definition: eda_item.h:128
A mix-in class (via multiple inheritance) that handles texts such as labels, parts,...
Definition: eda_text.h:80
static const TOOL_EVENT ConnectivityChangedEvent
Selected item had a property changed (except movement)
Definition: actions.h:340
void SetPosition(const VECTOR2I &aPos) override
Definition: footprint.cpp:2441
void SetOrientation(const EDA_ANGLE &aNewAngle)
Definition: footprint.cpp:2523
bool IsFlipped() const
Definition: footprint.h:396
const LIB_ID & GetFPID() const
Definition: footprint.h:253
void ClearAllNets()
Clear (i.e.
Definition: footprint.cpp:1060
void Flip(const VECTOR2I &aCentre, FLIP_DIRECTION aFlipDirection) override
Flip this object, i.e.
Definition: footprint.cpp:2382
VECTOR2I GetPosition() const override
Definition: footprint.h:229
Hold a record identifying a library accessed by the appropriate footprint library #PLUGIN object in t...
Definition: fp_lib_table.h:42
const FP_LIB_TABLE_ROW * FindRow(const wxString &aNickName, bool aCheckIfEnabled=false)
Return an FP_LIB_TABLE_ROW if aNickName is found in this table or in any chained fall back table frag...
FOOTPRINT * FootprintLoad(const wxString &aNickname, const wxString &aFootprintName, bool aKeepUUID=false)
Load a footprint having aFootprintName from the library given by aNickname.
A general implementation of a COLLECTORS_GUIDE.
Definition: collectors.h:319
void SetIgnoreBlindBuriedVias(bool ignore)
Definition: collectors.h:458
void SetIgnoreTracks(bool ignore)
Definition: collectors.h:464
void SetIgnoreFootprintsOnFront(bool ignore)
Definition: collectors.h:422
void SetIgnoreFPTextOnFront(bool ignore)
Definition: collectors.h:410
void SetIgnoreMicroVias(bool ignore)
Definition: collectors.h:461
void SetIgnoreFPTextOnBack(bool ignore)
Definition: collectors.h:404
void SetIgnoreThroughVias(bool ignore)
Definition: collectors.h:455
void SetIgnoreThroughHolePads(bool ignore)
Definition: collectors.h:440
void SetIgnoreFPReferences(bool ignore)
Definition: collectors.h:452
void SetIgnoreFPValues(bool ignore)
Definition: collectors.h:446
void SetIgnoreFootprintsOnBack(bool ignore)
Definition: collectors.h:416
Hold an error message and may be used when throwing exceptions containing meaningful error messages.
Definition: ki_exception.h:77
virtual const wxString What() const
A composite of Problem() and Where()
Definition: exceptions.cpp:30
A color representation with 4 components: red, green, blue, alpha.
Definition: color4d.h:104
virtual RENDER_SETTINGS * GetSettings()=0
Return a pointer to current settings that are going to be used when drawing items.
Contains methods for drawing PCB-specific items.
Definition: pcb_painter.h:181
virtual PCB_RENDER_SETTINGS * GetSettings() override
Return a pointer to current settings that are going to be used when drawing items.
Definition: pcb_painter.h:186
PCB specific render settings.
Definition: pcb_painter.h:79
void LoadColors(const COLOR_SETTINGS *aSettings) override
void LoadDisplayOptions(const PCB_DISPLAY_OPTIONS &aOptions)
Load settings related to display options (high-contrast mode, full or outline modes for vias/pads/tra...
virtual void Update(const VIEW_ITEM *aItem, int aUpdateFlags) const override
For dynamic VIEWs, inform the associated VIEW that the graphical representation of this item has chan...
Definition: pcb_view.cpp:91
virtual void Add(VIEW_ITEM *aItem, int aDrawPriority=-1) override
Add a VIEW_ITEM to the view.
Definition: pcb_view.cpp:57
virtual void Remove(VIEW_ITEM *aItem) override
Remove a VIEW_ITEM from the view.
Definition: pcb_view.cpp:74
void UpdateDisplayOptions(const PCB_DISPLAY_OPTIONS &aOptions)
Definition: pcb_view.cpp:122
Container for all the knowledge about how graphical objects are drawn on any output surface/device.
void SetDefaultFont(const wxString &aFont)
void SetGapLengthRatio(double aRatio)
void SetDashLengthRatio(double aRatio)
void SetHighlightFactor(float aFactor)
void SetSelectFactor(float aFactor)
VECTOR2D GetCursorPosition() const
Return the current cursor position in world coordinates.
An abstract base class for deriving all objects that can be added to a VIEW.
Definition: view_item.h:86
bool IsBOARD_ITEM() const
Definition: view_item.h:102
Hold a (potentially large) number of VIEW_ITEMs and renders them on a graphics device provided by the...
Definition: view.h:67
BOX2D GetViewport() const
Return the current viewport visible area rectangle.
Definition: view.cpp:520
bool HasItem(const VIEW_ITEM *aItem) const
Indicates whether or not the given item has been added to the view.
Definition: view.cpp:1659
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:457
void RecacheAllItems()
Rebuild GAL display lists.
Definition: view.cpp:1439
void UpdateAllItems(int aUpdateFlags)
Update all items in the view according to the given flags.
Definition: view.cpp:1549
PAINTER * GetPainter() const
Return the painter object used by the view for drawing #VIEW_ITEMS.
Definition: view.h:216
void UpdateAllItemsConditionally(int aUpdateFlags, std::function< bool(VIEW_ITEM *)> aCondition)
Update items in the view according to the given flags and condition.
Definition: view.cpp:1559
Definition: kiid.h:49
wxString AsString() const
Definition: kiid.cpp:246
PROJECT & Prj() const
Return a reference to the PROJECT associated with this KIWAY.
A minimalistic software bus for communications between various DLLs/DSOs (DSOs) within the same KiCad...
Definition: kiway.h:285
const UTF8 & GetLibItemName() const
Definition: lib_id.h:102
const UTF8 & GetLibNickname() const
Return the logical library name portion of a LIB_ID.
Definition: lib_id.h:87
const wxString GetFullURI(bool aSubstituted=false) const
Return the full location specifying URI for the LIB, either in original UI form or in environment var...
LSET is a set of PCB_LAYER_IDs.
Definition: lset.h:37
A class to perform either relative or absolute display origin transforms for a single axis of a point...
Definition: pad.h:54
Describe the page size and margins of a paper page on which to eventually print or plot.
Definition: page_info.h:59
const VECTOR2D GetSizeIU(double aIUScale) const
Gets the page size in internal units.
Definition: page_info.h:171
DISPLAY_OPTIONS m_Display
MAGNETIC_SETTINGS m_MagneticItems
SEVERITY GetSeverity(int aErrorCode) const override
std::unique_ptr< wxFileSystemWatcher > m_watcher
virtual void ReloadFootprint(FOOTPRINT *aFootprint)
Reload the footprint from the library.
virtual void OnDisplayOptionsChanged()
void FocusOnItems(std::vector< BOARD_ITEM * > aItems, PCB_LAYER_ID aLayer=UNDEFINED_LAYER)
void handleIconizeEvent(wxIconizeEvent &aEvent) override
Handle a window iconize event.
void FocusOnItem(EDA_ITEM *aItem) override
Focus on a particular canvas item.
ORIGIN_TRANSFORMS & GetOriginTransforms() override
Return a reference to the default ORIGIN_TRANSFORMS object.
virtual const PCB_PLOT_PARAMS & GetPlotSettings() const
Return the PCB_PLOT_PARAMS for the BOARD owned by this frame.
std::unique_ptr< NL_PCBNEW_PLUGIN > m_spaceMouse
wxDateTime m_watcherLastModified
const PCB_DISPLAY_OPTIONS & GetDisplayOptions() const
Display options control the way tracks, vias, outlines and other things are shown (for instance solid...
void LoadSettings(APP_SETTINGS_BASE *aCfg) override
Load common frame parameters from a configuration file.
void RemoveBoardChangeListener(wxEvtHandler *aListener)
Remove aListener to from the board changed listener list.
void handleActivateEvent(wxActivateEvent &aEvent) override
Handle a window activation event.
void setFPWatcher(FOOTPRINT *aFootprint)
Create or removes a watcher on the specified footprint.
virtual void unitsChangeRefresh() override
Called when when the units setting has changed to allow for any derived classes to handle refreshing ...
EDA_ITEM * GetItem(const KIID &aId) const override
Fetch an item by KIID.
const BOX2I GetDocumentExtents(bool aIncludeAllVisible=true) const override
Return bounding box of document with option to not include some items.
const VECTOR2I GetPageSizeIU() const override
Works off of GetPageSettings() to return the size of the paper page in the internal units of this par...
PCBNEW_SETTINGS * GetPcbNewSettings() const
virtual void SwitchLayer(PCB_LAYER_ID aLayer)
Change the active layer in the frame.
virtual PCB_LAYER_ID GetActiveLayer() const
PCB_BASE_FRAME(KIWAY *aKiway, wxWindow *aParent, FRAME_T aFrameType, const wxString &aTitle, const wxPoint &aPos, const wxSize &aSize, long aStyle, const wxString &aFrameName)
void OnModify() override
Must be called after a change in order to set the "modify" flag and update other data structures and ...
const VECTOR2I & GetAuxOrigin() const
virtual PCB_VIEWERS_SETTINGS_BASE * GetViewerSettingsBase() const
const VECTOR2I GetUserOrigin() const
virtual MAGNETIC_SETTINGS * GetMagneticItemsSettings()
std::vector< wxEvtHandler * > m_boardChangeListeners
void OnFPChange(wxFileSystemWatcherEvent &aEvent)
Handler for FP change events.
bool canCloseWindow(wxCloseEvent &aCloseEvent) override
const VECTOR2I & GetGridOrigin() const override
Return the absolute coordinates of the origin of the snap grid.
void CommonSettingsChanged(int aFlags) override
Notification event that some of the common (suite-wide) settings have changed.
const TITLE_BLOCK & GetTitleBlock() const override
const PAGE_INFO & GetPageSettings() const override
BOX2I GetBoardBoundingBox(bool aBoardEdgesOnly=false) const
Calculate the bounding box containing all board items (or board edge segments).
PCB_DRAW_PANEL_GAL * GetCanvas() const override
Return a pointer to GAL-based canvas of given EDA draw frame.
virtual void ActivateGalCanvas() override
Use to start up the GAL drawing canvas.
void SetDrawBgColor(const COLOR4D &aColor) override
void OnFpChangeDebounceTimer(wxTimerEvent &aEvent)
Handler for the filesystem watcher debounce timer.
virtual void SetBoard(BOARD *aBoard, PROGRESS_REPORTER *aReporter=nullptr)
Set the #m_Pcb member in such as way as to ensure deleting any previous BOARD.
virtual void SetPageSettings(const PAGE_INFO &aPageSettings) override
void SetTitleBlock(const TITLE_BLOCK &aTitleBlock) override
void SaveSettings(APP_SETTINGS_BASE *aCfg) override
Save common frame parameters to a configuration data file.
PCB_SCREEN * GetScreen() const override
Return a pointer to a BASE_SCREEN or one of its derivatives.
BOARD * GetBoard() const
virtual BOARD_DESIGN_SETTINGS & GetDesignSettings() const
Return the BOARD_DESIGN_SETTINGS for the open project.
virtual void ShowChangedLanguage() override
Redraw the menus and what not in current language.
void AddBoardChangeListener(wxEvtHandler *aListener)
Add aListener to post #EDA_EVT_BOARD_CHANGED command events to.
virtual void AddFootprintToBoard(FOOTPRINT *aFootprint)
Add the given footprint to the board.
virtual void doReCreateMenuBar() override
void SetDisplayOptions(const PCB_DISPLAY_OPTIONS &aOptions, bool aRefresh=true)
Update the current display options.
GENERAL_COLLECTORS_GUIDE GetCollectorsGuide()
virtual void SetPlotSettings(const PCB_PLOT_PARAMS &aSettings)
PCB_DISPLAY_OPTIONS m_displayOptions
FOOTPRINT_EDITOR_SETTINGS * GetFootprintEditorSettings() const
void SetGridOrigin(const VECTOR2I &aPoint) override
PCB_ORIGIN_TRANSFORMS m_originTransforms
EDA_3D_VIEWER_FRAME * CreateAndShow3D_Frame()
Show the 3D view frame.
wxTimer m_watcherDebounceTimer
EDA_3D_VIEWER_FRAME * Get3DViewerFrame()
virtual void SetActiveLayer(PCB_LAYER_ID aLayer)
virtual COLOR_SETTINGS * GetColorSettings(bool aForceRefresh=false) const override
Helper to retrieve the current color settings.
wxFileName m_watcherFileName
virtual void Update3DView(bool aMarkDirty, bool aRefresh, const wxString *aTitle=nullptr)
Update the 3D view, if the viewer is opened by this frame.
virtual void UpdateStatusBar() override
Update the status bar information.
HIGH_CONTRAST_MODE m_ContrastModeDisplay
How inactive layers are displayed.
void UpdateColors()
Update the color settings in the painter and GAL.
virtual KIGFX::PCB_VIEW * GetView() const override
Return a pointer to the #VIEW instance used in the panel.
void DisplayBoard(BOARD *aBoard, PROGRESS_REPORTER *aReporter=nullptr)
Add all items from the current board to the VIEW, so they can be displayed by GAL.
void RedrawRatsnest()
Return the bounding box of the view that should be used if model is not valid.
T ToDisplayRelY(T aInternalValue) const
T ToDisplayAbsX(T aInternalValue) const
T ToDisplayRelX(T aInternalValue) const
Transform a 2-D coordinate point referenced to the internal origin to the equivalent point referenced...
T ToDisplayAbsY(T aInternalValue) const
Parameters and options when plotting/printing a board.
virtual SETTINGS_MANAGER & GetSettingsManager() const
Definition: pgm_base.h:125
A progress reporter interface for use in multi-threaded environments.
static FP_LIB_TABLE * PcbFootprintLibs(PROJECT *aProject)
Return the table of footprint libraries without Kiway.
Definition: project_pcb.cpp:37
static void Cleanup3DCache(PROJECT *aProject)
T * GetAppSettings(const wxString &aFilename)
Return a handle to the a given settings by type.
Represent a set of closed polygons.
bool IsEmpty() const
Return true if the set is empty (no polygons at all)
int Append(int x, int y, int aOutline=-1, int aHole=-1, bool aAllowDuplication=false)
Appends a vertex at the end of the given outline/hole (default: the last outline)
int NewOutline()
Creates a new empty polygon in the set and returns its index.
void Deflate(int aAmount, CORNER_STRATEGY aCornerStrategy, int aMaxError)
void BooleanIntersection(const SHAPE_POLY_SET &b)
Perform boolean polyset intersection.
void BooleanSubtract(const SHAPE_POLY_SET &b)
Perform boolean polyset difference.
const BOX2I BBox(int aClearance=0) const override
Compute a bounding box of the shape, with a margin of aClearance a collision.
Hold the information shown in the lower right corner of a plot, printout, or editing view.
Definition: title_block.h:41
TOOL_MANAGER * m_toolManager
Definition: tools_holder.h:171
TOOL_DISPATCHER * m_toolDispatcher
Definition: tools_holder.h:173
TOOL_MANAGER * GetToolManager() const
Return the MVC controller.
Definition: tools_holder.h:55
virtual SELECTION & GetCurrentSelection()
Get the current selection from the canvas area.
Definition: tools_holder.h:98
@ MODEL_RELOAD
Model changes (the sheet for a schematic)
Definition: tool_base.h:80
@ GAL_SWITCH
Rendering engine changes.
Definition: tool_base.h:82
void PostEvent(const TOOL_EVENT &aEvent)
Put an event to the event queue to be processed at the end of event processing cycle.
bool RunAction(const std::string &aActionName, T aParam)
Run the specified action immediately, pausing the current action to run the new one.
Definition: tool_manager.h:150
void ResetTools(TOOL_BASE::RESET_REASON aReason)
Reset all tools (i.e.
void SetEnvironment(EDA_ITEM *aModel, KIGFX::VIEW *aView, KIGFX::VIEW_CONTROLS *aViewControls, APP_SETTINGS_BASE *aSettings, TOOLS_HOLDER *aFrame)
Set the work environment (model, view, view controls and the parent window).
wxString MessageTextFromValue(double aValue, bool aAddUnitLabel=true, EDA_DATA_TYPE aType=EDA_DATA_TYPE::DISTANCE) const
A lower-precision version of StringFromValue().
EDA_UNITS GetUserUnits() const
Handle a list of polygons defining a copper zone.
Definition: zone.h:74
SHAPE_POLY_SET * Outline()
Definition: zone.h:368
void TransformShapeToPolygon(SHAPE_POLY_SET &aBuffer, PCB_LAYER_ID aLayer, int aClearance, int aError, ERROR_LOC aErrorLoc, bool ignoreLineWidth=false) const override
Convert the zone shape to a closed polygon Used in filling zones calculations Circles and arcs are ap...
Definition: zone.cpp:1568
@ CLEANUP_FIRST
Definition: cleanup_item.h:33
bool IsOK(wxWindow *aParent, const wxString &aMessage)
Display a yes/no dialog with aMessage and returns the user response.
Definition: confirm.cpp:249
void DisplayInfoMessage(wxWindow *aParent, const wxString &aMessage, const wxString &aExtraInfo)
Display an informational message box with aMessage.
Definition: confirm.cpp:221
void DisplayError(wxWindow *aParent, const wxString &aText)
Display an error or warning message box with aMessage.
Definition: confirm.cpp:170
This file is part of the common library.
#define _(s)
Declaration of the eda_3d_viewer class.
static constexpr EDA_ANGLE ANGLE_0
Definition: eda_angle.h:401
#define QUALIFIED_VIEWER3D_FRAMENAME(parent)
#define IS_NEW
New item, just created.
FRAME_T
The set of EDA_BASE_FRAME derivatives, typically stored in EDA_BASE_FRAME::m_Ident.
Definition: frame_type.h:33
@ FRAME_PCB_EDITOR
Definition: frame_type.h:42
@ FRAME_CVPCB_DISPLAY
Definition: frame_type.h:53
@ FRAME_FOOTPRINT_VIEWER
Definition: frame_type.h:45
@ FRAME_FOOTPRINT_WIZARD
Definition: frame_type.h:46
@ FRAME_FOOTPRINT_PREVIEW
Definition: frame_type.h:48
@ FRAME_FOOTPRINT_CHOOSER
Definition: frame_type.h:44
@ FRAME_FOOTPRINT_EDITOR
Definition: frame_type.h:43
@ FRAME_PCB_DISPLAY3D
Definition: frame_type.h:47
@ FRAME_CVPCB
Definition: frame_type.h:52
static const std::string KiCadFootprintFileExtension
KIID niluuid(0)
bool IsCopperLayer(int aLayerId)
Test whether a layer is a copper layer.
Definition: layer_ids.h:663
@ LAYER_FOOTPRINTS_FR
Show footprints on front.
Definition: layer_ids.h:258
@ LAYER_FP_REFERENCES
Show footprints references (when texts are visible).
Definition: layer_ids.h:265
@ LAYER_PADS
Meta control for all pads opacity/visibility (color ignored).
Definition: layer_ids.h:291
@ LAYER_TRACKS
Definition: layer_ids.h:266
@ LAYER_FP_TEXT
Definition: layer_ids.h:239
@ LAYER_FOOTPRINTS_BK
Show footprints on back.
Definition: layer_ids.h:259
@ LAYER_FP_VALUES
Show footprints values (when texts are visible).
Definition: layer_ids.h:262
@ LAYER_VIAS
Meta control for all vias opacity/visibility.
Definition: layer_ids.h:232
PCB_LAYER_ID
A quick note on layer IDs:
Definition: layer_ids.h:60
@ Edge_Cuts
Definition: layer_ids.h:112
@ B_Mask
Definition: layer_ids.h:98
@ F_Mask
Definition: layer_ids.h:97
@ UNDEFINED_LAYER
Definition: layer_ids.h:61
Message panel definition file.
@ COLOR
Color has changed.
Definition: view_item.h:54
@ REPAINT
Item needs to be redrawn.
Definition: view_item.h:58
@ ALL
All except INITIAL_ADD.
Definition: view_item.h:59
Declaration of the NL_PCBNEW_PLUGIN class.
wxDEFINE_EVENT(EDA_EVT_BOARD_CHANGED, wxCommandEvent)
PGM_BASE & Pgm()
The global program "get" accessor.
Definition: pgm_base.cpp:1071
see class PGM_BASE
SEVERITY
@ RPT_SEVERITY_ACTION
KIWAY Kiway(KFCTL_STANDALONE)
float highlight_factor
How much to brighten highlighted objects by.
Definition: app_settings.h:122
float select_factor
How much to brighten selected objects by.
Definition: app_settings.h:123
const double IU_PER_MILS
Definition: base_units.h:77
constexpr int mmToIU(double mm) const
Definition: base_units.h:88
wxString user_grid_x
Definition: grid_settings.h:67
std::vector< GRID > grids
Definition: grid_settings.h:66
wxString user_grid_y
Definition: grid_settings.h:68
Common grid settings, available to every frame.
Definition: grid_settings.h:34
GRID_SETTINGS grid
Definition: app_settings.h:81
std::vector< double > zoom_factors
Definition: app_settings.h:78
#define TEXTVARS_CHANGED
Definition: tools_holder.h:153
double RAD2DEG(double rad)
Definition: trigo.h:167
@ PCB_SHAPE_T
class PCB_SHAPE, a segment not on copper layers
Definition: typeinfo.h:88
@ PCB_DIM_ORTHOGONAL_T
class PCB_DIM_ORTHOGONAL, a linear dimension constrained to x/y
Definition: typeinfo.h:105
@ PCB_DIM_LEADER_T
class PCB_DIM_LEADER, a leader dimension (graphic item)
Definition: typeinfo.h:102
@ PCB_VIA_T
class PCB_VIA, a via (like a track segment on a copper layer)
Definition: typeinfo.h:97
@ PCB_DIM_CENTER_T
class PCB_DIM_CENTER, a center point marking (graphic item)
Definition: typeinfo.h:103
@ PCB_TEXTBOX_T
class PCB_TEXTBOX, wrapped text on a layer
Definition: typeinfo.h:93
@ PCB_ZONE_T
class ZONE, a copper pour area
Definition: typeinfo.h:107
@ PCB_TEXT_T
class PCB_TEXT, text on a layer
Definition: typeinfo.h:92
@ PCB_FIELD_T
class PCB_FIELD, text associated with a footprint property
Definition: typeinfo.h:90
@ PCB_MARKER_T
class PCB_MARKER, a marker used to show something
Definition: typeinfo.h:99
@ PCB_FOOTPRINT_T
class FOOTPRINT, a footprint
Definition: typeinfo.h:86
@ PCB_DIM_ALIGNED_T
class PCB_DIM_ALIGNED, a linear dimension (graphic item)
Definition: typeinfo.h:101
@ PCB_PAD_T
class PAD, a pad in a footprint
Definition: typeinfo.h:87
@ PCB_ARC_T
class PCB_ARC, an arc track segment on a copper layer
Definition: typeinfo.h:98
@ PCB_TRACE_T
class PCB_TRACK, a track segment (segment on a copper layer)
Definition: typeinfo.h:96
@ PCB_DIM_RADIAL_T
class PCB_DIM_RADIAL, a radius or diameter dimension
Definition: typeinfo.h:104
VECTOR2< int32_t > VECTOR2I
Definition: vector2d.h:695
VECTOR2D ToVECTOR2D(const wxPoint &aPoint)
Definition: vector2wx.h:40
Definition of file extensions used in Kicad.
#define ZOOM_LIST_PCBNEW
Definition: zoom_defines.h:32
#define ZOOM_LIST_PCBNEW_HYPER
Definition: zoom_defines.h:35