Bail on 45º text in pin conflicts map.
Fixes https://gitlab.com/kicad/code/kicad/issues/5515
This commit is contained in:
parent
2e50723781
commit
dd53b9c399
|
@ -234,7 +234,6 @@ set( COMMON_WIDGET_SRCS
|
||||||
widgets/widget_hotkey_list.cpp
|
widgets/widget_hotkey_list.cpp
|
||||||
widgets/wx_busy_indicator.cpp
|
widgets/wx_busy_indicator.cpp
|
||||||
widgets/wx_grid.cpp
|
widgets/wx_grid.cpp
|
||||||
widgets/wx_angle_text.cpp
|
|
||||||
widgets/wx_aui_dock_art.cpp
|
widgets/wx_aui_dock_art.cpp
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -1,113 +0,0 @@
|
||||||
/*
|
|
||||||
* This program source code file is part of KICAD, a free EDA CAD application.
|
|
||||||
*
|
|
||||||
* Copyright (C) 2020 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 <wx/wx.h>
|
|
||||||
#include <widgets/wx_angle_text.h>
|
|
||||||
#include <eda_rect.h>
|
|
||||||
|
|
||||||
WX_ANGLE_TEXT::WX_ANGLE_TEXT( wxWindow* aParent, wxWindowID aId, const wxString& aLabel,
|
|
||||||
const wxPoint& aPos, double aAngle ) :
|
|
||||||
wxPanel( aParent, aId, aPos, wxDefaultSize ),
|
|
||||||
m_label( aLabel ),
|
|
||||||
m_angle( aAngle )
|
|
||||||
{
|
|
||||||
wxFont font = wxSystemSettings::GetFont( wxSYS_DEFAULT_GUI_FONT );
|
|
||||||
font.SetPointSize( font.GetPointSize() + 2 ); // rotated text looks visually smaller
|
|
||||||
SetFont( font );
|
|
||||||
|
|
||||||
// Measure the size of the text
|
|
||||||
wxClientDC dc( this );
|
|
||||||
dc.SetFont( font );
|
|
||||||
|
|
||||||
wxSize size = dc.GetTextExtent( m_label );
|
|
||||||
wxPoint pos = GetPosition();
|
|
||||||
EDA_RECT rect( wxPoint( 0, 0 ), size );
|
|
||||||
EDA_RECT bbox = rect.GetBoundingBoxRotated( rect.GetPosition(), m_angle );
|
|
||||||
|
|
||||||
pos.y += bbox.GetTop() + ( rect.GetBottom() - bbox.GetBottom() );
|
|
||||||
size.y = bbox.GetHeight();
|
|
||||||
size.x = bbox.GetWidth();
|
|
||||||
|
|
||||||
Move( pos );
|
|
||||||
SetSize( size );
|
|
||||||
|
|
||||||
Bind( wxEVT_ERASE_BACKGROUND, &WX_ANGLE_TEXT::OnEraseBackground, this );
|
|
||||||
Bind( wxEVT_PAINT, &WX_ANGLE_TEXT::OnPaint, this );
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void WX_ANGLE_TEXT::OnEraseBackground( wxEraseEvent& WXUNUSED( aEvent ) )
|
|
||||||
{
|
|
||||||
// NOP so that we don't erase other labels which intersect
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void WX_ANGLE_TEXT::OnPaint( wxPaintEvent& WXUNUSED( aEvent ) )
|
|
||||||
{
|
|
||||||
wxPaintDC dc( this );
|
|
||||||
|
|
||||||
dc.SetFont( GetFont() );
|
|
||||||
dc.SetTextForeground( wxSystemSettings::GetColour( wxSYS_COLOUR_WINDOWTEXT ) );
|
|
||||||
dc.SetTextBackground( wxTransparentColor );
|
|
||||||
dc.SetBackgroundMode( wxTRANSPARENT );
|
|
||||||
dc.SetBackground( *wxTRANSPARENT_BRUSH );
|
|
||||||
|
|
||||||
wxSize size = dc.GetTextExtent( m_label );
|
|
||||||
EDA_RECT rect( wxPoint( 0, 0 ), size );
|
|
||||||
EDA_RECT bbox = rect.GetBoundingBoxRotated( rect.GetPosition(), m_angle );
|
|
||||||
wxPoint pos( 0, -bbox.GetTop() );
|
|
||||||
|
|
||||||
dc.DrawRotatedText( m_label, pos, m_angle / 10 );
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
EDA_RECT WX_ANGLE_TEXT::GetBoundingBox( wxWindow* aWindow, const wxString& aLabel, double aAngle )
|
|
||||||
{
|
|
||||||
wxSize size = WX_ANGLE_TEXT::GetTextSize( aWindow, aLabel );
|
|
||||||
EDA_RECT rect( wxPoint( 0, 0 ), size );
|
|
||||||
|
|
||||||
return rect.GetBoundingBoxRotated( rect.GetPosition(), aAngle );
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
wxSize WX_ANGLE_TEXT::GetTextSize( wxWindow* aWindow, const wxString& aLabel )
|
|
||||||
{
|
|
||||||
// Create the font used for the text
|
|
||||||
wxFont font = wxSystemSettings::GetFont( wxSYS_DEFAULT_GUI_FONT );
|
|
||||||
|
|
||||||
#ifdef __WXMAC__
|
|
||||||
// Rotated text looks visually smaller on OSX...
|
|
||||||
font.SetPointSize( font.GetPointSize() + 2 );
|
|
||||||
#elif __WXGTK3__
|
|
||||||
// TODO: needs testing...
|
|
||||||
#else
|
|
||||||
// ... but larger on MSW
|
|
||||||
font.SetPointSize( font.GetPointSize() - 2 );
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Measure the size of the text
|
|
||||||
wxClientDC dc( aWindow );
|
|
||||||
dc.SetFont( font );
|
|
||||||
|
|
||||||
return dc.GetTextExtent( aLabel );
|
|
||||||
}
|
|
|
@ -1,64 +0,0 @@
|
||||||
/*
|
|
||||||
* This program source code file is part of KICAD, a free EDA CAD application.
|
|
||||||
*
|
|
||||||
* Copyright (C) 2020 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
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef _WX_ANGLE_TEXT_
|
|
||||||
#define _WX_ANGLE_TEXT_
|
|
||||||
|
|
||||||
#include <eda_rect.h>
|
|
||||||
#include <wx/panel.h>
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class WX_ANGLE_TEXT : public wxPanel
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
WX_ANGLE_TEXT( wxWindow* aParent, wxWindowID aId, const wxString& aLabel,
|
|
||||||
const wxPoint& aPos, double aAngle );
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the bounding box that this angled text will take up on a certain window.
|
|
||||||
*
|
|
||||||
* @param aWindow is the wxWindow the text will go on
|
|
||||||
* @param aLabel is the text string
|
|
||||||
* @param aAngle is the angle of the text
|
|
||||||
*/
|
|
||||||
static EDA_RECT GetBoundingBox( wxWindow* aWindow, const wxString& aLabel, double aAngle );
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the height and width of the unrotated text string that is created for this control.
|
|
||||||
* This will include any modifications done to the font.
|
|
||||||
*
|
|
||||||
* @param aWindow is the wxWindow the text will go on
|
|
||||||
* @param aLabel is the text string
|
|
||||||
*/
|
|
||||||
static wxSize GetTextSize( wxWindow* aWindow, const wxString& aLabel );
|
|
||||||
|
|
||||||
protected:
|
|
||||||
void OnEraseBackground( wxEraseEvent& WXUNUSED( aEvent ) );
|
|
||||||
void OnPaint( wxPaintEvent& WXUNUSED( aEvent ) );
|
|
||||||
|
|
||||||
wxString m_label;
|
|
||||||
double m_angle;
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif /*_WX_ANGLE_TEXT_*/
|
|
|
@ -25,7 +25,6 @@
|
||||||
#include <sch_edit_frame.h>
|
#include <sch_edit_frame.h>
|
||||||
#include <kiface_i.h>
|
#include <kiface_i.h>
|
||||||
#include <bitmaps.h>
|
#include <bitmaps.h>
|
||||||
#include <reporter.h>
|
|
||||||
#include <wildcards_and_files_ext.h>
|
#include <wildcards_and_files_ext.h>
|
||||||
#include <schematic.h>
|
#include <schematic.h>
|
||||||
#include <connection_graph.h>
|
#include <connection_graph.h>
|
||||||
|
@ -34,7 +33,7 @@
|
||||||
#include <panel_setup_pinmap.h>
|
#include <panel_setup_pinmap.h>
|
||||||
#include <erc.h>
|
#include <erc.h>
|
||||||
#include <id.h>
|
#include <id.h>
|
||||||
#include <widgets/wx_angle_text.h>
|
#include <wx/statline.h>
|
||||||
|
|
||||||
|
|
||||||
// Control identifiers for events
|
// Control identifiers for events
|
||||||
|
@ -70,14 +69,6 @@ void PANEL_SETUP_PINMAP::ResetPanel()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifdef __WXMAC__
|
|
||||||
#define COL_LABEL_PLATFORM_FUDGE wxPoint( 5, 0 )
|
|
||||||
#elif __WXGTK3__
|
|
||||||
#define COL_LABEL_PLATFORM_FUDGE wxPoint( 0, 0 ) // TODO: needs testing...
|
|
||||||
#else
|
|
||||||
#define COL_LABEL_PLATFORM_FUDGE wxPoint( 0, 2 )
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void PANEL_SETUP_PINMAP::reBuildMatrixPanel()
|
void PANEL_SETUP_PINMAP::reBuildMatrixPanel()
|
||||||
{
|
{
|
||||||
// Try to know the size of bitmap button used in drc matrix
|
// Try to know the size of bitmap button used in drc matrix
|
||||||
|
@ -85,16 +76,8 @@ void PANEL_SETUP_PINMAP::reBuildMatrixPanel()
|
||||||
wxSize bmapSize = dummy->GetSize();
|
wxSize bmapSize = dummy->GetSize();
|
||||||
delete dummy;
|
delete dummy;
|
||||||
|
|
||||||
wxPoint pos;
|
wxSize charSize = GetTextSize( "X", m_matrixPanel );
|
||||||
// Get the text size for the angled text
|
wxPoint pos( 0, charSize.y * 2 );
|
||||||
EDA_RECT bbox = WX_ANGLE_TEXT::GetBoundingBox( m_matrixPanel, CommentERC_V[0], 450 );
|
|
||||||
wxSize txtSize = WX_ANGLE_TEXT::GetTextSize( m_matrixPanel, CommentERC_V[0] );
|
|
||||||
|
|
||||||
bmapSize.y = std::max( bmapSize.y, txtSize.y );
|
|
||||||
|
|
||||||
// compute the Y pos interval:
|
|
||||||
pos.y = bbox.GetHeight();
|
|
||||||
|
|
||||||
wxStaticText* text;
|
wxStaticText* text;
|
||||||
|
|
||||||
if( !m_initialized )
|
if( !m_initialized )
|
||||||
|
@ -106,7 +89,7 @@ void PANEL_SETUP_PINMAP::reBuildMatrixPanel()
|
||||||
{
|
{
|
||||||
int y = pos.y + (ii * bmapSize.y);
|
int y = pos.y + (ii * bmapSize.y);
|
||||||
text = new wxStaticText( m_matrixPanel, -1, CommentERC_H[ii],
|
text = new wxStaticText( m_matrixPanel, -1, CommentERC_H[ii],
|
||||||
wxPoint( 5, y + ( bmapSize.y / 2 ) - ( txtSize.y / 2 ) ) );
|
wxPoint( 5, y + ( bmapSize.y / 2 ) - ( 12 / 2 ) ) );
|
||||||
labels.push_back( text );
|
labels.push_back( text );
|
||||||
|
|
||||||
int x = text->GetRect().GetRight();
|
int x = text->GetRect().GetRight();
|
||||||
|
@ -139,11 +122,13 @@ void PANEL_SETUP_PINMAP::reBuildMatrixPanel()
|
||||||
|
|
||||||
if( ( ii == jj ) && !m_initialized )
|
if( ( ii == jj ) && !m_initialized )
|
||||||
{
|
{
|
||||||
wxPoint txtpos;
|
wxPoint textPos( x + KiROUND( bmapSize.x / 2 ) - KiROUND( charSize.x / 2 ),
|
||||||
txtpos.x = x + ( bmapSize.x / 2 ) - ( sqrt( 2 ) * txtSize.y / 2 );
|
y - charSize.y * 2 );
|
||||||
txtpos.y = y - txtSize.y;
|
new wxStaticText( m_matrixPanel, wxID_ANY, CommentERC_V[ii], textPos );
|
||||||
txtpos += COL_LABEL_PLATFORM_FUDGE;
|
|
||||||
new WX_ANGLE_TEXT( m_matrixPanel, wxID_ANY, CommentERC_V[ii], txtpos, 450 );
|
wxPoint calloutPos( x + KiROUND( bmapSize.x / 2 ) - 2,
|
||||||
|
y - charSize.y );
|
||||||
|
new wxStaticText( m_matrixPanel, wxID_ANY, "|", calloutPos );
|
||||||
}
|
}
|
||||||
|
|
||||||
int event_id = ID_MATRIX_0 + ii + ( jj * ELECTRICAL_PINTYPES_TOTAL );
|
int event_id = ID_MATRIX_0 + ii + ( jj * ELECTRICAL_PINTYPES_TOTAL );
|
||||||
|
@ -162,27 +147,6 @@ void PANEL_SETUP_PINMAP::reBuildMatrixPanel()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool PANEL_SETUP_PINMAP::Show( bool show )
|
|
||||||
{
|
|
||||||
wxPanel::Show( show );
|
|
||||||
|
|
||||||
// For some reason the angle text doesn't get drawn if the paint events are fired while
|
|
||||||
// it's not the active tab.
|
|
||||||
if( show )
|
|
||||||
{
|
|
||||||
for( wxWindow* win : m_matrixPanel->GetChildren() )
|
|
||||||
{
|
|
||||||
WX_ANGLE_TEXT* angleText = dynamic_cast<WX_ANGLE_TEXT*>( win );
|
|
||||||
|
|
||||||
if( angleText )
|
|
||||||
angleText->Refresh();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void PANEL_SETUP_PINMAP::setDRCMatrixButtonState( wxBitmapButton *aButton, PIN_ERROR aState )
|
void PANEL_SETUP_PINMAP::setDRCMatrixButtonState( wxBitmapButton *aButton, PIN_ERROR aState )
|
||||||
{
|
{
|
||||||
BITMAP_DEF bitmap_butt = nullptr;
|
BITMAP_DEF bitmap_butt = nullptr;
|
||||||
|
|
|
@ -48,7 +48,6 @@ private:
|
||||||
public:
|
public:
|
||||||
PANEL_SETUP_PINMAP( wxWindow* aWindow, SCH_EDIT_FRAME* aParent );
|
PANEL_SETUP_PINMAP( wxWindow* aWindow, SCH_EDIT_FRAME* aParent );
|
||||||
|
|
||||||
bool Show( bool show ) override;
|
|
||||||
void ImportSettingsFrom( PIN_ERROR aPinMap[][ELECTRICAL_PINTYPES_TOTAL] );
|
void ImportSettingsFrom( PIN_ERROR aPinMap[][ELECTRICAL_PINTYPES_TOTAL] );
|
||||||
|
|
||||||
void ResetPanel() override;
|
void ResetPanel() override;
|
||||||
|
|
Loading…
Reference in New Issue