KiCad PCB EDA Suite
Loading...
Searching...
No Matches
pl_editor_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) 2013 CERN
5 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
6 * @author Jean-Pierre Charras, jp.charras at wanadoo.fr
7 *
8 * This program is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public License
10 * as published by the Free Software Foundation; either version 2
11 * of the License, or (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, you may find one here:
20 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
21 * or you may search the http://www.gnu.org website for the version 2 license,
22 * or you may write to the Free Software Foundation, Inc.,
23 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
24 */
25
26#include <kiface_base.h>
27#include <pgm_base.h>
28#include <bitmaps.h>
29#include <core/arraydim.h>
33#include <confirm.h>
34#include <kiplatform/app.h>
36#include <gal/painter.h>
38#include <tool/selection.h>
39#include <tool/action_toolbar.h>
42#include <tool/tool_manager.h>
43#include <tool/common_control.h>
44#include <tool/common_tools.h>
45#include <tool/picker_tool.h>
46#include <tool/zoom_tool.h>
48#include "pl_editor_frame.h"
49#include "pl_editor_id.h"
50#include "pl_editor_settings.h"
51#include "properties_frame.h"
52#include <toolbars_pl_editor.h>
53#include "tools/pl_actions.h"
56#include "tools/pl_edit_tool.h"
60#include <view/view_controls.h>
61
62#include <wx/filedlg.h>
63#include <wx/print.h>
64#include <wx/treebook.h>
65#include <wx/msgdlg.h>
66#include <wx/log.h>
67#include <kiplatform/ui.h>
68
69#if defined(__linux__) || defined(__FreeBSD__)
71#else
73#endif
74
75
76BEGIN_EVENT_TABLE( PL_EDITOR_FRAME, EDA_DRAW_FRAME )
77 EVT_MENU( wxID_CLOSE, PL_EDITOR_FRAME::OnExit )
78 EVT_MENU( wxID_EXIT, PL_EDITOR_FRAME::OnExit )
79
80 EVT_MENU( wxID_FILE, PL_EDITOR_FRAME::Files_io )
81
84
87
88 // Drop files event
89 EVT_DROP_FILES( PL_EDITOR_FRAME::OnDropFiles )
90END_EVENT_TABLE()
91
92
93PL_EDITOR_FRAME::PL_EDITOR_FRAME( KIWAY* aKiway, wxWindow* aParent ) :
94 EDA_DRAW_FRAME( aKiway, aParent, FRAME_PL_EDITOR, wxT( "PlEditorFrame" ), wxDefaultPosition,
98 m_originSelectBox( nullptr ), m_originSelectChoice( 0 ), m_pageSelectBox( nullptr ),
99 m_mruImagePath( wxEmptyString )
100{
101 m_maximizeByDefault = true;
103
104 m_showBorderAndTitleBlock = true; // true for reference drawings.
106 m_aboutTitle = _HKI( "KiCad Drawing Sheet Editor" );
107
108 // Give an icon
109 wxIcon icon;
110 wxIconBundle icon_bundle;
111
112 icon.CopyFromBitmap( KiBitmap( BITMAPS::icon_pagelayout_editor, 48 ) );
113 icon_bundle.AddIcon( icon );
114 icon.CopyFromBitmap( KiBitmap( BITMAPS::icon_pagelayout_editor, 128 ) );
115 icon_bundle.AddIcon( icon );
116 icon.CopyFromBitmap( KiBitmap( BITMAPS::icon_pagelayout_editor, 256 ) );
117 icon_bundle.AddIcon( icon );
118 icon.CopyFromBitmap( KiBitmap( BITMAPS::icon_pagelayout_editor_32 ) );
119 icon_bundle.AddIcon( icon );
120 icon.CopyFromBitmap( KiBitmap( BITMAPS::icon_pagelayout_editor_16 ) );
121 icon_bundle.AddIcon( icon );
122
123 SetIcons( icon_bundle );
124
125 // Create GAL canvas
126 auto* drawPanel = new PL_DRAW_PANEL_GAL( this, -1, wxPoint( 0, 0 ), m_frameSize,
129 SetCanvas( drawPanel );
130
131 LoadSettings( config() );
132
134 DragAcceptFiles( true );
135
136 VECTOR2I pageSizeIU = GetPageLayout().GetPageSettings().GetSizeIU( drawSheetIUScale.IU_PER_MILS );
137 SetScreen( new BASE_SCREEN( pageSizeIU ) );
138
139 setupTools();
142
146
147 wxStatusBar* stsbar = GetStatusBar();
148 int spacer = KIUI::GetTextSize( wxT( "M" ), stsbar ).x * 2;
149
150 int dims[] = {
151
152 // balance of status bar on far left is set to a default or whatever is left over.
153 -1,
154
155 // When using GetTextSize() remember the width of '1' is not the same
156 // as the width of '0' unless the font is fixed width, and it usually won't be.
157
158 // zoom:
159 KIUI::GetTextSize( wxT( "Z 762000" ), stsbar ).x + spacer,
160
161 // cursor coords
162 KIUI::GetTextSize( wxT( "X 0234.567 Y 0234.567" ), stsbar ).x + spacer,
163
164 // delta distances
165 KIUI::GetTextSize( wxT( "dx 0234.567 dx 0234.567" ), stsbar ).x + spacer,
166
167 // grid size
168 KIUI::GetTextSize( wxT( "grid 0234.567" ), stsbar ).x + spacer,
169
170 // Coord origin (use the bigger message)
171 KIUI::GetTextSize( _( "coord origin: Right Bottom page corner" ), stsbar ).x + spacer,
172
173 // units display, Inches is bigger than mm
174 KIUI::GetTextSize( _( "Inches" ), stsbar ).x + spacer,
175
176 // constraint mode
177 KIUI::GetTextSize( _( "Constrain to H, V, 45" ), stsbar ).x + spacer
178 };
179
180 if( stsbar )
181 stsbar->SetFieldsCount( arrayDim( dims ), dims );
182
183 m_auimgr.SetManagedWindow( this );
184
187
188 // Rows; layers 4 - 6
189 m_auimgr.AddPane( m_tbTopMain, EDA_PANE().HToolbar().Name( "TopMainToolbar" )
190 .Top().Layer( 6 ) );
191 m_auimgr.AddPane( m_tbLeft, EDA_PANE().VToolbar().Name( "LeftToolbar" )
192 .Left().Layer( 3 ) );
193 m_auimgr.AddPane( m_messagePanel, EDA_PANE().Messages().Name( "MsgPanel" )
194 .Bottom().Layer( 6 ) );
195
196 // Columns; layers 1 - 3
197 m_auimgr.AddPane( m_tbRight, EDA_PANE().VToolbar().Name( "RightToolbar" )
198 .Right().Layer( 2 ) );
199
200 m_auimgr.AddPane( m_propertiesPagelayout, EDA_PANE().Palette().Name( "Props" )
201 .Right().Layer( 3 )
202 .Caption( _( "Properties" ) )
203 .MinSize( m_propertiesPagelayout->GetMinSize() )
204 .BestSize( m_propertiesFrameWidth, -1 ) );
205
206 // Center
207 m_auimgr.AddPane( GetCanvas(), EDA_PANE().Canvas().Name( "DrawFrame" )
208 .Center() );
209
211
214
215 // Add the exit key handler
216 setupUnits( config() );
217
218 VECTOR2I originCoord = ReturnCoordOriginCorner();
219 SetGridOrigin( originCoord );
220
221 // Initialize the current drawing sheet
222#if 0 //start with empty layout
225#else // start with the default KiCad layout
226 DS_DATA_MODEL::GetTheInstance().LoadDrawingSheet( wxEmptyString, nullptr );
227#endif
229
230 // Ensure the window is on top
231 Raise();
232
233 // Register a call to update the toolbar sizes. It can't be done immediately because
234 // it seems to require some sizes calculated that aren't yet (at least on GTK).
235 CallAfter( [this]()
236 {
237 // Ensure the controls on the toolbars all are correctly sized
239 } );
240
241 try
242 {
243 if( !m_spaceMouse )
244 {
245#if defined(__linux__) || defined(__FreeBSD__)
246 m_spaceMouse = std::make_unique<SPNAV_2D_PLUGIN>( GetCanvas() );
247 m_spaceMouse->SetScale( drawSheetIUScale.IU_PER_MILS / pcbIUScale.IU_PER_MILS );
248#else
249 m_spaceMouse = std::make_unique<NL_PL_EDITOR_PLUGIN>();
250#endif
251 }
252
253 m_spaceMouse->SetCanvas( GetCanvas() );
254 }
255 catch( const std::system_error& e )
256 {
257 wxLogTrace( wxT( "KI_TRACE_NAVLIB" ), e.what() );
258 }
259}
260
261
263{
264 // Ensure m_canvasType is up to date, to save it in config
266
267 // Shutdown all running tools
268 if( m_toolManager )
269 m_toolManager->ShutdownAllTools();
270}
271
272
274{
275 // Create the manager and dispatcher & route draw panel events to the dispatcher
277 m_toolManager->SetEnvironment( nullptr, GetCanvas()->GetView(),
278 GetCanvas()->GetViewControls(), config(), this );
279 m_actions = new PL_ACTIONS();
281
283
284 // Register tools
285 m_toolManager->RegisterTool( new COMMON_CONTROL );
286 m_toolManager->RegisterTool( new COMMON_TOOLS );
287 m_toolManager->RegisterTool( new ZOOM_TOOL );
288 m_toolManager->RegisterTool( new PL_SELECTION_TOOL );
289 m_toolManager->RegisterTool( new PL_EDITOR_CONTROL );
290 m_toolManager->RegisterTool( new PL_DRAWING_TOOLS );
291 m_toolManager->RegisterTool( new PL_EDIT_TOOL );
292 m_toolManager->RegisterTool( new PL_POINT_EDITOR );
293 m_toolManager->RegisterTool( new PICKER_TOOL );
294 m_toolManager->InitTools();
295
296 // Run the selection tool, it is supposed to be always active
297 m_toolManager->InvokeTool( "common.InteractiveSelection" );
298}
299
300
302{
304
305 ACTION_MANAGER* mgr = m_toolManager->GetActionManager();
306 EDITOR_CONDITIONS cond( this );
307
308 wxASSERT( mgr );
309
310#define ENABLE( x ) ACTION_CONDITIONS().Enable( x )
311#define CHECK( x ) ACTION_CONDITIONS().Check( x )
312
316
318
323
330
339
340 // Not a tool, just a way to activate the action
343
344 auto titleBlockNormalMode =
345 [] ( const SELECTION& )
346 {
348 };
349
350 auto titleBlockEditMode =
351 [] ( const SELECTION& )
352 {
354 };
355
356 mgr->SetConditions( PL_ACTIONS::layoutNormalMode, CHECK( titleBlockNormalMode ) );
357 mgr->SetConditions( PL_ACTIONS::layoutEditMode, CHECK( titleBlockEditMode ) );
358
359#undef CHECK
360#undef ENABLE
361}
362
363
364bool PL_EDITOR_FRAME::OpenProjectFiles( const std::vector<wxString>& aFileSet, int aCtl )
365{
366 wxString fn = aFileSet[0];
367
368 if( !LoadDrawingSheetFile( fn ) )
369 {
370 wxMessageBox( wxString::Format( _( "Error loading drawing sheet '%s'." ), fn ) );
371 return false;
372 }
373 else
374 {
376 return true;
377 }
378}
379
380
382{
383 // Must be called after a change in order to set the "modify" flag and update
384 // the frame title.
386
388
389 if( m_isClosing )
390 return;
391
393}
394
395
397{
398 return GetScreen() && GetScreen()->IsContentModified();
399}
400
401
402void PL_EDITOR_FRAME::OnExit( wxCommandEvent& aEvent )
403{
404 if( aEvent.GetId() == wxID_EXIT )
405 Kiway().OnKiCadExit();
406
407 if( aEvent.GetId() == wxID_CLOSE || Kiface().IsSingle() )
408 Close( false );
409}
410
411
412bool PL_EDITOR_FRAME::canCloseWindow( wxCloseEvent& aEvent )
413{
414 // Shutdown blocks must be determined and vetoed as early as possible
416 && aEvent.GetId() == wxEVT_QUERY_END_SESSION
417 && IsContentModified() )
418 {
419 return false;
420 }
421
422 if( IsContentModified() )
423 {
424 wxFileName filename = GetCurrentFileName();
425 wxString msg = _( "Save changes to '%s' before closing?" );
426
427 if( !HandleUnsavedChanges( this, wxString::Format( msg, filename.GetFullName() ),
428 [&]() -> bool
429 {
430 return saveCurrentPageLayout();
431 } ) )
432 {
433 return false;
434 }
435 }
436
437 return true;
438}
439
440
442{
443 // do not show the window because we do not want any paint event
444 Show( false );
445
446 // clean up the data before the view is destroyed
448
449 // On Linux, m_propertiesPagelayout must be destroyed
450 // before deleting the main frame to avoid a crash when closing
451 m_propertiesPagelayout->Destroy();
452 Destroy();
453}
454
455
456void PL_EDITOR_FRAME::OnSelectPage( wxCommandEvent& event )
457{
458 KIGFX::VIEW* view = GetCanvas()->GetView();
459 view->SetLayerVisible( LAYER_DRAWINGSHEET_PAGE1, m_pageSelectBox->GetSelection() == 0 );
460 view->SetLayerVisible( LAYER_DRAWINGSHEET_PAGEn, m_pageSelectBox->GetSelection() == 1 );
461 GetCanvas()->Refresh();
462}
463
464
466{
467 m_originSelectChoice = m_originSelectBox->GetSelection();
468 UpdateStatusBar(); // Update grid origin
470 GetCanvas()->Refresh();
471}
472
473
474void PL_EDITOR_FRAME::ToPrinter( bool doPreview )
475{
476 // static print data and page setup data, to remember settings during the session
477 static wxPrintData* s_PrintData;
478 static wxPageSetupDialogData* s_pageSetupData = nullptr;
479
480 const PAGE_INFO& pageInfo = GetPageSettings();
481
482 if( s_PrintData == nullptr ) // First print
483 {
484 s_PrintData = new wxPrintData();
485 s_PrintData->SetQuality( wxPRINT_QUALITY_HIGH ); // Default resolution = HIGH;
486 }
487
488 if( !s_PrintData->Ok() )
489 {
490 wxMessageBox( _( "Error Init Printer info" ) );
491 return;
492 }
493
494 if( s_pageSetupData == nullptr )
495 s_pageSetupData = new wxPageSetupDialogData( *s_PrintData );
496
497 s_pageSetupData->SetPaperId( pageInfo.GetPaperId() );
498 s_pageSetupData->GetPrintData().SetOrientation( pageInfo.GetWxOrientation() );
499
500 if( pageInfo.IsCustom() )
501 {
502 if( pageInfo.IsPortrait() )
503 s_pageSetupData->SetPaperSize( wxSize( EDA_UNIT_UTILS::Mils2mm( pageInfo.GetWidthMils() ),
504 EDA_UNIT_UTILS::Mils2mm( pageInfo.GetHeightMils() ) ) );
505 else
506 s_pageSetupData->SetPaperSize( wxSize( EDA_UNIT_UTILS::Mils2mm( pageInfo.GetHeightMils() ),
507 EDA_UNIT_UTILS::Mils2mm( pageInfo.GetWidthMils() ) ) );
508 }
509
510 *s_PrintData = s_pageSetupData->GetPrintData();
511
512 if( doPreview )
513 InvokeDialogPrintPreview( this, s_PrintData );
514 else
515 InvokeDialogPrint( this, s_PrintData, s_pageSetupData );
516}
517
518
519const BOX2I PL_EDITOR_FRAME::GetDocumentExtents( bool aIncludeAllVisible ) const
520{
521 BOX2I rv( VECTOR2I( 0, 0 ), GetPageLayout().GetPageSettings().GetSizeIU( drawSheetIUScale.IU_PER_MILS ) );
522 return rv;
523}
524
525
527{
529
530 PL_EDITOR_SETTINGS* cfg = dynamic_cast<PL_EDITOR_SETTINGS*>( aCfg );
531 wxCHECK( cfg, /*void*/ );
532
535
537
540
541 PAGE_INFO pageInfo = GetPageSettings();
542 pageInfo.SetType( cfg->m_LastPaperSize, cfg->m_LastWasPortrait );
543 SetPageSettings( pageInfo );
544}
545
546
548{
550
551 auto cfg = static_cast<PL_EDITOR_SETTINGS*>( aCfg );
552
554
555 cfg->m_PropertiesFrameWidth = m_propertiesFrameWidth;
556 cfg->m_CornerOrigin = m_originSelectChoice;
557 cfg->m_BlackBackground = GetDrawBgColor() == BLACK;
558 cfg->m_LastPaperSize = GetPageSettings().GetTypeAsString();
559 cfg->m_LastWasPortrait = GetPageSettings().IsPortrait();
560 cfg->m_LastCustomWidth = PAGE_INFO::GetCustomWidthMils();
561 cfg->m_LastCustomHeight = PAGE_INFO::GetCustomHeightMils();
562}
563
564
566{
567 wxString title;
568 wxFileName file( GetCurrentFileName() );
569
570 if( IsContentModified() )
571 title = wxT( "*" );
572
573 if( file.IsOk() )
574 title += file.GetName();
575 else
576 title += _( "[no drawing sheet loaded]" );
577
578 title += wxT( " \u2014 " ) + _( "Drawing Sheet Editor" ),
579
580 SetTitle( title );
581}
582
583
588
589
590void PL_EDITOR_FRAME::SetCurrentFileName( const wxString& aName )
591{
593}
594
595
596void PL_EDITOR_FRAME::SetPageSettings( const PAGE_INFO& aPageSettings )
597{
598 m_pageLayout.SetPageSettings( aPageSettings );
599
600 if( GetScreen() )
601 GetScreen()->InitDataPoints( aPageSettings.GetSizeIU( drawSheetIUScale.IU_PER_MILS ) );
602}
603
604
606{
607 return m_pageLayout.GetPageSettings();
608}
609
610
612{
613 // this function is only needed because EDA_DRAW_FRAME is not compiled
614 // with either -DPCBNEW or -DEESCHEMA, so the virtual is used to route
615 // into an application specific source file.
616 return m_pageLayout.GetPageSettings().GetSizeIU( drawSheetIUScale.IU_PER_MILS );
617}
618
619
624
625
627{
628 m_pageLayout.SetTitleBlock( aTitleBlock );
629}
630
631
633{
635
638
639 // Update gal display options like cursor shape, grid options:
641
642 GetCanvas()->GetView()->GetPainter()->GetSettings()->LoadColors( colors );
643
646
648 Layout();
649 SendSizeEvent();
650}
651
652
654{
655 // calculate the position (in page, in iu) of the corner used as coordinate origin
656 // coordinate origin can be the paper Top Left corner, or each of 4 page corners
657 VECTOR2I originCoord;
658
659 // To avoid duplicate code, we use a dummy segment starting at 0,0 in relative coord
661
662 switch( m_originSelectChoice )
663 {
664 default:
665 case 0: // Origin = paper Left Top corner
666 break;
667
668 case 1: // Origin = page Right Bottom corner
669 dummy.SetStart( 0, 0, RB_CORNER );
670 originCoord = dummy.GetStartPosIU();
671 break;
672
673 case 2: // Origin = page Left Bottom corner
674 dummy.SetStart( 0, 0, LB_CORNER );
675 originCoord = dummy.GetStartPosIU();
676 break;
677
678 case 3: // Origin = page Right Top corner
679 dummy.SetStart( 0, 0, RT_CORNER );
680 originCoord = dummy.GetStartPosIU();
681 break;
682
683 case 4: // Origin = page Left Top corner
684 dummy.SetStart( 0, 0, LT_CORNER );
685 originCoord = dummy.GetStartPosIU();
686 break;
687 }
688
689 return originCoord;
690}
691
692
694{
695 wxString line;
696 wxString gridformatter;
697
698 switch( GetUserUnits() )
699 {
700 case EDA_UNITS::INCH: gridformatter = wxS( "grid %.3f" ); break;
701 case EDA_UNITS::MM: gridformatter = wxS( "grid %.4f" ); break;
702 default: gridformatter = wxS( "grid %f" ); break;
703 }
704
706 GetCanvas()->GetGAL()->GetGridSize().x );
707 line.Printf( gridformatter, grid );
708
709 SetStatusText( line, 4 );
710}
711
712
714{
715 // Display Zoom level:
716 SetStatusText( GetZoomLevelIndicator(), 1 );
717
718 // coordinate origin can be the paper Top Left corner, or each of 4 page corners
719 VECTOR2I originCoord = ReturnCoordOriginCorner();
720 SetGridOrigin( originCoord );
721
722 // We need the orientation of axis (sign of coordinates)
723 int Xsign = 1;
724 int Ysign = 1;
725
726 switch( m_originSelectChoice )
727 {
728 default:
729 case 0: // Origin = paper Left Top corner
730 break;
731
732 case 1: // Origin = page Right Bottom corner
733 Xsign = -1;
734 Ysign = -1;
735 break;
736
737 case 2: // Origin = page Left Bottom corner
738 Ysign = -1;
739 break;
740
741 case 3: // Origin = page Right Top corner
742 Xsign = -1;
743 break;
744
745 case 4: // Origin = page Left Top corner
746 break;
747 }
748
749 // Display absolute coordinates:
751 VECTOR2D coord = cursorPos - originCoord;
752 double dXpos = EDA_UNIT_UTILS::UI::ToUserUnit( drawSheetIUScale, GetUserUnits(), coord.x * Xsign );
753 double dYpos = EDA_UNIT_UTILS::UI::ToUserUnit( drawSheetIUScale, GetUserUnits(), coord.y * Ysign );
754
755 wxString absformatter = wxT( "X %.4g Y %.4g" );
756 wxString locformatter = wxT( "dx %.4g dy %.4g" );
757
758 switch( GetUserUnits() )
759 {
760 case EDA_UNITS::INCH: SetStatusText( _( "inches" ), 6 ); break;
761 case EDA_UNITS::MILS: SetStatusText( _( "mils" ), 6 ); break;
762 case EDA_UNITS::MM: SetStatusText( _( "mm" ), 6 ); break;
763 case EDA_UNITS::UNSCALED: SetStatusText( wxEmptyString, 6 ); break;
764 default: wxASSERT( false ); break;
765 }
766
767 wxString line;
768
769 // Display abs coordinates
770 line.Printf( absformatter, dXpos, dYpos );
771 SetStatusText( line, 2 );
772
773 // Display relative coordinates:
774 if( GetScreen() )
775 {
776 double dx = cursorPos.x - GetScreen()->m_LocalOrigin.x;
777 double dy = cursorPos.y - GetScreen()->m_LocalOrigin.y;
780 line.Printf( locformatter, dXpos, dYpos );
781 SetStatusText( line, 3 );
782 }
783
785
786 // Display corner reference for coord origin
787 line.Printf( _("coord origin: %s"),
788 m_originSelectBox->GetString( m_originSelectChoice ).GetData() );
789 SetStatusText( line, 5 );
790}
791
792
797
798
800{
801 return m_toolManager->GetTool<PL_SELECTION_TOOL>()->GetSelection();
802}
803
804
806{
808
810 PL_SELECTION& selection = selTool->GetSelection();
811 DS_DATA_ITEM* item = nullptr;
812
813 if( selection.GetSize() == 1 )
814 item = static_cast<DS_DRAW_ITEM_BASE*>( selection.Front() )->GetPeer();
815
816 m_propertiesPagelayout->CopyPrmsFromItemToPanel( item );
817 m_propertiesPagelayout->CopyPrmsFromGeneralToPanel();
819 GetCanvas()->Refresh();
820}
821
822
824{
825 DS_DATA_ITEM * item = nullptr;
826
827 switch( aType )
828 {
830 item = new DS_DATA_ITEM_TEXT( wxT( "Text") );
831 break;
832
835 break;
836
839 break;
840
842 item = new DS_DATA_ITEM_POLYGONS();
843 break;
844
846 {
847 wxFileDialog fileDlg( this, _( "Choose Image" ), m_mruImagePath, wxEmptyString,
848 FILEEXT::ImageFileWildcard(), wxFD_OPEN );
849
851
852 if( fileDlg.ShowModal() != wxID_OK )
853 return nullptr;
854
855 wxString fullFilename = fileDlg.GetPath();
856 m_mruImagePath = wxPathOnly( fullFilename );
857
858 if( !wxFileExists( fullFilename ) )
859 {
860 wxMessageBox( _( "Could not load image from '%s'." ), fullFilename );
861 break;
862 }
863
865
866 if( !image->ReadImageFile( fullFilename ) )
867 {
868 wxMessageBox( _( "Could not load image from '%s'." ), fullFilename );
869 delete image;
870 break;
871 }
872
873 // Set the scale factor for pl_editor (it is set for Eeschema by default)
874 image->SetPixelSizeIu( drawSheetIUScale.IU_PER_MILS * 1000.0 / image->GetPPI() );
875 item = new DS_DATA_ITEM_BITMAP( image );
876 break;
877 }
878 }
879
880 if( item == nullptr )
881 return nullptr;
882
884 item->SyncDrawItems( nullptr, GetCanvas()->GetView() );
885
886 return item;
887}
888
889
891{
893 GetScreen()->SetContentModified( false );
895
896 m_propertiesPagelayout->CopyPrmsFromItemToPanel( nullptr );
897 m_propertiesPagelayout->CopyPrmsFromGeneralToPanel();
898
900
902
903 if( GetCurrentFileName().IsEmpty() )
904 {
905 // Default shutdown reason until a file is loaded
906 KIPLATFORM::APP::SetShutdownBlockReason( this, _( "New drawing sheet file is unsaved" ) );
907 }
908 else
909 {
910 KIPLATFORM::APP::SetShutdownBlockReason( this, _( "Drawing sheet changes are unsaved" ) );
911 }
912}
913
914
916{
917 if( aItemCount == 0 )
918 return;
919
920 UNDO_REDO_CONTAINER& list = ( whichList == UNDO_LIST ) ? m_undoList : m_redoList;
921
922 if( aItemCount < 0 )
923 {
924 list.ClearCommandList();
925 }
926 else
927 {
928 for( int ii = 0; ii < aItemCount; ii++ )
929 {
930 if( list.m_CommandsList.size() == 0 )
931 break;
932
933 PICKED_ITEMS_LIST* curr_cmd = list.m_CommandsList[0];
934 list.m_CommandsList.erase( list.m_CommandsList.begin() );
935
936 curr_cmd->ClearListAndDeleteItems( []( EDA_ITEM* aItem )
937 {
938 delete aItem;
939 } );
940 delete curr_cmd; // Delete command
941 }
942 }
943}
944
945
947{
948 return m_pageSelectBox->GetSelection() == 0;
949}
950
951#if 1
953{
954 VECTOR2D size = GetPageSettings().GetSizeIU( drawSheetIUScale.IU_PER_MILS );
955
956 std::vector<MSG_PANEL_ITEM> msgItems;
957 msgItems.emplace_back( _( "Page Width" ), MessageTextFromValue( size.x ) );
958 msgItems.emplace_back( _( "Page Height" ), MessageTextFromValue( size.y ) );
959
960 SetMsgPanel( msgItems );
961}
962#endif
963
964void PL_EDITOR_FRAME::handleActivateEvent( wxActivateEvent& aEvent )
965{
967
968 if( m_spaceMouse )
969 m_spaceMouse->SetFocus( aEvent.GetActive() );
970}
971
972
973void PL_EDITOR_FRAME::handleIconizeEvent( wxIconizeEvent& aEvent )
974{
976
977 if( m_spaceMouse )
978 m_spaceMouse->SetFocus( false );
979}
constexpr std::size_t arrayDim(T const (&)[N]) noexcept
Returns # of elements in an array.
Definition arraydim.h:31
constexpr EDA_IU_SCALE drawSheetIUScale
Definition base_units.h:126
constexpr EDA_IU_SCALE pcbIUScale
Definition base_units.h:125
KIFACE_BASE & Kiface()
Global KIFACE_BASE "get" accessor.
wxBitmap KiBitmap(BITMAPS aBitmap, int aHeightTag)
Construct a wxBitmap from an image identifier Returns the image from the active theme if the image ha...
Definition bitmap.cpp:104
@ icon_pagelayout_editor
@ icon_pagelayout_editor_16
@ icon_pagelayout_editor_32
BOX2< VECTOR2I > BOX2I
Definition box2.h:922
static TOOL_ACTION toggleGrid
Definition actions.h:198
static TOOL_ACTION paste
Definition actions.h:80
static TOOL_ACTION copy
Definition actions.h:78
static TOOL_ACTION undo
Definition actions.h:75
static TOOL_ACTION doDelete
Definition actions.h:85
static TOOL_ACTION selectionTool
Definition actions.h:251
static TOOL_ACTION save
Definition actions.h:58
static TOOL_ACTION zoomFitScreen
Definition actions.h:142
static TOOL_ACTION redo
Definition actions.h:76
static TOOL_ACTION deleteTool
Definition actions.h:86
static TOOL_ACTION zoomTool
Definition actions.h:146
static TOOL_ACTION cut
Definition actions.h:77
Manage TOOL_ACTION objects.
void SetConditions(const TOOL_ACTION &aAction, const ACTION_CONDITIONS &aConditions)
Set the conditions the UI elements for activating a specific tool action should use for determining t...
APP_SETTINGS_BASE is a settings class that should be derived for each standalone KiCad application.
WINDOW_SETTINGS m_Window
wxString m_ColorTheme
Active color theme name.
Handles how to draw a screen (a board, a schematic ...)
Definition base_screen.h:41
bool IsContentModified() const
Definition base_screen.h:60
static wxString m_DrawingSheetFileName
the name of the drawing sheet file, or empty to use the default drawing sheet
Definition base_screen.h:85
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)
This class handle bitmap images in KiCad.
Definition bitmap_base.h:49
Color settings are a bit different than most of the settings objects in that there can be more than o...
Handle actions that are shared between different applications.
Handles action that are shared between different applications.
Drawing sheet structure type definitions.
virtual void SyncDrawItems(DS_DRAW_ITEM_LIST *aCollector, KIGFX::VIEW *aView)
bool LoadDrawingSheet(const wxString &aFullFileName, wxString *aMsg, bool aAppend=false)
Populate the list with a custom layout or the default layout if no custom layout is available.
static DS_DATA_MODEL & GetTheInstance()
Return the instance of DS_DATA_MODEL used in the application.
void Append(DS_DATA_ITEM *aItem)
void AllowVoidList(bool Allow)
In KiCad applications, a drawing sheet is needed So if the list is empty, a default drawing sheet is ...
void ClearList()
Erase the list of items.
Base class to handle basic graphic items.
DS_DATA_ITEM * GetPeer() 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.
UNDO_REDO_CONTAINER m_undoList
virtual void ClearUndoRedoList()
Clear the undo and redo list using ClearUndoORRedoList()
UNDO_REDO_LIST
Specify whether we are interacting with the undo or redo stacks.
virtual void OnModify()
Must be called after a model change in order to set the "modify" flag and do other frame-specific pro...
ACTION_TOOLBAR * m_tbRight
TOOLBAR_SETTINGS * m_toolbarSettings
wxAuiManager m_auimgr
virtual void RecreateToolbars()
UNDO_REDO_CONTAINER m_redoList
ACTION_TOOLBAR * m_tbLeft
virtual void OnDropFiles(wxDropFilesEvent &aEvent)
Handle event fired when a file is dropped to the window.
std::map< const wxString, TOOL_ACTION * > m_acceptedExts
Associate file extensions with action to execute.
ACTION_TOOLBAR * m_tbTopMain
wxString m_aboutTitle
bool m_isClosing
Set by the close window event handler after frames are asked if they can close.
void ReCreateMenuBar()
Recreate the menu bar.
The base class for create windows for drawing purpose.
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.
virtual BASE_SCREEN * GetScreen() const
Return a pointer to a BASE_SCREEN or one of its derivatives.
void setupUnits(APP_SETTINGS_BASE *aCfg)
void SetMsgPanel(const std::vector< MSG_PANEL_ITEM > &aList)
Clear the message panel and populates it with the contents of aList.
void LoadSettings(APP_SETTINGS_BASE *aCfg) override
Load common frame parameters from a configuration file.
virtual void SwitchCanvas(EDA_DRAW_PANEL_GAL::GAL_TYPE aCanvasType)
Change the current rendering backend.
const wxString GetZoomLevelIndicator() const
Return a human readable value for display in dialogs.
GAL_DISPLAY_OPTIONS_IMPL & GetGalDisplayOptions()
Return a reference to the gal rendering options used by GAL for rendering.
virtual void resolveCanvasType()
Determine the canvas type to load (with prompt if required) and initializes m_canvasType.
EDA_MSG_PANEL * m_messagePanel
void SetCanvas(EDA_DRAW_PANEL_GAL *aPanel)
virtual void SetScreen(BASE_SCREEN *aScreen)
EDA_DRAW_FRAME(KIWAY *aKiway, wxWindow *aParent, FRAME_T aFrameType, const wxString &aTitle, const wxPoint &aPos, const wxSize &aSize, long aStyle, const wxString &aFrameName, const EDA_IU_SCALE &aIuScale)
virtual void handleActivateEvent(wxActivateEvent &aEvent)
Handle a window activation event.
virtual void SetDrawBgColor(const COLOR4D &aColor)
virtual COLOR_SETTINGS * GetColorSettings(bool aForceRefresh=false) const
Returns a pointer to the active color theme settings.
virtual EDA_DRAW_PANEL_GAL * GetCanvas() const
Return a pointer to GAL-based canvas of given EDA draw frame.
virtual COLOR4D GetDrawBgColor() const
void setupUIConditions() override
Setup the UI conditions for the various actions and their controls in this frame.
void CommonSettingsChanged(int aFlags) override
Notification event that some of the common (suite-wide) settings have changed.
bool m_showBorderAndTitleBlock
GAL_TYPE GetBackend() const
Return the type of backend currently used by GAL canvas.
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.
void ForceRefresh()
Force a redraw.
virtual void Refresh(bool aEraseBackground=true, const wxRect *aRect=nullptr) override
@ GAL_TYPE_NONE
GAL not used (the legacy wxDC engine is used)
void SetEventDispatcher(TOOL_DISPATCHER *aEventDispatcher)
Set a dispatcher that processes events and forwards them to tools.
A base class for most all the KiCad significant classes used in schematics and boards.
Definition eda_item.h:100
Specialization of the wxAuiPaneInfo class for KiCad panels.
Class that groups generic conditions for editor states.
SELECTION_CONDITION NoActiveTool()
Create a functor testing if there are no tools active in the frame.
SELECTION_CONDITION RedoAvailable()
Create a functor that tests if there are any items in the redo queue.
SELECTION_CONDITION CurrentTool(const TOOL_ACTION &aTool)
Create a functor testing if the specified tool is the current active tool in the frame.
virtual SELECTION_CONDITION UndoAvailable()
Create a functor that tests if there are any items in the undo queue.
SELECTION_CONDITION GridVisible()
Create a functor testing if the grid is visible in a frame.
void ReadWindowSettings(WINDOW_SETTINGS &aCfg)
Read GAL config options from application-level config.
virtual RENDER_SETTINGS * GetSettings()=0
Return a pointer to current settings that are going to be used when drawing items.
virtual void LoadColors(const COLOR_SETTINGS *aSettings)
VECTOR2D GetCursorPosition() const
Return the current cursor position in world coordinates.
Hold a (potentially large) number of VIEW_ITEMs and renders them on a graphics device provided by the...
Definition view.h:67
void SetLayerVisible(int aLayer, bool aVisible=true)
Control the visibility of a particular layer.
Definition view.h:409
void UpdateAllItems(int aUpdateFlags)
Update all items in the view according to the given flags.
Definition view.cpp:1685
PAINTER * GetPainter() const
Return the painter object used by the view for drawing #VIEW_ITEMS.
Definition view.h:229
bool Destroy() override
Our version of Destroy() which is virtual from wxWidgets.
A minimalistic software bus for communications between various DLLs/DSOs (DSOs) within the same KiCad...
Definition kiway.h:315
void OnKiCadExit()
Definition kiway.cpp:800
Describe the page size and margins of a paper page on which to eventually print or plot.
Definition page_info.h:79
wxString GetTypeAsString() const
bool SetType(PAGE_SIZE_TYPE aPageSize, bool aIsPortrait=false)
Set the name of the page type and also the sizes and margins commonly associated with that type name.
static void SetCustomWidthMils(double aWidthInMils)
Set the width of Custom page in mils for any custom page constructed or made via SetType() after maki...
wxPrintOrientation GetWxOrientation() const
Definition page_info.h:133
static double GetCustomHeightMils()
Definition page_info.h:202
const VECTOR2D GetSizeIU(double aIUScale) const
Gets the page size in internal units.
Definition page_info.h:177
double GetHeightMils() const
Definition page_info.h:147
wxPaperSize GetPaperId() const
Definition page_info.h:138
double GetWidthMils() const
Definition page_info.h:142
bool IsCustom() const
bool IsPortrait() const
Definition page_info.h:128
static double GetCustomWidthMils()
Definition page_info.h:197
static void SetCustomHeightMils(double aHeightInMils)
Set the height of Custom page in mils for any custom page constructed or made via SetType() after mak...
A holder to handle information on schematic or board items.
void ClearListAndDeleteItems(std::function< void(EDA_ITEM *)> aItemDeleter)
Delete the list of pickers AND the data pointed by #m_PickedItem or #m_PickedItemLink according to th...
Gather all the actions that are shared by tools.
Definition pl_actions.h:36
static TOOL_ACTION placeImage
Definition pl_actions.h:41
static TOOL_ACTION drawRectangle
Definition pl_actions.h:42
static TOOL_ACTION layoutNormalMode
Definition pl_actions.h:49
static TOOL_ACTION placeText
Definition pl_actions.h:40
static TOOL_ACTION layoutEditMode
Definition pl_actions.h:50
static TOOL_ACTION appendImportedDrawingSheet
Definition pl_actions.h:44
static TOOL_ACTION drawLine
Definition pl_actions.h:43
Tool responsible for drawing/placing items (lines, rectangles, text, etc.)
void DisplayDrawingSheet()
Build and update the list of WS_DRAW_ITEM_xxx showing the frame layout.
Handle actions specific to the drawing sheet editor.
The main window used in the drawing sheet editor.
bool OpenProjectFiles(const std::vector< wxString > &aFileSet, int aCtl) override
Open a project or set of files given by aFileList.
void OnNewDrawingSheet()
Must be called to initialize parameters when a new drawing sheet is loaded.
std::unique_ptr< NL_PL_EDITOR_PLUGIN > m_spaceMouse
void OnModify() override
Must be called after a change in order to set the "modify" flag.
void SetCurrentFileName(const wxString &aName)
Store the current layout description file filename.
bool IsContentModified() const override
Get if the drawing sheet has been modified but not saved.
void Files_io(wxCommandEvent &event)
void configureToolbars() override
void ToPrinter(bool doPreview)
Open a dialog frame to print layers.
PL_EDITOR_FRAME(KIWAY *aKiway, wxWindow *aParent)
void UpdateMsgPanelInfo()
Display the size of the sheet to the message panel.
const BOX2I GetDocumentExtents(bool aIncludeAllVisible=true) const override
Return bounding box of document with option to not include some items.
void doCloseWindow() override
VECTOR2I ReturnCoordOriginCorner() const
Calculate the position (in page, in iu) of the corner used as coordinate origin of items.
void OnClearFileHistory(wxCommandEvent &aEvent)
void SetPageSettings(const PAGE_INFO &) override
DS_DATA_ITEM * AddDrawingSheetItem(int aType)
Add a new item to the drawing sheet item list.
wxString GetCurrentFileName() const override
bool canCloseWindow(wxCloseEvent &aCloseEvent) override
void OnFileHistory(wxCommandEvent &event)
void UpdateStatusBar() override
Update the status bar information.
void SetGridOrigin(const VECTOR2I &aPoint) override
void OnSelectPage(wxCommandEvent &event)
const TITLE_BLOCK & GetTitleBlock() const override
void UpdateTitleAndInfo()
Display the short filename (if exists) loaded file on the caption of the main window.
const VECTOR2I GetPageSizeIU() const override
Works off of GetPageSettings() to return the size of the paper page in the internal units of this par...
void OnSelectCoordOriginCorner(wxCommandEvent &event)
Called when the user select one of the 4 page corner as corner reference (or the left top paper corne...
void handleActivateEvent(wxActivateEvent &aEvent) override
Handle a window activation event.
void LoadSettings(APP_SETTINGS_BASE *aCfg) override
Load common frame parameters from a configuration file.
SELECTION & GetCurrentSelection() override
Get the current selection from the canvas area.
PL_EDITOR_LAYOUT m_pageLayout
bool GetPageNumberOption() const
Drawing sheet editor can show the title block using a page number 1 or another number.
void UpdateToolbarControlSizes() override
Update the sizes of any controls in the toolbars of the frame.
void CommonSettingsChanged(int aFlags) override
Notification event that some of the common (suite-wide) settings have changed.
void handleIconizeEvent(wxIconizeEvent &aEvent) override
Handle a window iconize event.
void HardRedraw() override
Refresh the library tree and redraw the window.
void DisplayGridMsg() override
Display current grid size in the status bar.
void SaveSettings(APP_SETTINGS_BASE *aCfg) override
Save common frame parameters to a configuration data file.
wxChoice * m_originSelectBox
const PAGE_INFO & GetPageSettings() const override
const PL_EDITOR_LAYOUT & GetPageLayout() const
void setupUIConditions() override
Setup the UI conditions for the various actions and their controls in this frame.
PROPERTIES_FRAME * m_propertiesPagelayout
The last filename chosen to be proposed to the user.
wxChoice * m_pageSelectBox
PL_DRAW_PANEL_GAL * GetCanvas() const override
Return a pointer to GAL-based canvas of given EDA draw frame.
void ClearUndoORRedoList(UNDO_REDO_LIST whichList, int aItemCount=-1) override
Remove the aItemCount of old commands from aList and delete commands, pickers and picked items if nee...
void SetTitleBlock(const TITLE_BLOCK &aTitleBlock) override
void OnExit(wxCommandEvent &aEvent)
Event handler for the wxID_EXIT and wxID_CLOSE events.
bool LoadDrawingSheetFile(const wxString &aFullFileName)
Load a .kicad_wks drawing sheet file.
TITLE_BLOCK & GetTitleBlock()
Tool that displays edit points allowing to modify items by dragging the points.
PL_SELECTION & GetSelection()
Return the set of currently selected items.
PROPERTIES_FRAME display properties of the current item.
static bool NotEmpty(const SELECTION &aSelection)
Test if there are any items selected.
static bool Idle(const SELECTION &aSelection)
Test if there no items selected or being edited.
static bool ShowAlways(const SELECTION &aSelection)
The default condition function (always returns true).
static bool ShowNever(const SELECTION &aSelection)
Always returns false.
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
TOOL_DISPATCHER * m_toolDispatcher
ACTIONS * m_actions
Master controller class:
A holder to handle a list of undo (or redo) commands.
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
void SetUserUnits(EDA_UNITS aUnits)
@ WHITE
Definition color4d.h:48
@ BLACK
Definition color4d.h:44
bool HandleUnsavedChanges(wxWindow *aParent, const wxString &aMessage, const std::function< bool()> &aSaveFunction)
Display a dialog with Save, Cancel and Discard Changes buttons.
Definition confirm.cpp:150
This file is part of the common library.
#define CHECK(x)
#define ENABLE(x)
int InvokeDialogPrintPreview(PL_EDITOR_FRAME *aCaller, wxPrintData *aPrintData)
Create and show a print preview dialog returns 1 if OK, 0 , there is a problem.
int InvokeDialogPrint(PL_EDITOR_FRAME *aCaller, wxPrintData *aPrintData, wxPageSetupDialogData *aPageSetupData)
Create and show a print dialog returns 1 if OK, 0 , there is a problem.
@ RB_CORNER
@ RT_CORNER
@ LT_CORNER
@ LB_CORNER
#define _(s)
#define KICAD_DEFAULT_DRAWFRAME_STYLE
#define PL_EDITOR_FRAME_NAME
EVT_MENU_RANGE(ID_GERBVIEW_DRILL_FILE1, ID_GERBVIEW_DRILL_FILEMAX, GERBVIEW_FRAME::OnDrlFileHistory) EVT_MENU_RANGE(ID_GERBVIEW_ZIP_FILE1
@ FRAME_PL_EDITOR
Definition frame_type.h:59
static const std::string DrawingSheetFileExtension
static wxString ImageFileWildcard()
@ ID_FILE_LIST_CLEAR
Definition id.h:62
@ ID_FILEMAX
Definition id.h:60
@ ID_FILE1
Definition id.h:59
@ LAYER_DRAWINGSHEET_PAGEn
Sheet Editor previewing pages after first page.
Definition layer_ids.h:327
@ LAYER_DRAWINGSHEET_PAGE1
Sheet Editor previewing first page.
Definition layer_ids.h:326
KICOMMON_API double ToUserUnit(const EDA_IU_SCALE &aIuScale, EDA_UNITS aUnit, double aValue)
Convert aValue in internal units to the appropriate user units defined by aUnit.
KICOMMON_API int Mils2mm(double aVal)
Convert mils to mm.
Definition eda_units.cpp:82
@ COLOR
Color has changed.
Definition view_item.h:54
void SetShutdownBlockReason(wxWindow *aWindow, const wxString &aReason)
Sets the block reason why the window/application is preventing OS shutdown.
Definition unix/app.cpp:102
bool SupportsShutdownBlockReason()
Whether or not the window supports setting a shutdown block reason.
Definition unix/app.cpp:91
void AllowNetworkFileSystems(wxDialog *aDialog)
Configure a file dialog to show network and virtual file systems.
Definition wxgtk/ui.cpp:435
KICOMMON_API wxSize GetTextSize(const wxString &aSingleLine, wxWindow *aWindow)
Return the size of aSingleLine of text when it is rendered in aWindow using whatever font is currentl...
Definition ui_common.cpp:78
#define _HKI(x)
Definition page_info.cpp:44
see class PGM_BASE
@ ID_SELECT_PAGE_NUMBER
@ ID_SELECT_COORDINATE_ORIGIN
#define DEFAULT_THEME
T * GetToolbarSettings(const wxString &aFilename)
T * GetAppSettings(const char *aFilename)
KIWAY Kiway(KFCTL_STANDALONE)
std::vector< FAB_LAYER_COLOR > dummy
VECTOR2< int32_t > VECTOR2I
Definition vector2d.h:687
VECTOR2< double > VECTOR2D
Definition vector2d.h:686
Definition of file extensions used in Kicad.