diff options
author | saurabhb17 | 2020-02-26 16:11:59 +0530 |
---|---|---|
committer | GitHub | 2020-02-26 16:11:59 +0530 |
commit | e255d0622297488c1c52755be670733418c994cf (patch) | |
tree | 1392c90227aeea231c1d86371131e04c40382918 /pcbnew/pcb_base_edit_frame.cpp | |
parent | 0db48f6533517ecebfd9f0693f89deca28408b76 (diff) | |
parent | c38609295ad4b617aef472b9c575aee18710a50f (diff) | |
download | KiCad-eSim-e255d0622297488c1c52755be670733418c994cf.tar.gz KiCad-eSim-e255d0622297488c1c52755be670733418c994cf.tar.bz2 KiCad-eSim-e255d0622297488c1c52755be670733418c994cf.zip |
Merge pull request #1 from saurabhb17/develop
Secondary files
Diffstat (limited to 'pcbnew/pcb_base_edit_frame.cpp')
-rw-r--r-- | pcbnew/pcb_base_edit_frame.cpp | 95 |
1 files changed, 95 insertions, 0 deletions
diff --git a/pcbnew/pcb_base_edit_frame.cpp b/pcbnew/pcb_base_edit_frame.cpp new file mode 100644 index 0000000..81b28c6 --- /dev/null +++ b/pcbnew/pcb_base_edit_frame.cpp @@ -0,0 +1,95 @@ +/* + * This program source code file is part of KiCad, a free EDA CAD application. + * + * Copyright (C) 2014 CERN + * @author Maciej Suminski <maciej.suminski@cern.ch> + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, you may find one here: + * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html + * or you may search the http://www.gnu.org website for the version 2 license, + * or you may write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA + */ + +#include <pcb_base_edit_frame.h> +#include <tool/tool_manager.h> +#include <pcb_draw_panel_gal.h> +#include <gal/graphics_abstraction_layer.h> +#include <class_board.h> + +void PCB_BASE_EDIT_FRAME::SetRotationAngle( int aRotationAngle ) +{ + wxCHECK2_MSG( aRotationAngle > 0 && aRotationAngle <= 900, aRotationAngle = 900, + wxT( "Invalid rotation angle, defaulting to 90." ) ); + + m_rotationAngle = aRotationAngle; +} + + +bool PCB_BASE_EDIT_FRAME::PostCommandMenuEvent( int evt_type ) +{ + if( evt_type != 0 ) + { + wxCommandEvent evt( wxEVT_COMMAND_MENU_SELECTED ); + evt.SetEventObject( this ); + evt.SetId( evt_type ); + wxPostEvent( this, evt ); + return true; + } + + return false; +} + + +void PCB_BASE_EDIT_FRAME::UseGalCanvas( bool aEnable ) +{ + PCB_BASE_FRAME::UseGalCanvas( aEnable ); + + // No matter what, reenable undo/redo on switching to the legacy canvas + if( !aEnable ) + UndoRedoBlock( false ); + else + static_cast<PCB_DRAW_PANEL_GAL*>( GetGalCanvas() )->SyncLayersVisibility( m_Pcb ); +} + + +void PCB_BASE_EDIT_FRAME::SetBoard( BOARD* aBoard ) +{ + bool new_board = ( aBoard != m_Pcb ); + + // The active tool might store a reference to the BOARD that is about to be deleted. + if( m_toolManager ) + m_toolManager->DeactivateTool(); + + // It has to be done before the previous board is destroyed by SetBoard() + if( new_board ) + GetGalCanvas()->GetView()->Clear(); + + PCB_BASE_FRAME::SetBoard( aBoard ); + + GetGalCanvas()->GetGAL()->SetGridOrigin( VECTOR2D( aBoard->GetGridOrigin() ) ); + + // update the tool manager with the new board and its view. + if( m_toolManager ) + { + PCB_DRAW_PANEL_GAL* drawPanel = static_cast<PCB_DRAW_PANEL_GAL*>( GetGalCanvas() ); + + drawPanel->DisplayBoard( aBoard ); + m_toolManager->SetEnvironment( aBoard, drawPanel->GetView(), + drawPanel->GetViewControls(), this ); + + if( new_board ) + m_toolManager->ResetTools( TOOL_BASE::MODEL_RELOAD ); + } +} |