/* * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright The 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 SCH_TABLECELL::SCH_TABLECELL( int aLineWidth, FILL_T aFillType ) : SCH_TEXTBOX( LAYER_NOTES, aLineWidth, aFillType, wxEmptyString, SCH_TABLECELL_T ), m_colSpan( 1 ), m_rowSpan( 1 ) { } void SCH_TABLECELL::swapData( SCH_ITEM* aItem ) { SCH_TEXTBOX::swapData( aItem ); SCH_TABLECELL* cell = static_cast( aItem ); std::swap( m_colSpan, cell->m_colSpan ); std::swap( m_rowSpan, cell->m_rowSpan ); } wxString SCH_TABLECELL::GetItemDescription( UNITS_PROVIDER* aUnitsProvider, bool aFull ) const { return wxString::Format( _( "Table Cell %s" ), GetAddr() ); } int SCH_TABLECELL::GetRow() const { const SCH_TABLE* table = static_cast( GetParent() ); for( int row = 0; row < table->GetRowCount(); ++row ) { for( int col = 0; col < table->GetColCount(); ++col ) { if( table->GetCell( row, col ) == this ) return row; } } return -1; } int SCH_TABLECELL::GetColumn() const { const SCH_TABLE* table = static_cast( GetParent() ); for( int row = 0; row < table->GetRowCount(); ++row ) { for( int col = 0; col < table->GetColCount(); ++col ) { if( table->GetCell( row, col ) == this ) return col; } } return -1; } wxString SCH_TABLECELL::GetAddr() const { return wxString::Format( wxT( "%c%d" ), 'A' + GetColumn() % 26, GetRow() + 1 ); } int SCH_TABLECELL::GetColumnWidth() const { return static_cast( GetParent() )->GetColWidth( GetColumn() ); } void SCH_TABLECELL::SetColumnWidth( int aWidth ) { SCH_TABLE* table = static_cast( GetParent() ); table->SetColWidth( GetColumn(), aWidth ); table->Normalize(); } int SCH_TABLECELL::GetRowHeight() const { return static_cast( GetParent() )->GetRowHeight( GetRow() ); } void SCH_TABLECELL::SetRowHeight( int aHeight ) { SCH_TABLE* table = static_cast( GetParent() ); table->SetRowHeight( GetRow(), aHeight ); table->Normalize(); } void SCH_TABLECELL::Plot( PLOTTER* aPlotter, bool aBackground, const SCH_PLOT_OPTS& aPlotOpts, int aUnit, int aBodyStyle, const VECTOR2I& aOffset, bool aDimmed ) { const int cell_body_style = -1; // flage to disable box ouline plotting if( m_colSpan >= 1 && m_rowSpan >= 1 ) SCH_TEXTBOX::Plot( aPlotter, aBackground, aPlotOpts, aUnit, cell_body_style, aOffset, aDimmed ); } void SCH_TABLECELL::GetMsgPanelInfo( EDA_DRAW_FRAME* aFrame, std::vector& aList ) { aList.emplace_back( _( "Table Cell" ), GetAddr() ); // Don't use GetShownText() here; we want to show the user the variable references aList.emplace_back( _( "Text" ), KIUI::EllipsizeStatusText( aFrame, GetText() ) ); aList.emplace_back( _( "Cell Width" ), aFrame->MessageTextFromValue( std::abs( GetEnd().x - GetStart().x ) ) ); aList.emplace_back( _( "Cell Height" ), aFrame->MessageTextFromValue( std::abs( GetEnd().y - GetStart().y ) ) ); aList.emplace_back( _( "Font" ), GetFont() ? GetFont()->GetName() : _( "Default" ) ); wxString textStyle[] = { _( "Normal" ), _( "Italic" ), _( "Bold" ), _( "Bold Italic" ) }; int style = IsBold() && IsItalic() ? 3 : IsBold() ? 2 : IsItalic() ? 1 : 0; aList.emplace_back( _( "Style" ), textStyle[style] ); aList.emplace_back( _( "Text Size" ), aFrame->MessageTextFromValue( GetTextWidth() ) ); } double SCH_TABLECELL::Similarity( const SCH_ITEM& aOtherItem ) const { if( aOtherItem.Type() != Type() ) return 0.0; const SCH_TABLECELL& other = static_cast( aOtherItem ); double similarity = 1.0; if( m_colSpan != other.m_colSpan ) similarity *= 0.9; if( m_rowSpan != other.m_rowSpan ) similarity *= 0.9; similarity *= SCH_TEXTBOX::Similarity( other ); return similarity; } bool SCH_TABLECELL::operator==( const SCH_ITEM& aOtherItem ) const { if( aOtherItem.Type() != Type() ) return false; const SCH_TABLECELL& other = static_cast( aOtherItem ); return *this == other; } bool SCH_TABLECELL::operator==( const SCH_TABLECELL& aOtherItem ) const { return m_colSpan == aOtherItem.m_colSpan && m_rowSpan == aOtherItem.m_rowSpan && SCH_TEXTBOX::operator==( aOtherItem ); } static struct SCH_TABLECELL_DESC { SCH_TABLECELL_DESC() { PROPERTY_MANAGER& propMgr = PROPERTY_MANAGER::Instance(); REGISTER_TYPE( SCH_TABLECELL ); propMgr.AddTypeCast( new TYPE_CAST ); propMgr.AddTypeCast( new TYPE_CAST ); propMgr.AddTypeCast( new TYPE_CAST ); propMgr.AddTypeCast( new TYPE_CAST ); propMgr.InheritsAfter( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( SCH_TEXTBOX ) ); propMgr.InheritsAfter( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( SCH_SHAPE ) ); propMgr.InheritsAfter( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_SHAPE ) ); propMgr.InheritsAfter( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_TEXT ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_SHAPE ), _HKI( "Start X" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_SHAPE ), _HKI( "Start Y" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_SHAPE ), _HKI( "End X" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_SHAPE ), _HKI( "End Y" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_SHAPE ), _HKI( "Shape" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_SHAPE ), _HKI( "Width" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_SHAPE ), _HKI( "Height" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_SHAPE ), _HKI( "Fill" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_SHAPE ), _HKI( "Fill Color" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_SHAPE ), _HKI( "Line Width" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_SHAPE ), _HKI( "Line Style" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_SHAPE ), _HKI( "Line Color" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_SHAPE ), _HKI( "Corner Radius" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_TEXT ), _HKI( "Width" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_TEXT ), _HKI( "Height" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_TEXT ), _HKI( "Thickness" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_TEXT ), _HKI( "Orientation" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_TEXT ), _HKI( "Mirrored" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_TEXT ), _HKI( "Visible" ) ); propMgr.Mask( TYPE_HASH( SCH_TABLECELL ), TYPE_HASH( EDA_TEXT ), _HKI( "Hyperlink" ) ); const wxString tableProps = _( "Table" ); propMgr.AddProperty( new PROPERTY( _HKI( "Column Width" ), &SCH_TABLECELL::SetColumnWidth, &SCH_TABLECELL::GetColumnWidth, PROPERTY_DISPLAY::PT_SIZE ), tableProps ); propMgr.AddProperty( new PROPERTY( _HKI( "Row Height" ), &SCH_TABLECELL::SetRowHeight, &SCH_TABLECELL::GetRowHeight, PROPERTY_DISPLAY::PT_SIZE ), tableProps ); const wxString cellProps = _( "Cell Properties" ); propMgr.AddProperty( new PROPERTY( _HKI( "Background Fill" ), &EDA_SHAPE::SetFilled, &EDA_SHAPE::IsSolidFill ), cellProps ); propMgr.AddProperty( new PROPERTY( _HKI( "Background Fill Color" ), &EDA_SHAPE::SetFillColor, &EDA_SHAPE::GetFillColor ), cellProps ) .SetIsHiddenFromRulesEditor(); } } _SCH_TABLECELL_DESC;