/* * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2017 Seth Hillbrand * Copyright (C) 2014-2022 KiCad Developers, see AUTHORS.txt for contributors. * * 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 #include #include #include #include #include #include DIALOG_LINE_PROPERTIES::DIALOG_LINE_PROPERTIES( SCH_EDIT_FRAME* aParent, std::deque& aLines ) : DIALOG_LINE_PROPERTIES_BASE( aParent ), m_frame( aParent ), m_lines( aLines ), m_width( aParent, m_staticTextWidth, m_lineWidth, m_staticWidthUnits, true ) { m_colorSwatch->SetDefaultColor( COLOR4D::UNSPECIFIED ); m_helpLabel1->SetFont( KIUI::GetInfoFont( this ).Italic() ); m_helpLabel2->SetFont( KIUI::GetInfoFont( this ).Italic() ); SetInitialFocus( m_lineWidth ); for( const std::pair& typeEntry : lineTypeNames ) m_typeCombo->Append( typeEntry.second.name, KiBitmap( typeEntry.second.bitmap ) ); m_typeCombo->Append( DEFAULT_STYLE ); SetupStandardButtons( { { wxID_APPLY, _( "Default" ) } } ); // Now all widgets have the size fixed, call FinishDialogSettings finishDialogSettings(); } bool DIALOG_LINE_PROPERTIES::TransferDataToWindow() { SCH_LINE* first_stroke_item = m_lines.front(); if( std::all_of( m_lines.begin() + 1, m_lines.end(), [&]( const SCH_LINE* r ) { return r->GetPenWidth() == first_stroke_item->GetPenWidth(); } ) ) { m_width.SetValue( first_stroke_item->GetStroke().GetWidth() ); } else { m_width.SetValue( INDETERMINATE_ACTION ); } if( std::all_of( m_lines.begin() + 1, m_lines.end(), [&]( const SCH_LINE* r ) { return r->GetStroke().GetColor() == first_stroke_item->GetStroke().GetColor(); } ) ) { m_colorSwatch->SetSwatchColor( first_stroke_item->GetStroke().GetColor(), false ); } else { m_colorSwatch->SetSwatchColor( COLOR4D::UNSPECIFIED, false ); } if( std::all_of( m_lines.begin() + 1, m_lines.end(), [&]( const SCH_LINE* r ) { return r->GetStroke().GetPlotStyle() == first_stroke_item->GetStroke().GetPlotStyle(); } ) ) { int style = static_cast( first_stroke_item->GetStroke().GetPlotStyle() ); if( style == -1 ) m_typeCombo->SetStringSelection( DEFAULT_STYLE ); else if( style < (int) lineTypeNames.size() ) m_typeCombo->SetSelection( style ); else wxFAIL_MSG( "Line type not found in the type lookup map" ); } else { m_typeCombo->Append( INDETERMINATE_STYLE ); m_typeCombo->SetStringSelection( INDETERMINATE_STYLE ); } return true; } void DIALOG_LINE_PROPERTIES::resetDefaults( wxCommandEvent& event ) { m_width.SetValue( 0 ); m_colorSwatch->SetSwatchColor( COLOR4D::UNSPECIFIED, false ); m_typeCombo->SetStringSelection( DEFAULT_STYLE ); Refresh(); } bool DIALOG_LINE_PROPERTIES::TransferDataFromWindow() { PICKED_ITEMS_LIST pickedItems; for( SCH_LINE* line : m_lines ) pickedItems.PushItem( ITEM_PICKER( m_frame->GetScreen(), line, UNDO_REDO::CHANGED ) ); m_frame->SaveCopyInUndoList( pickedItems, UNDO_REDO::CHANGED, false, false ); for( SCH_LINE* line : m_lines ) { if( !m_width.IsIndeterminate() ) line->SetLineWidth( m_width.GetValue() ); auto it = lineTypeNames.begin(); std::advance( it, m_typeCombo->GetSelection() ); if( it == lineTypeNames.end() ) line->SetLineStyle( PLOT_DASH_TYPE::DEFAULT ); else line->SetLineStyle( it->first ); line->SetLineColor( m_colorSwatch->GetSwatchColor() ); m_frame->UpdateItem( line, false, true ); } m_frame->GetCanvas()->Refresh(); m_frame->OnModify(); return true; }