Move color configuration into a separate widget
This commit is contained in:
parent
b5a9e466ff
commit
c4694e029d
|
@ -72,6 +72,11 @@ set( EESCHEMA_DLGS
|
|||
dialogs/dialog_schematic_find_base.cpp
|
||||
)
|
||||
|
||||
set( EESCHEMA_WIDGETS
|
||||
widgets/widget_color_config.cpp
|
||||
)
|
||||
|
||||
|
||||
set( EESCHEMA_SRCS
|
||||
autoplace_fields.cpp
|
||||
annotate.cpp
|
||||
|
@ -90,6 +95,7 @@ set( EESCHEMA_SRCS
|
|||
controle.cpp
|
||||
cross-probing.cpp
|
||||
${EESCHEMA_DLGS}
|
||||
${EESCHEMA_WIDGETS}
|
||||
edit_component_in_schematic.cpp
|
||||
edit_bitmap.cpp
|
||||
edit_label.cpp
|
||||
|
|
|
@ -33,264 +33,21 @@
|
|||
|
||||
#include <dialog_color_config.h>
|
||||
|
||||
|
||||
#define ID_COLOR_SETUP 1800
|
||||
|
||||
// Specify the width and height of every (color-displaying / bitmap) button
|
||||
const int BUTT_SIZE_X = 16;
|
||||
const int BUTT_SIZE_Y = 16;
|
||||
|
||||
|
||||
/********************/
|
||||
/* Layer menu list. */
|
||||
/********************/
|
||||
|
||||
struct COLORBUTTON
|
||||
{
|
||||
wxString m_Name;
|
||||
int m_Layer;
|
||||
};
|
||||
|
||||
struct BUTTONINDEX
|
||||
{
|
||||
wxString m_Name;
|
||||
COLORBUTTON* m_Buttons;
|
||||
};
|
||||
|
||||
static COLORBUTTON generalColorButtons[] = {
|
||||
{ _( "Wire" ), LAYER_WIRE },
|
||||
{ _( "Bus" ), LAYER_BUS },
|
||||
{ _( "Junction" ), LAYER_JUNCTION },
|
||||
{ _( "Label" ), LAYER_LOCLABEL },
|
||||
{ _( "Global label" ), LAYER_GLOBLABEL },
|
||||
{ _( "Net name" ), LAYER_NETNAM },
|
||||
{ _( "Notes" ), LAYER_NOTES },
|
||||
{ _( "No connect symbol" ), LAYER_NOCONNECT },
|
||||
{ wxT( "" ), -1 } // Sentinel marking end of list.
|
||||
};
|
||||
|
||||
static COLORBUTTON componentColorButtons[] = {
|
||||
{ _( "Body" ), LAYER_DEVICE },
|
||||
{ _( "Body background" ), LAYER_DEVICE_BACKGROUND },
|
||||
{ _( "Pin" ), LAYER_PIN },
|
||||
{ _( "Pin number" ), LAYER_PINNUM },
|
||||
{ _( "Pin name" ), LAYER_PINNAM },
|
||||
{ _( "Reference" ), LAYER_REFERENCEPART },
|
||||
{ _( "Value" ), LAYER_VALUEPART },
|
||||
{ _( "Fields" ), LAYER_FIELDS },
|
||||
{ wxT( "" ), -1 } // Sentinel marking end of list.
|
||||
};
|
||||
|
||||
static COLORBUTTON sheetColorButtons[] = {
|
||||
{ _( "Sheet" ), LAYER_SHEET },
|
||||
{ _( "Sheet file name" ), LAYER_SHEETFILENAME },
|
||||
{ _( "Sheet name" ), LAYER_SHEETNAME },
|
||||
{ _( "Sheet label" ), LAYER_SHEETLABEL },
|
||||
{ _( "Hierarchical label" ),LAYER_HIERLABEL },
|
||||
{ wxT( "" ), -1 } // Sentinel marking end of list.
|
||||
};
|
||||
|
||||
static COLORBUTTON miscColorButtons[] = {
|
||||
{ _( "ERC warning" ), LAYER_ERC_WARN },
|
||||
{ _( "ERC error" ), LAYER_ERC_ERR },
|
||||
{ _( "Grid" ), LAYER_GRID },
|
||||
{ wxT( "" ), -1 } // Sentinel marking end of list.
|
||||
};
|
||||
|
||||
|
||||
static BUTTONINDEX buttonGroups[] = {
|
||||
{ _( "General" ), generalColorButtons },
|
||||
{ _( "Component" ), componentColorButtons },
|
||||
{ _( "Sheet" ), sheetColorButtons },
|
||||
{ _( "Miscellaneous" ), miscColorButtons },
|
||||
{ wxT( "" ), NULL }
|
||||
};
|
||||
|
||||
|
||||
static EDA_COLOR_T currentColors[ LAYERSCH_ID_COUNT ];
|
||||
|
||||
|
||||
DIALOG_COLOR_CONFIG::DIALOG_COLOR_CONFIG( EDA_DRAW_FRAME* aParent ) :
|
||||
DIALOG_COLOR_CONFIG_BASE( aParent )
|
||||
{
|
||||
m_parent = aParent;
|
||||
CreateControls();
|
||||
|
||||
m_colorConfig = new WIDGET_COLOR_CONFIG( this, aParent );
|
||||
m_mainBoxSizer->Insert( 0, m_colorConfig, 1, wxEXPAND | wxALL, 5 );
|
||||
|
||||
GetSizer()->SetSizeHints( this );
|
||||
}
|
||||
|
||||
|
||||
void DIALOG_COLOR_CONFIG::CreateControls()
|
||||
{
|
||||
wxStaticText* label;
|
||||
int buttonId = 1800;
|
||||
|
||||
BUTTONINDEX* groups = buttonGroups;
|
||||
wxBoxSizer* columnBoxSizer = NULL;
|
||||
|
||||
while( groups->m_Buttons != NULL )
|
||||
{
|
||||
COLORBUTTON* buttons = groups->m_Buttons;
|
||||
|
||||
columnBoxSizer = new wxBoxSizer( wxVERTICAL );
|
||||
m_mainBoxSizer->Add( columnBoxSizer, 1, wxALIGN_TOP | wxLEFT | wxTOP, 5 );
|
||||
wxBoxSizer* rowBoxSizer = new wxBoxSizer( wxHORIZONTAL );
|
||||
columnBoxSizer->Add( rowBoxSizer, 0, wxGROW | wxLEFT | wxRIGHT | wxBOTTOM, 5 );
|
||||
|
||||
// Add a text string to identify the column of color select buttons.
|
||||
label = new wxStaticText( this, wxID_ANY, groups->m_Name );
|
||||
|
||||
// Make the column label font bold.
|
||||
wxFont font( label->GetFont() );
|
||||
font.SetWeight( wxFONTWEIGHT_BOLD );
|
||||
label->SetFont( font );
|
||||
|
||||
rowBoxSizer->Add( label, 1, wxALIGN_CENTER_VERTICAL | wxALL, 5 );
|
||||
|
||||
while( buttons->m_Layer >= 0 )
|
||||
{
|
||||
rowBoxSizer = new wxBoxSizer( wxHORIZONTAL );
|
||||
columnBoxSizer->Add( rowBoxSizer, 0, wxGROW | wxALL, 0 );
|
||||
|
||||
wxMemoryDC iconDC;
|
||||
wxBitmap bitmap( BUTT_SIZE_X, BUTT_SIZE_Y );
|
||||
|
||||
iconDC.SelectObject( bitmap );
|
||||
|
||||
EDA_COLOR_T color = GetLayerColor( LAYERSCH_ID( buttons->m_Layer ) );
|
||||
currentColors[ buttons->m_Layer ] = color;
|
||||
|
||||
iconDC.SetPen( *wxBLACK_PEN );
|
||||
|
||||
wxBrush brush;
|
||||
ColorSetBrush( &brush, color );
|
||||
brush.SetStyle( wxBRUSHSTYLE_SOLID );
|
||||
iconDC.SetBrush( brush );
|
||||
iconDC.DrawRectangle( 0, 0, BUTT_SIZE_X, BUTT_SIZE_Y );
|
||||
|
||||
wxBitmapButton* bitmapButton = new wxBitmapButton(
|
||||
this, buttonId, bitmap, wxDefaultPosition,
|
||||
wxSize( BUTT_SIZE_X+8, BUTT_SIZE_Y+6 ) );
|
||||
bitmapButton->SetClientData( (void*) buttons );
|
||||
|
||||
rowBoxSizer->Add( bitmapButton, 0, wxALIGN_CENTER_VERTICAL | wxRIGHT | wxBOTTOM, 5 );
|
||||
|
||||
label = new wxStaticText( this, wxID_ANY, wxGetTranslation( buttons->m_Name ) );
|
||||
rowBoxSizer->Add( label, 1, wxALIGN_CENTER_VERTICAL | wxRIGHT | wxBOTTOM, 5 );
|
||||
buttonId += 1;
|
||||
buttons++;
|
||||
}
|
||||
|
||||
groups++;
|
||||
}
|
||||
|
||||
Connect( 1800, buttonId - 1, wxEVT_COMMAND_BUTTON_CLICKED,
|
||||
wxCommandEventHandler( DIALOG_COLOR_CONFIG::SetColor ) );
|
||||
|
||||
wxArrayString selBgColorStrings;
|
||||
selBgColorStrings.Add( _( "White" ) );
|
||||
selBgColorStrings.Add( _( "Black" ) );
|
||||
m_SelBgColor = new wxRadioBox( this, wxID_ANY, _( "Background Color" ),
|
||||
wxDefaultPosition, wxDefaultSize,
|
||||
selBgColorStrings, 1, wxRA_SPECIFY_COLS );
|
||||
m_SelBgColor->SetSelection( ( m_parent->GetDrawBgColor() == BLACK ) ? 1 : 0 );
|
||||
|
||||
if( columnBoxSizer )
|
||||
{
|
||||
// Add a spacer to improve appearance.
|
||||
columnBoxSizer->AddSpacer( 5 );
|
||||
columnBoxSizer->Add( m_SelBgColor, 1, wxGROW | wxRIGHT | wxTOP | wxBOTTOM, 5 );
|
||||
}
|
||||
|
||||
currentColors[ LAYER_BACKGROUND ] = m_parent->GetDrawBgColor();
|
||||
|
||||
// Dialog now needs to be resized, but the associated command is found elsewhere.
|
||||
}
|
||||
|
||||
|
||||
void DIALOG_COLOR_CONFIG::SetColor( wxCommandEvent& event )
|
||||
{
|
||||
wxBitmapButton* button = (wxBitmapButton*) event.GetEventObject();
|
||||
|
||||
wxCHECK_RET( button != NULL, wxT( "Color button event object is NULL." ) );
|
||||
|
||||
COLORBUTTON* colorButton = (COLORBUTTON*) button->GetClientData();
|
||||
|
||||
wxCHECK_RET( colorButton != NULL, wxT( "Client data not set for color button." ) );
|
||||
|
||||
EDA_COLOR_T color = DisplayColorFrame( this, colorButton->m_Layer );
|
||||
|
||||
if( color < 0 || currentColors[ colorButton->m_Layer ] == color )
|
||||
return;
|
||||
|
||||
currentColors[ colorButton->m_Layer ] = color;
|
||||
|
||||
wxMemoryDC iconDC;
|
||||
|
||||
wxBitmap bitmap = button->GetBitmapLabel();
|
||||
iconDC.SelectObject( bitmap );
|
||||
iconDC.SetPen( *wxBLACK_PEN );
|
||||
|
||||
wxBrush brush;
|
||||
|
||||
ColorSetBrush( &brush, color);
|
||||
|
||||
brush.SetStyle( wxBRUSHSTYLE_SOLID );
|
||||
|
||||
iconDC.SetBrush( brush );
|
||||
iconDC.DrawRectangle( 0, 0, BUTT_SIZE_X, BUTT_SIZE_Y );
|
||||
button->SetBitmapLabel( bitmap );
|
||||
button->Refresh();
|
||||
|
||||
Refresh( false );
|
||||
}
|
||||
|
||||
|
||||
bool DIALOG_COLOR_CONFIG::TransferDataFromWindow()
|
||||
{
|
||||
bool warning = false;
|
||||
|
||||
// Check for color conflicts with background color to give user a chance to bail
|
||||
// out before making changes.
|
||||
|
||||
EDA_COLOR_T bgcolor = WHITE;
|
||||
|
||||
if( m_SelBgColor->GetSelection() > 0 )
|
||||
bgcolor = BLACK;
|
||||
|
||||
for( LAYERSCH_ID clyr = LAYER_WIRE; clyr < LAYERSCH_ID_COUNT; ++clyr )
|
||||
{
|
||||
if( bgcolor == currentColors[ clyr ] && clyr != LAYER_BACKGROUND )
|
||||
{
|
||||
warning = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// Prompt the user if an item has the same color as the background
|
||||
// because this item cannot be seen:
|
||||
if( warning )
|
||||
{
|
||||
if( wxMessageBox( _( "Some items have the same color as the background\n"
|
||||
"and they will not be seen on the screen. Are you\n"
|
||||
"sure you want to use these colors?" ),
|
||||
_( "Warning" ),
|
||||
wxYES_NO | wxICON_QUESTION, this ) == wxNO )
|
||||
return false;
|
||||
}
|
||||
|
||||
// Update color of background
|
||||
m_parent->SetDrawBgColor( bgcolor );
|
||||
currentColors[ LAYER_BACKGROUND ] = bgcolor;
|
||||
|
||||
|
||||
for( LAYERSCH_ID clyr = LAYER_WIRE; clyr < LAYERSCH_ID_COUNT; ++clyr )
|
||||
{
|
||||
SetLayerColor( currentColors[ clyr ], clyr );
|
||||
}
|
||||
|
||||
m_parent->SetGridColor( GetLayerColor( LAYER_GRID ) );
|
||||
m_parent->GetCanvas()->Refresh();
|
||||
|
||||
return true;
|
||||
return m_colorConfig->TransferDataFromControl();
|
||||
}
|
||||
|
|
|
@ -26,7 +26,7 @@
|
|||
#define DIALOG_COLOR_CONFIG_H_
|
||||
|
||||
#include <dialog_color_config_base.h>
|
||||
|
||||
#include "../widgets/widget_color_config.h"
|
||||
|
||||
class wxBoxSizer;
|
||||
class wxStaticLine;
|
||||
|
@ -39,14 +39,8 @@ class wxStdDialogButtonSizer;
|
|||
|
||||
class DIALOG_COLOR_CONFIG : public DIALOG_COLOR_CONFIG_BASE
|
||||
{
|
||||
private:
|
||||
EDA_DRAW_FRAME* m_parent;
|
||||
wxRadioBox* m_SelBgColor;
|
||||
|
||||
// Creates the controls and sizers
|
||||
void CreateControls();
|
||||
|
||||
void SetColor( wxCommandEvent& aEvent );
|
||||
WIDGET_COLOR_CONFIG* m_colorConfig;
|
||||
|
||||
public:
|
||||
// Constructors and destructor
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
///////////////////////////////////////////////////////////////////////////
|
||||
// C++ code generated with wxFormBuilder (version Jun 5 2014)
|
||||
// C++ code generated with wxFormBuilder (version Dec 28 2015)
|
||||
// http://www.wxformbuilder.org/
|
||||
//
|
||||
// PLEASE DO "NOT" EDIT THIS FILE!
|
||||
|
@ -13,16 +13,10 @@ DIALOG_COLOR_CONFIG_BASE::DIALOG_COLOR_CONFIG_BASE( wxWindow* parent, wxWindowID
|
|||
{
|
||||
this->SetSizeHints( wxDefaultSize, wxDefaultSize );
|
||||
|
||||
wxBoxSizer* bmainSizer;
|
||||
bmainSizer = new wxBoxSizer( wxVERTICAL );
|
||||
|
||||
m_mainBoxSizer = new wxBoxSizer( wxHORIZONTAL );
|
||||
|
||||
|
||||
bmainSizer->Add( m_mainBoxSizer, 1, wxEXPAND, 5 );
|
||||
m_mainBoxSizer = new wxBoxSizer( wxVERTICAL );
|
||||
|
||||
m_staticline = new wxStaticLine( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLI_HORIZONTAL );
|
||||
bmainSizer->Add( m_staticline, 0, wxEXPAND | wxALL, 5 );
|
||||
m_mainBoxSizer->Add( m_staticline, 0, wxEXPAND | wxALL, 5 );
|
||||
|
||||
m_sdbSizer = new wxStdDialogButtonSizer();
|
||||
m_sdbSizerOK = new wxButton( this, wxID_OK );
|
||||
|
@ -33,12 +27,12 @@ DIALOG_COLOR_CONFIG_BASE::DIALOG_COLOR_CONFIG_BASE( wxWindow* parent, wxWindowID
|
|||
m_sdbSizer->AddButton( m_sdbSizerCancel );
|
||||
m_sdbSizer->Realize();
|
||||
|
||||
bmainSizer->Add( m_sdbSizer, 0, wxALIGN_RIGHT|wxALL, 5 );
|
||||
m_mainBoxSizer->Add( m_sdbSizer, 0, wxALIGN_RIGHT|wxALL, 5 );
|
||||
|
||||
|
||||
this->SetSizer( bmainSizer );
|
||||
this->SetSizer( m_mainBoxSizer );
|
||||
this->Layout();
|
||||
bmainSizer->Fit( this );
|
||||
m_mainBoxSizer->Fit( this );
|
||||
|
||||
this->Centre( wxBOTH );
|
||||
}
|
||||
|
|
|
@ -90,20 +90,9 @@
|
|||
<event name="OnUpdateUI"></event>
|
||||
<object class="wxBoxSizer" expanded="1">
|
||||
<property name="minimum_size"></property>
|
||||
<property name="name">bmainSizer</property>
|
||||
<property name="name">m_mainBoxSizer</property>
|
||||
<property name="orient">wxVERTICAL</property>
|
||||
<property name="permission">none</property>
|
||||
<object class="sizeritem" expanded="1">
|
||||
<property name="border">5</property>
|
||||
<property name="flag">wxEXPAND</property>
|
||||
<property name="proportion">1</property>
|
||||
<object class="wxBoxSizer" expanded="1">
|
||||
<property name="minimum_size"></property>
|
||||
<property name="name">m_mainBoxSizer</property>
|
||||
<property name="orient">wxHORIZONTAL</property>
|
||||
<property name="permission">protected</property>
|
||||
</object>
|
||||
</object>
|
||||
<property name="permission">protected</property>
|
||||
<object class="sizeritem" expanded="1">
|
||||
<property name="border">5</property>
|
||||
<property name="flag">wxEXPAND | wxALL</property>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
///////////////////////////////////////////////////////////////////////////
|
||||
// C++ code generated with wxFormBuilder (version Jun 5 2014)
|
||||
// C++ code generated with wxFormBuilder (version Dec 28 2015)
|
||||
// http://www.wxformbuilder.org/
|
||||
//
|
||||
// PLEASE DO "NOT" EDIT THIS FILE!
|
||||
|
@ -14,13 +14,13 @@
|
|||
class DIALOG_SHIM;
|
||||
|
||||
#include "dialog_shim.h"
|
||||
#include <wx/sizer.h>
|
||||
#include <wx/gdicmn.h>
|
||||
#include <wx/statline.h>
|
||||
#include <wx/gdicmn.h>
|
||||
#include <wx/font.h>
|
||||
#include <wx/colour.h>
|
||||
#include <wx/settings.h>
|
||||
#include <wx/string.h>
|
||||
#include <wx/sizer.h>
|
||||
#include <wx/button.h>
|
||||
#include <wx/dialog.h>
|
||||
|
||||
|
|
|
@ -0,0 +1,295 @@
|
|||
/*
|
||||
* This program source code file is part of KiCad, a free EDA CAD application.
|
||||
*
|
||||
* Copyright (C) 2015 Jean-Pierre Charras, jp.charras at wanadoo.fr
|
||||
* Copyright (C) 2016 KiCad Developers, see CHANGELOG.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
|
||||
*/
|
||||
|
||||
/* Set up color Layers for Eeschema
|
||||
*/
|
||||
|
||||
#include <fctsys.h>
|
||||
#include <draw_frame.h>
|
||||
#include <class_drawpanel.h>
|
||||
|
||||
#include <general.h>
|
||||
|
||||
#include "widget_color_config.h"
|
||||
|
||||
// Specify the width and height of every (color-displaying / bitmap) button
|
||||
const int BUTT_SIZE_X = 16;
|
||||
const int BUTT_SIZE_Y = 16;
|
||||
|
||||
|
||||
/********************/
|
||||
/* Layer menu list. */
|
||||
/********************/
|
||||
|
||||
struct COLORBUTTON
|
||||
{
|
||||
wxString m_Name;
|
||||
int m_Layer;
|
||||
};
|
||||
|
||||
struct BUTTONINDEX
|
||||
{
|
||||
wxString m_Name;
|
||||
COLORBUTTON* m_Buttons;
|
||||
};
|
||||
|
||||
static COLORBUTTON generalColorButtons[] = {
|
||||
{ _( "Wire" ), LAYER_WIRE },
|
||||
{ _( "Bus" ), LAYER_BUS },
|
||||
{ _( "Junction" ), LAYER_JUNCTION },
|
||||
{ _( "Label" ), LAYER_LOCLABEL },
|
||||
{ _( "Global label" ), LAYER_GLOBLABEL },
|
||||
{ _( "Net name" ), LAYER_NETNAM },
|
||||
{ _( "Notes" ), LAYER_NOTES },
|
||||
{ _( "No connect symbol" ), LAYER_NOCONNECT },
|
||||
{ wxT( "" ), -1 } // Sentinel marking end of list.
|
||||
};
|
||||
|
||||
static COLORBUTTON componentColorButtons[] = {
|
||||
{ _( "Body" ), LAYER_DEVICE },
|
||||
{ _( "Body background" ), LAYER_DEVICE_BACKGROUND },
|
||||
{ _( "Pin" ), LAYER_PIN },
|
||||
{ _( "Pin number" ), LAYER_PINNUM },
|
||||
{ _( "Pin name" ), LAYER_PINNAM },
|
||||
{ _( "Reference" ), LAYER_REFERENCEPART },
|
||||
{ _( "Value" ), LAYER_VALUEPART },
|
||||
{ _( "Fields" ), LAYER_FIELDS },
|
||||
{ wxT( "" ), -1 } // Sentinel marking end of list.
|
||||
};
|
||||
|
||||
static COLORBUTTON sheetColorButtons[] = {
|
||||
{ _( "Sheet" ), LAYER_SHEET },
|
||||
{ _( "Sheet file name" ), LAYER_SHEETFILENAME },
|
||||
{ _( "Sheet name" ), LAYER_SHEETNAME },
|
||||
{ _( "Sheet label" ), LAYER_SHEETLABEL },
|
||||
{ _( "Hierarchical label" ),LAYER_HIERLABEL },
|
||||
{ wxT( "" ), -1 } // Sentinel marking end of list.
|
||||
};
|
||||
|
||||
static COLORBUTTON miscColorButtons[] = {
|
||||
{ _( "ERC warning" ), LAYER_ERC_WARN },
|
||||
{ _( "ERC error" ), LAYER_ERC_ERR },
|
||||
{ _( "Grid" ), LAYER_GRID },
|
||||
{ wxT( "" ), -1 } // Sentinel marking end of list.
|
||||
};
|
||||
|
||||
|
||||
static BUTTONINDEX buttonGroups[] = {
|
||||
{ _( "General" ), generalColorButtons },
|
||||
{ _( "Component" ), componentColorButtons },
|
||||
{ _( "Sheet" ), sheetColorButtons },
|
||||
{ _( "Miscellaneous" ), miscColorButtons },
|
||||
{ wxT( "" ), NULL }
|
||||
};
|
||||
|
||||
|
||||
static EDA_COLOR_T currentColors[ LAYERSCH_ID_COUNT ];
|
||||
|
||||
|
||||
WIDGET_COLOR_CONFIG::WIDGET_COLOR_CONFIG( wxWindow* aParent, EDA_DRAW_FRAME* aDrawFrame ) :
|
||||
wxPanel( aParent ), m_drawFrame( aDrawFrame )
|
||||
{
|
||||
CreateControls();
|
||||
|
||||
GetSizer()->SetSizeHints( this );
|
||||
}
|
||||
|
||||
|
||||
void WIDGET_COLOR_CONFIG::CreateControls()
|
||||
{
|
||||
wxStaticText* label;
|
||||
int buttonId = 1800;
|
||||
|
||||
m_mainBoxSizer = new wxBoxSizer( wxHORIZONTAL );
|
||||
SetSizer( m_mainBoxSizer );
|
||||
|
||||
BUTTONINDEX* groups = buttonGroups;
|
||||
wxBoxSizer* columnBoxSizer = NULL;
|
||||
|
||||
while( groups->m_Buttons != NULL )
|
||||
{
|
||||
COLORBUTTON* buttons = groups->m_Buttons;
|
||||
|
||||
columnBoxSizer = new wxBoxSizer( wxVERTICAL );
|
||||
m_mainBoxSizer->Add( columnBoxSizer, 1, wxALIGN_TOP | wxLEFT | wxTOP, 5 );
|
||||
wxBoxSizer* rowBoxSizer = new wxBoxSizer( wxHORIZONTAL );
|
||||
columnBoxSizer->Add( rowBoxSizer, 0, wxGROW | wxLEFT | wxRIGHT | wxBOTTOM, 5 );
|
||||
|
||||
// Add a text string to identify the column of color select buttons.
|
||||
label = new wxStaticText( this, wxID_ANY, groups->m_Name );
|
||||
|
||||
// Make the column label font bold.
|
||||
wxFont font( label->GetFont() );
|
||||
font.SetWeight( wxFONTWEIGHT_BOLD );
|
||||
label->SetFont( font );
|
||||
|
||||
rowBoxSizer->Add( label, 1, wxALIGN_CENTER_VERTICAL | wxALL, 5 );
|
||||
|
||||
while( buttons->m_Layer >= 0 )
|
||||
{
|
||||
rowBoxSizer = new wxBoxSizer( wxHORIZONTAL );
|
||||
columnBoxSizer->Add( rowBoxSizer, 0, wxGROW | wxALL, 0 );
|
||||
|
||||
wxMemoryDC iconDC;
|
||||
wxBitmap bitmap( BUTT_SIZE_X, BUTT_SIZE_Y );
|
||||
|
||||
iconDC.SelectObject( bitmap );
|
||||
|
||||
EDA_COLOR_T color = GetLayerColor( LAYERSCH_ID( buttons->m_Layer ) );
|
||||
currentColors[ buttons->m_Layer ] = color;
|
||||
|
||||
iconDC.SetPen( *wxBLACK_PEN );
|
||||
|
||||
wxBrush brush;
|
||||
ColorSetBrush( &brush, color );
|
||||
brush.SetStyle( wxBRUSHSTYLE_SOLID );
|
||||
iconDC.SetBrush( brush );
|
||||
iconDC.DrawRectangle( 0, 0, BUTT_SIZE_X, BUTT_SIZE_Y );
|
||||
|
||||
wxBitmapButton* bitmapButton = new wxBitmapButton(
|
||||
this, buttonId, bitmap, wxDefaultPosition,
|
||||
wxSize( BUTT_SIZE_X+8, BUTT_SIZE_Y+6 ) );
|
||||
bitmapButton->SetClientData( (void*) buttons );
|
||||
|
||||
rowBoxSizer->Add( bitmapButton, 0, wxALIGN_CENTER_VERTICAL | wxRIGHT | wxBOTTOM, 5 );
|
||||
|
||||
label = new wxStaticText( this, wxID_ANY, wxGetTranslation( buttons->m_Name ) );
|
||||
rowBoxSizer->Add( label, 1, wxALIGN_CENTER_VERTICAL | wxRIGHT | wxBOTTOM, 5 );
|
||||
buttonId += 1;
|
||||
buttons++;
|
||||
}
|
||||
|
||||
groups++;
|
||||
}
|
||||
|
||||
Connect( 1800, buttonId - 1, wxEVT_COMMAND_BUTTON_CLICKED,
|
||||
wxCommandEventHandler( WIDGET_COLOR_CONFIG::SetColor ) );
|
||||
|
||||
wxArrayString selBgColorStrings;
|
||||
selBgColorStrings.Add( _( "White" ) );
|
||||
selBgColorStrings.Add( _( "Black" ) );
|
||||
m_SelBgColor = new wxRadioBox( this, wxID_ANY, _( "Background Color" ),
|
||||
wxDefaultPosition, wxDefaultSize,
|
||||
selBgColorStrings, 1, wxRA_SPECIFY_COLS );
|
||||
m_SelBgColor->SetSelection( ( GetDrawFrame()->GetDrawBgColor() == BLACK ) ? 1 : 0 );
|
||||
|
||||
if( columnBoxSizer )
|
||||
{
|
||||
// Add a spacer to improve appearance.
|
||||
columnBoxSizer->AddSpacer( 5 );
|
||||
columnBoxSizer->Add( m_SelBgColor, 1, wxGROW | wxRIGHT | wxTOP | wxBOTTOM, 5 );
|
||||
}
|
||||
|
||||
currentColors[ LAYER_BACKGROUND ] = GetDrawFrame()->GetDrawBgColor();
|
||||
|
||||
// Dialog now needs to be resized, but the associated command is found elsewhere.
|
||||
}
|
||||
|
||||
|
||||
void WIDGET_COLOR_CONFIG::SetColor( wxCommandEvent& event )
|
||||
{
|
||||
wxBitmapButton* button = (wxBitmapButton*) event.GetEventObject();
|
||||
|
||||
wxCHECK_RET( button != NULL, wxT( "Color button event object is NULL." ) );
|
||||
|
||||
COLORBUTTON* colorButton = (COLORBUTTON*) button->GetClientData();
|
||||
|
||||
wxCHECK_RET( colorButton != NULL, wxT( "Client data not set for color button." ) );
|
||||
|
||||
EDA_COLOR_T color = DisplayColorFrame( this, colorButton->m_Layer );
|
||||
|
||||
if( color < 0 || currentColors[ colorButton->m_Layer ] == color )
|
||||
return;
|
||||
|
||||
currentColors[ colorButton->m_Layer ] = color;
|
||||
|
||||
wxMemoryDC iconDC;
|
||||
|
||||
wxBitmap bitmap = button->GetBitmapLabel();
|
||||
iconDC.SelectObject( bitmap );
|
||||
iconDC.SetPen( *wxBLACK_PEN );
|
||||
|
||||
wxBrush brush;
|
||||
|
||||
ColorSetBrush( &brush, color);
|
||||
|
||||
brush.SetStyle( wxBRUSHSTYLE_SOLID );
|
||||
|
||||
iconDC.SetBrush( brush );
|
||||
iconDC.DrawRectangle( 0, 0, BUTT_SIZE_X, BUTT_SIZE_Y );
|
||||
button->SetBitmapLabel( bitmap );
|
||||
button->Refresh();
|
||||
|
||||
Refresh( false );
|
||||
}
|
||||
|
||||
|
||||
bool WIDGET_COLOR_CONFIG::TransferDataFromControl()
|
||||
{
|
||||
bool warning = false;
|
||||
|
||||
// Check for color conflicts with background color to give user a chance to bail
|
||||
// out before making changes.
|
||||
|
||||
EDA_COLOR_T bgcolor = WHITE;
|
||||
|
||||
if( m_SelBgColor->GetSelection() > 0 )
|
||||
bgcolor = BLACK;
|
||||
|
||||
for( LAYERSCH_ID clyr = LAYER_WIRE; clyr < LAYERSCH_ID_COUNT; ++clyr )
|
||||
{
|
||||
if( bgcolor == currentColors[ clyr ] && clyr != LAYER_BACKGROUND )
|
||||
{
|
||||
warning = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// Prompt the user if an item has the same color as the background
|
||||
// because this item cannot be seen:
|
||||
if( warning )
|
||||
{
|
||||
if( wxMessageBox( _( "Some items have the same color as the background\n"
|
||||
"and they will not be seen on the screen. Are you\n"
|
||||
"sure you want to use these colors?" ),
|
||||
_( "Warning" ),
|
||||
wxYES_NO | wxICON_QUESTION, this ) == wxNO )
|
||||
return false;
|
||||
}
|
||||
|
||||
// Update color of background
|
||||
GetDrawFrame()->SetDrawBgColor( bgcolor );
|
||||
currentColors[ LAYER_BACKGROUND ] = bgcolor;
|
||||
|
||||
|
||||
for( LAYERSCH_ID clyr = LAYER_WIRE; clyr < LAYERSCH_ID_COUNT; ++clyr )
|
||||
{
|
||||
SetLayerColor( currentColors[ clyr ], clyr );
|
||||
}
|
||||
|
||||
GetDrawFrame()->SetGridColor( GetLayerColor( LAYER_GRID ) );
|
||||
GetDrawFrame()->GetCanvas()->Refresh();
|
||||
|
||||
return true;
|
||||
}
|
|
@ -0,0 +1,61 @@
|
|||
/*
|
||||
* This program source code file is part of KiCad, a free EDA CAD application.
|
||||
*
|
||||
* Copyright (C) 2007 G. Harland
|
||||
* Copyright (C) 1992-2016 KiCad Developers, see CHANGELOG.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 WIDGET_COLOR_CONFIG_H_
|
||||
#define WIDGET_COLOR_CONFIG_H_
|
||||
|
||||
#include <wx/panel.h>
|
||||
#include <wx/sizer.h>
|
||||
|
||||
class wxBoxSizer;
|
||||
class wxStaticLine;
|
||||
class wxStdDialogButtonSizer;
|
||||
|
||||
|
||||
/***********************************************/
|
||||
/* Derived class for the frame color settings. */
|
||||
/***********************************************/
|
||||
|
||||
class WIDGET_COLOR_CONFIG : public wxPanel
|
||||
{
|
||||
private:
|
||||
EDA_DRAW_FRAME* m_drawFrame;
|
||||
wxRadioBox* m_SelBgColor;
|
||||
wxBoxSizer* m_mainBoxSizer;
|
||||
|
||||
// Creates the controls and sizers
|
||||
void CreateControls();
|
||||
|
||||
void SetColor( wxCommandEvent& aEvent );
|
||||
|
||||
virtual EDA_DRAW_FRAME* GetDrawFrame() { return m_drawFrame; }
|
||||
|
||||
public:
|
||||
// Constructors and destructor
|
||||
WIDGET_COLOR_CONFIG( wxWindow* aParent, EDA_DRAW_FRAME* aDrawFrame );
|
||||
|
||||
bool TransferDataFromControl();
|
||||
};
|
||||
|
||||
#endif // WIDGET_COLOR_CONFIG_H_
|
Loading…
Reference in New Issue