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#ifndef __linux__
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 wxWindow* 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 SetStatusWidths( arrayDim( dims ), dims );
181
182 m_auimgr.SetManagedWindow( this );
183
186
187 // Rows; layers 4 - 6
188 m_auimgr.AddPane( m_tbTopMain, EDA_PANE().HToolbar().Name( "TopMainToolbar" )
189 .Top().Layer( 6 ) );
190 m_auimgr.AddPane( m_tbLeft, EDA_PANE().VToolbar().Name( "LeftToolbar" )
191 .Left().Layer( 3 ) );
192 m_auimgr.AddPane( m_messagePanel, EDA_PANE().Messages().Name( "MsgPanel" )
193 .Bottom().Layer( 6 ) );
194
195 // Columns; layers 1 - 3
196 m_auimgr.AddPane( m_tbRight, EDA_PANE().VToolbar().Name( "RightToolbar" )
197 .Right().Layer( 2 ) );
198
199 m_auimgr.AddPane( m_propertiesPagelayout, EDA_PANE().Palette().Name( "Props" )
200 .Right().Layer( 3 )
201 .Caption( _( "Properties" ) )
202 .MinSize( m_propertiesPagelayout->GetMinSize() )
203 .BestSize( m_propertiesFrameWidth, -1 ) );
204
205 // Center
206 m_auimgr.AddPane( GetCanvas(), EDA_PANE().Canvas().Name( "DrawFrame" )
207 .Center() );
208
210
213
214 // Add the exit key handler
215 setupUnits( config() );
216
217 VECTOR2I originCoord = ReturnCoordOriginCorner();
218 SetGridOrigin( originCoord );
219
220 // Initialize the current drawing sheet
221#if 0 //start with empty layout
224#else // start with the default KiCad layout
225 DS_DATA_MODEL::GetTheInstance().LoadDrawingSheet( wxEmptyString, nullptr );
226#endif
228
229 // Ensure the window is on top
230 Raise();
231
232 // Register a call to update the toolbar sizes. It can't be done immediately because
233 // it seems to require some sizes calculated that aren't yet (at least on GTK).
234 CallAfter( [this]()
235 {
236 // Ensure the controls on the toolbars all are correctly sized
238 } );
239
240 try
241 {
242 if( !m_spaceMouse )
243 {
244#ifndef __linux__
245 m_spaceMouse = std::make_unique<NL_PL_EDITOR_PLUGIN>();
246#else
247 m_spaceMouse = std::make_unique<SPNAV_2D_PLUGIN>( GetCanvas() );
248 m_spaceMouse->SetScale( drawSheetIUScale.IU_PER_MILS / pcbIUScale.IU_PER_MILS );
249#endif
250 }
251
252 m_spaceMouse->SetCanvas( GetCanvas() );
253 }
254 catch( const std::system_error& e )
255 {
256 wxLogTrace( wxT( "KI_TRACE_NAVLIB" ), e.what() );
257 }
258}
259
260
262{
263 // Ensure m_canvasType is up to date, to save it in config
265
266 // Shutdown all running tools
267 if( m_toolManager )
268 m_toolManager->ShutdownAllTools();
269}
270
271
273{
274 // Create the manager and dispatcher & route draw panel events to the dispatcher
276 m_toolManager->SetEnvironment( nullptr, GetCanvas()->GetView(),
277 GetCanvas()->GetViewControls(), config(), this );
278 m_actions = new PL_ACTIONS();
280
282
283 // Register tools
284 m_toolManager->RegisterTool( new COMMON_CONTROL );
285 m_toolManager->RegisterTool( new COMMON_TOOLS );
286 m_toolManager->RegisterTool( new ZOOM_TOOL );
287 m_toolManager->RegisterTool( new PL_SELECTION_TOOL );
288 m_toolManager->RegisterTool( new PL_EDITOR_CONTROL );
289 m_toolManager->RegisterTool( new PL_DRAWING_TOOLS );
290 m_toolManager->RegisterTool( new PL_EDIT_TOOL );
291 m_toolManager->RegisterTool( new PL_POINT_EDITOR );
292 m_toolManager->RegisterTool( new PICKER_TOOL );
293 m_toolManager->InitTools();
294
295 // Run the selection tool, it is supposed to be always active
296 m_toolManager->InvokeTool( "common.InteractiveSelection" );
297}
298
299
301{
303
304 ACTION_MANAGER* mgr = m_toolManager->GetActionManager();
305 EDITOR_CONDITIONS cond( this );
306
307 wxASSERT( mgr );
308
309#define ENABLE( x ) ACTION_CONDITIONS().Enable( x )
310#define CHECK( x ) ACTION_CONDITIONS().Check( x )
311
315
317
322
329
338
339 // Not a tool, just a way to activate the action
342
343 auto titleBlockNormalMode =
344 [] ( const SELECTION& )
345 {
347 };
348
349 auto titleBlockEditMode =
350 [] ( const SELECTION& )
351 {
353 };
354
355 mgr->SetConditions( PL_ACTIONS::layoutNormalMode, CHECK( titleBlockNormalMode ) );
356 mgr->SetConditions( PL_ACTIONS::layoutEditMode, CHECK( titleBlockEditMode ) );
357
358#undef CHECK
359#undef ENABLE
360}
361
362
363bool PL_EDITOR_FRAME::OpenProjectFiles( const std::vector<wxString>& aFileSet, int aCtl )
364{
365 wxString fn = aFileSet[0];
366
367 if( !LoadDrawingSheetFile( fn ) )
368 {
369 wxMessageBox( wxString::Format( _( "Error loading drawing sheet '%s'." ), fn ) );
370 return false;
371 }
372 else
373 {
375 return true;
376 }
377}
378
379
381{
382 // Must be called after a change in order to set the "modify" flag and update
383 // the frame title.
385
387
388 if( m_isClosing )
389 return;
390
392}
393
394
396{
397 return GetScreen() && GetScreen()->IsContentModified();
398}
399
400
401void PL_EDITOR_FRAME::OnExit( wxCommandEvent& aEvent )
402{
403 if( aEvent.GetId() == wxID_EXIT )
404 Kiway().OnKiCadExit();
405
406 if( aEvent.GetId() == wxID_CLOSE || Kiface().IsSingle() )
407 Close( false );
408}
409
410
411bool PL_EDITOR_FRAME::canCloseWindow( wxCloseEvent& aEvent )
412{
413 // Shutdown blocks must be determined and vetoed as early as possible
415 && aEvent.GetId() == wxEVT_QUERY_END_SESSION
416 && IsContentModified() )
417 {
418 return false;
419 }
420
421 if( IsContentModified() )
422 {
423 wxFileName filename = GetCurrentFileName();
424 wxString msg = _( "Save changes to '%s' before closing?" );
425
426 if( !HandleUnsavedChanges( this, wxString::Format( msg, filename.GetFullName() ),
427 [&]() -> bool
428 {
429 return saveCurrentPageLayout();
430 } ) )
431 {
432 return false;
433 }
434 }
435
436 return true;
437}
438
439
441{
442 // do not show the window because we do not want any paint event
443 Show( false );
444
445 // clean up the data before the view is destroyed
447
448 // On Linux, m_propertiesPagelayout must be destroyed
449 // before deleting the main frame to avoid a crash when closing
450 m_propertiesPagelayout->Destroy();
451 Destroy();
452}
453
454
455void PL_EDITOR_FRAME::OnSelectPage( wxCommandEvent& event )
456{
457 KIGFX::VIEW* view = GetCanvas()->GetView();
458 view->SetLayerVisible( LAYER_DRAWINGSHEET_PAGE1, m_pageSelectBox->GetSelection() == 0 );
459 view->SetLayerVisible( LAYER_DRAWINGSHEET_PAGEn, m_pageSelectBox->GetSelection() == 1 );
460 GetCanvas()->Refresh();
461}
462
463
465{
466 m_originSelectChoice = m_originSelectBox->GetSelection();
467 UpdateStatusBar(); // Update grid origin
469 GetCanvas()->Refresh();
470}
471
472
473void PL_EDITOR_FRAME::ToPrinter( bool doPreview )
474{
475 // static print data and page setup data, to remember settings during the session
476 static wxPrintData* s_PrintData;
477 static wxPageSetupDialogData* s_pageSetupData = nullptr;
478
479 const PAGE_INFO& pageInfo = GetPageSettings();
480
481 if( s_PrintData == nullptr ) // First print
482 {
483 s_PrintData = new wxPrintData();
484 s_PrintData->SetQuality( wxPRINT_QUALITY_HIGH ); // Default resolution = HIGH;
485 }
486
487 if( !s_PrintData->Ok() )
488 {
489 wxMessageBox( _( "Error Init Printer info" ) );
490 return;
491 }
492
493 if( s_pageSetupData == nullptr )
494 s_pageSetupData = new wxPageSetupDialogData( *s_PrintData );
495
496 s_pageSetupData->SetPaperId( pageInfo.GetPaperId() );
497 s_pageSetupData->GetPrintData().SetOrientation( pageInfo.GetWxOrientation() );
498
499 if( pageInfo.IsCustom() )
500 {
501 if( pageInfo.IsPortrait() )
502 s_pageSetupData->SetPaperSize( wxSize( EDA_UNIT_UTILS::Mils2mm( pageInfo.GetWidthMils() ),
503 EDA_UNIT_UTILS::Mils2mm( pageInfo.GetHeightMils() ) ) );
504 else
505 s_pageSetupData->SetPaperSize( wxSize( EDA_UNIT_UTILS::Mils2mm( pageInfo.GetHeightMils() ),
506 EDA_UNIT_UTILS::Mils2mm( pageInfo.GetWidthMils() ) ) );
507 }
508
509 *s_PrintData = s_pageSetupData->GetPrintData();
510
511 if( doPreview )
512 InvokeDialogPrintPreview( this, s_PrintData );
513 else
514 InvokeDialogPrint( this, s_PrintData, s_pageSetupData );
515}
516
517
518const BOX2I PL_EDITOR_FRAME::GetDocumentExtents( bool aIncludeAllVisible ) const
519{
520 BOX2I rv( VECTOR2I( 0, 0 ), GetPageLayout().GetPageSettings().GetSizeIU( drawSheetIUScale.IU_PER_MILS ) );
521 return rv;
522}
523
524
526{
528
529 PL_EDITOR_SETTINGS* cfg = dynamic_cast<PL_EDITOR_SETTINGS*>( aCfg );
530 wxCHECK( cfg, /*void*/ );
531
534
536
539
540 PAGE_INFO pageInfo = GetPageSettings();
541 pageInfo.SetType( cfg->m_LastPaperSize, cfg->m_LastWasPortrait );
542 SetPageSettings( pageInfo );
543}
544
545
547{
549
550 auto cfg = static_cast<PL_EDITOR_SETTINGS*>( aCfg );
551
553
554 cfg->m_PropertiesFrameWidth = m_propertiesFrameWidth;
555 cfg->m_CornerOrigin = m_originSelectChoice;
556 cfg->m_BlackBackground = GetDrawBgColor() == BLACK;
557 cfg->m_LastPaperSize = GetPageSettings().GetTypeAsString();
558 cfg->m_LastWasPortrait = GetPageSettings().IsPortrait();
559 cfg->m_LastCustomWidth = PAGE_INFO::GetCustomWidthMils();
560 cfg->m_LastCustomHeight = PAGE_INFO::GetCustomHeightMils();
561}
562
563
565{
566 wxString title;
567 wxFileName file( GetCurrentFileName() );
568
569 if( IsContentModified() )
570 title = wxT( "*" );
571
572 if( file.IsOk() )
573 title += file.GetName();
574 else
575 title += _( "[no drawing sheet loaded]" );
576
577 title += wxT( " \u2014 " ) + _( "Drawing Sheet Editor" ),
578
579 SetTitle( title );
580}
581
582
587
588
589void PL_EDITOR_FRAME::SetCurrentFileName( const wxString& aName )
590{
592}
593
594
595void PL_EDITOR_FRAME::SetPageSettings( const PAGE_INFO& aPageSettings )
596{
597 m_pageLayout.SetPageSettings( aPageSettings );
598
599 if( GetScreen() )
600 GetScreen()->InitDataPoints( aPageSettings.GetSizeIU( drawSheetIUScale.IU_PER_MILS ) );
601}
602
603
605{
606 return m_pageLayout.GetPageSettings();
607}
608
609
611{
612 // this function is only needed because EDA_DRAW_FRAME is not compiled
613 // with either -DPCBNEW or -DEESCHEMA, so the virtual is used to route
614 // into an application specific source file.
615 return m_pageLayout.GetPageSettings().GetSizeIU( drawSheetIUScale.IU_PER_MILS );
616}
617
618
623
624
626{
627 m_pageLayout.SetTitleBlock( aTitleBlock );
628}
629
630
632{
634
637
638 // Update gal display options like cursor shape, grid options:
640
641 GetCanvas()->GetView()->GetPainter()->GetSettings()->LoadColors( colors );
642
645
647 Layout();
648 SendSizeEvent();
649}
650
651
653{
654 // calculate the position (in page, in iu) of the corner used as coordinate origin
655 // coordinate origin can be the paper Top Left corner, or each of 4 page corners
656 VECTOR2I originCoord;
657
658 // To avoid duplicate code, we use a dummy segment starting at 0,0 in relative coord
660
661 switch( m_originSelectChoice )
662 {
663 default:
664 case 0: // Origin = paper Left Top corner
665 break;
666
667 case 1: // Origin = page Right Bottom corner
668 dummy.SetStart( 0, 0, RB_CORNER );
669 originCoord = dummy.GetStartPosIU();
670 break;
671
672 case 2: // Origin = page Left Bottom corner
673 dummy.SetStart( 0, 0, LB_CORNER );
674 originCoord = dummy.GetStartPosIU();
675 break;
676
677 case 3: // Origin = page Right Top corner
678 dummy.SetStart( 0, 0, RT_CORNER );
679 originCoord = dummy.GetStartPosIU();
680 break;
681
682 case 4: // Origin = page Left Top corner
683 dummy.SetStart( 0, 0, LT_CORNER );
684 originCoord = dummy.GetStartPosIU();
685 break;
686 }
687
688 return originCoord;
689}
690
691
693{
694 wxString line;
695 wxString gridformatter;
696
697 switch( GetUserUnits() )
698 {
699 case EDA_UNITS::INCH: gridformatter = wxS( "grid %.3f" ); break;
700 case EDA_UNITS::MM: gridformatter = wxS( "grid %.4f" ); break;
701 default: gridformatter = wxS( "grid %f" ); break;
702 }
703
705 GetCanvas()->GetGAL()->GetGridSize().x );
706 line.Printf( gridformatter, grid );
707
708 SetStatusText( line, 4 );
709}
710
711
713{
714 // Display Zoom level:
715 SetStatusText( GetZoomLevelIndicator(), 1 );
716
717 // coordinate origin can be the paper Top Left corner, or each of 4 page corners
718 VECTOR2I originCoord = ReturnCoordOriginCorner();
719 SetGridOrigin( originCoord );
720
721 // We need the orientation of axis (sign of coordinates)
722 int Xsign = 1;
723 int Ysign = 1;
724
725 switch( m_originSelectChoice )
726 {
727 default:
728 case 0: // Origin = paper Left Top corner
729 break;
730
731 case 1: // Origin = page Right Bottom corner
732 Xsign = -1;
733 Ysign = -1;
734 break;
735
736 case 2: // Origin = page Left Bottom corner
737 Ysign = -1;
738 break;
739
740 case 3: // Origin = page Right Top corner
741 Xsign = -1;
742 break;
743
744 case 4: // Origin = page Left Top corner
745 break;
746 }
747
748 // Display absolute coordinates:
750 VECTOR2D coord = cursorPos - originCoord;
751 double dXpos = EDA_UNIT_UTILS::UI::ToUserUnit( drawSheetIUScale, GetUserUnits(), coord.x * Xsign );
752 double dYpos = EDA_UNIT_UTILS::UI::ToUserUnit( drawSheetIUScale, GetUserUnits(), coord.y * Ysign );
753
754 wxString absformatter = wxT( "X %.4g Y %.4g" );
755 wxString locformatter = wxT( "dx %.4g dy %.4g" );
756
757 switch( GetUserUnits() )
758 {
759 case EDA_UNITS::INCH: SetStatusText( _( "inches" ), 6 ); break;
760 case EDA_UNITS::MILS: SetStatusText( _( "mils" ), 6 ); break;
761 case EDA_UNITS::MM: SetStatusText( _( "mm" ), 6 ); break;
762 case EDA_UNITS::UNSCALED: SetStatusText( wxEmptyString, 6 ); break;
763 default: wxASSERT( false ); break;
764 }
765
766 wxString line;
767
768 // Display abs coordinates
769 line.Printf( absformatter, dXpos, dYpos );
770 SetStatusText( line, 2 );
771
772 // Display relative coordinates:
773 if( GetScreen() )
774 {
775 double dx = cursorPos.x - GetScreen()->m_LocalOrigin.x;
776 double dy = cursorPos.y - GetScreen()->m_LocalOrigin.y;
779 line.Printf( locformatter, dXpos, dYpos );
780 SetStatusText( line, 3 );
781 }
782
784
785 // Display corner reference for coord origin
786 line.Printf( _("coord origin: %s"),
787 m_originSelectBox->GetString( m_originSelectChoice ).GetData() );
788 SetStatusText( line, 5 );
789}
790
791
796
797
799{
800 return m_toolManager->GetTool<PL_SELECTION_TOOL>()->GetSelection();
801}
802
803
805{
807
809 PL_SELECTION& selection = selTool->GetSelection();
810 DS_DATA_ITEM* item = nullptr;
811
812 if( selection.GetSize() == 1 )
813 item = static_cast<DS_DRAW_ITEM_BASE*>( selection.Front() )->GetPeer();
814
815 m_propertiesPagelayout->CopyPrmsFromItemToPanel( item );
816 m_propertiesPagelayout->CopyPrmsFromGeneralToPanel();
818 GetCanvas()->Refresh();
819}
820
821
823{
824 DS_DATA_ITEM * item = nullptr;
825
826 switch( aType )
827 {
829 item = new DS_DATA_ITEM_TEXT( wxT( "Text") );
830 break;
831
834 break;
835
838 break;
839
841 item = new DS_DATA_ITEM_POLYGONS();
842 break;
843
845 {
846 wxFileDialog fileDlg( this, _( "Choose Image" ), m_mruImagePath, wxEmptyString,
847 FILEEXT::ImageFileWildcard(), wxFD_OPEN );
848
850
851 if( fileDlg.ShowModal() != wxID_OK )
852 return nullptr;
853
854 wxString fullFilename = fileDlg.GetPath();
855 m_mruImagePath = wxPathOnly( fullFilename );
856
857 if( !wxFileExists( fullFilename ) )
858 {
859 wxMessageBox( _( "Could not load image from '%s'." ), fullFilename );
860 break;
861 }
862
864
865 if( !image->ReadImageFile( fullFilename ) )
866 {
867 wxMessageBox( _( "Could not load image from '%s'." ), fullFilename );
868 delete image;
869 break;
870 }
871
872 // Set the scale factor for pl_editor (it is set for Eeschema by default)
873 image->SetPixelSizeIu( drawSheetIUScale.IU_PER_MILS * 1000.0 / image->GetPPI() );
874 item = new DS_DATA_ITEM_BITMAP( image );
875 break;
876 }
877 }
878
879 if( item == nullptr )
880 return nullptr;
881
883 item->SyncDrawItems( nullptr, GetCanvas()->GetView() );
884
885 return item;
886}
887
888
890{
892 GetScreen()->SetContentModified( false );
894
895 m_propertiesPagelayout->CopyPrmsFromItemToPanel( nullptr );
896 m_propertiesPagelayout->CopyPrmsFromGeneralToPanel();
897
899
901
902 if( GetCurrentFileName().IsEmpty() )
903 {
904 // Default shutdown reason until a file is loaded
905 KIPLATFORM::APP::SetShutdownBlockReason( this, _( "New drawing sheet file is unsaved" ) );
906 }
907 else
908 {
909 KIPLATFORM::APP::SetShutdownBlockReason( this, _( "Drawing sheet changes are unsaved" ) );
910 }
911}
912
913
915{
916 if( aItemCount == 0 )
917 return;
918
919 UNDO_REDO_CONTAINER& list = ( whichList == UNDO_LIST ) ? m_undoList : m_redoList;
920
921 if( aItemCount < 0 )
922 {
923 list.ClearCommandList();
924 }
925 else
926 {
927 for( int ii = 0; ii < aItemCount; ii++ )
928 {
929 if( list.m_CommandsList.size() == 0 )
930 break;
931
932 PICKED_ITEMS_LIST* curr_cmd = list.m_CommandsList[0];
933 list.m_CommandsList.erase( list.m_CommandsList.begin() );
934
935 curr_cmd->ClearListAndDeleteItems( []( EDA_ITEM* aItem )
936 {
937 delete aItem;
938 } );
939 delete curr_cmd; // Delete command
940 }
941 }
942}
943
944
946{
947 return m_pageSelectBox->GetSelection() == 0;
948}
949
950#if 1
952{
953 VECTOR2D size = GetPageSettings().GetSizeIU( drawSheetIUScale.IU_PER_MILS );
954
955 std::vector<MSG_PANEL_ITEM> msgItems;
956 msgItems.emplace_back( _( "Page Width" ), MessageTextFromValue( size.x ) );
957 msgItems.emplace_back( _( "Page Height" ), MessageTextFromValue( size.y ) );
958
959 SetMsgPanel( msgItems );
960}
961#endif
962
963void PL_EDITOR_FRAME::handleActivateEvent( wxActivateEvent& aEvent )
964{
966
967 if( m_spaceMouse )
968 m_spaceMouse->SetFocus( aEvent.GetActive() );
969}
970
971
972void PL_EDITOR_FRAME::handleIconizeEvent( wxIconizeEvent& aEvent )
973{
975
976 if( m_spaceMouse )
977 m_spaceMouse->SetFocus( false );
978}
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:113
constexpr EDA_IU_SCALE pcbIUScale
Definition base_units.h:112
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:98
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:66
void SetLayerVisible(int aLayer, bool aVisible=true)
Control the visibility of a particular layer.
Definition view.h:400
void UpdateAllItems(int aUpdateFlags)
Update all items in the view according to the given flags.
Definition view.cpp:1572
PAINTER * GetPainter() const
Return the painter object used by the view for drawing #VIEW_ITEMS.
Definition view.h:220
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:294
void OnKiCadExit()
Definition kiway.cpp:761
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:131
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:90
bool SupportsShutdownBlockReason()
Whether or not the window supports setting a shutdown block reason.
Definition unix/app.cpp:79
void AllowNetworkFileSystems(wxDialog *aDialog)
Configure a file dialog to show network and virtual file systems.
Definition wxgtk/ui.cpp:717
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:695
VECTOR2< double > VECTOR2D
Definition vector2d.h:694
Definition of file extensions used in Kicad.