diff --git a/pcb_calculator/CMakeLists.txt b/pcb_calculator/CMakeLists.txt index 99b0f78f9e..f58e348d27 100644 --- a/pcb_calculator/CMakeLists.txt +++ b/pcb_calculator/CMakeLists.txt @@ -22,6 +22,8 @@ set( PCB_CALCULATOR_SRCS calculator_panels/panel_cable_size_base.cpp calculator_panels/panel_color_code.cpp calculator_panels/panel_color_code_base.cpp + calculator_panels/panel_corrosion.cpp + calculator_panels/panel_corrosion_base.cpp calculator_panels/panel_electrical_spacing.cpp calculator_panels/panel_electrical_spacing_base.cpp calculator_panels/panel_eserie.cpp diff --git a/pcb_calculator/calculator_panels/panel_corrosion.cpp b/pcb_calculator/calculator_panels/panel_corrosion.cpp new file mode 100644 index 0000000000..da89142dca --- /dev/null +++ b/pcb_calculator/calculator_panels/panel_corrosion.cpp @@ -0,0 +1,153 @@ +/* + * This program source code file is part of KICAD, a free EDA CAD application. + * + * Copyright (C) 1992-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 3 + * 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, see . + */ + +#include +#include + +#define CORROSION_VOLTAGE_1 0.3 +#define CORROSION_VOLTAGE_2 0.5 +#define CORROSION_VOLTAGE_3 0.8 + + +CORROSION_TABLE_ENTRY::CORROSION_TABLE_ENTRY( wxString aName, wxString aSymbol, double aPot ) +{ + m_potential = aPot; + m_name = aName; + m_symbol = aSymbol; +} + +PANEL_CORROSION::PANEL_CORROSION( wxWindow* parent, wxWindowID id, const wxPoint& pos, + const wxSize& size, long style, const wxString& name ) : + PANEL_CORROSION_BASE( parent, id, pos, size, style, name ) +{ + m_entries.clear(); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Platinum" ), "Pt", -0.57 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Gold" ), "Au", -0.44 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Titanium" ), "Ti", -0.32 ) ); + m_entries.push_back( + CORROSION_TABLE_ENTRY( wxT( "Stainless steel 18-9" ), "X8CrNiS18-9", -0.32 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Silver" ), "Ag", -0.22 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Mercury" ), "Hg", -0.22 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Nickel" ), "Ni", -0.14 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Copper" ), "Cu", 0.0 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Copper-Aluminium" ), "CuAl10", 0.03 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Brass" ), "CuZn39Pb", 0.08 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Bronze" ), "CuSn12", 0.2 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Tin" ), "CuSn12", 0.23 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Lead" ), "Pb", 0.27 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Aluminium-Copper" ), "AlCu4Mg", 0.37 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Cast iron" ), "", 0.38 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Carbon steel" ), "", 0.43 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Aluminium" ), "Al", 0.52 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Cadmium" ), "Al", 0.53 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Iron" ), "Fe", 0.535 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Chrome" ), "Fe", 0.63 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Zinc" ), "Zn", 0.83 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Manganese" ), "Mn", 0.9 ) ); + m_entries.push_back( CORROSION_TABLE_ENTRY( wxT( "Magnesium" ), "Mg", 1.38 ) ); + + // Resize the table + + m_table->DeleteCols( 0, m_table->GetNumberCols() ); + m_table->DeleteRows( 0, m_table->GetNumberRows() ); + m_table->AppendCols( m_entries.size() ); + m_table->AppendRows( m_entries.size() ); + + // Fill the table with data + int i = 0; + + wxColour color_ok( 189, 255, 189 ); + wxColour color_w1( 255, 255, 157 ); + wxColour color_w2( 250, 191, 9 ); + wxColour color_w3( 255, 83, 83 ); + + wxColour color_text( 0, 0, 0 ); + wxString value; + + + for( CORROSION_TABLE_ENTRY entryA : m_entries ) + { + int j = 0; + + wxString label = entryA.m_name; + + if( entryA.m_symbol.size() > 0 ) + { + label += " (" + entryA.m_symbol + ")"; + } + m_table->SetRowLabelValue( i, label ); + m_table->SetColLabelValue( i, label ); + + for( CORROSION_TABLE_ENTRY entryB : m_entries ) + { + double diff = entryA.m_potential - entryB.m_potential; + value = ""; + value << diff * 1000; // Let's display it in mV instead of V. + m_table->SetCellValue( i, j, value ); + + // Overide anything that could come from a dark them + m_table->SetCellTextColour( i, j, color_text ); + + if( abs( diff ) > CORROSION_VOLTAGE_3 ) + { + m_table->SetCellBackgroundColour( i, j, color_w3 ); + } + else if( abs( diff ) > CORROSION_VOLTAGE_2 ) + { + m_table->SetCellBackgroundColour( i, j, color_w2 ); + } + else if( abs( diff ) > CORROSION_VOLTAGE_1 ) + { + m_table->SetCellBackgroundColour( i, j, color_w1 ); + } + else + { + m_table->SetCellBackgroundColour( i, j, color_ok ); + } + j++; + } + i++; + } + + m_table->SetColLabelTextOrientation( wxVERTICAL ); + + m_table->SetColLabelSize( wxGRID_AUTOSIZE ); + m_table->SetRowLabelSize( wxGRID_AUTOSIZE ); + m_table->AutoSizeColumns(); + m_table->AutoSizeRows(); +} + + +PANEL_CORROSION::~PANEL_CORROSION() +{ +} + +void PANEL_CORROSION::ThemeChanged() +{ +} + + +void PANEL_CORROSION::LoadSettings( PCB_CALCULATOR_SETTINGS* aCfg ) +{ +} + + +void PANEL_CORROSION::SaveSettings( PCB_CALCULATOR_SETTINGS* aCfg ) +{ +} diff --git a/pcb_calculator/calculator_panels/panel_corrosion.h b/pcb_calculator/calculator_panels/panel_corrosion.h new file mode 100644 index 0000000000..8d40d83de2 --- /dev/null +++ b/pcb_calculator/calculator_panels/panel_corrosion.h @@ -0,0 +1,55 @@ +/* + * This program source code file is part of KICAD, a free EDA CAD application. + * + * Copyright (C) 1992-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 3 + * 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, see . + */ + +#ifndef PANEL_CORROSION_H +#define PANEL_CORROSION_H + +#include "panel_corrosion_base.h" +#include + +class PCB_CALCULATOR_SETTINGS; + +class CORROSION_TABLE_ENTRY +{ +public: + CORROSION_TABLE_ENTRY( wxString aName, wxString aSymbol, double aPot ); + /** @brief Translatable name ( Copper ) */ + wxString m_name; + /** @brief Chemical symbol (Cu), not translatable */ + wxString m_symbol; + /** @brief potential in volts, relative to copper */ + double m_potential; +}; + +class PANEL_CORROSION : public PANEL_CORROSION_BASE +{ +public: + PANEL_CORROSION( wxWindow* parent, wxWindowID id = wxID_ANY, + const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, + long style = wxTAB_TRAVERSAL, const wxString& name = wxEmptyString ); + ~PANEL_CORROSION(); + + std::vector m_entries; + // Methods from CALCULATOR_PANEL that must be overriden + void LoadSettings( PCB_CALCULATOR_SETTINGS* aCfg ) override; + void SaveSettings( PCB_CALCULATOR_SETTINGS* aCfg ) override; + void ThemeChanged() override; +}; + +#endif diff --git a/pcb_calculator/calculator_panels/panel_corrosion_base.cpp b/pcb_calculator/calculator_panels/panel_corrosion_base.cpp new file mode 100644 index 0000000000..c95d84eaba --- /dev/null +++ b/pcb_calculator/calculator_panels/panel_corrosion_base.cpp @@ -0,0 +1,65 @@ +/////////////////////////////////////////////////////////////////////////// +// C++ code generated with wxFormBuilder (version 3.10.0-4761b0c5) +// http://www.wxformbuilder.org/ +// +// PLEASE DO *NOT* EDIT THIS FILE! +/////////////////////////////////////////////////////////////////////////// + +#include "panel_corrosion_base.h" + +/////////////////////////////////////////////////////////////////////////// + +PANEL_CORROSION_BASE::PANEL_CORROSION_BASE( wxWindow* parent, wxWindowID id, const wxPoint& pos, const wxSize& size, long style, const wxString& name ) : CALCULATOR_PANEL( parent, id, pos, size, style, name ) +{ + wxBoxSizer* bSizer6; + bSizer6 = new wxBoxSizer( wxVERTICAL ); + + m_scrolledWindow1 = new wxScrolledWindow( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxHSCROLL|wxVSCROLL ); + m_scrolledWindow1->SetScrollRate( 5, 5 ); + wxBoxSizer* bSizer7; + bSizer7 = new wxBoxSizer( wxVERTICAL ); + + m_table = new wxGrid( m_scrolledWindow1, wxID_ANY, wxDefaultPosition, wxDefaultSize, 0 ); + + // Grid + m_table->CreateGrid( 1, 1 ); + m_table->EnableEditing( true ); + m_table->EnableGridLines( true ); + m_table->EnableDragGridSize( false ); + m_table->SetMargins( 0, 0 ); + + // Columns + m_table->EnableDragColMove( false ); + m_table->EnableDragColSize( true ); + m_table->SetColLabelValue( 0, _("Copper (Cu)") ); + m_table->SetColLabelAlignment( wxALIGN_CENTER, wxALIGN_CENTER ); + + // Rows + m_table->EnableDragRowSize( true ); + m_table->SetRowLabelValue( 0, _("Copper (Cu)") ); + m_table->SetRowLabelAlignment( wxALIGN_CENTER, wxALIGN_CENTER ); + + // Label Appearance + + // Cell Defaults + m_table->SetDefaultCellAlignment( wxALIGN_LEFT, wxALIGN_TOP ); + bSizer7->Add( m_table, 1, wxALL|wxEXPAND, 5 ); + + + m_scrolledWindow1->SetSizer( bSizer7 ); + m_scrolledWindow1->Layout(); + bSizer7->Fit( m_scrolledWindow1 ); + bSizer6->Add( m_scrolledWindow1, 1, wxEXPAND | wxALL, 5 ); + + m_staticText16 = new wxStaticText( this, wxID_ANY, _("When two metals are in contact, there will be a potential difference between them that will lead to corrosion.\nIn order to avoid corrosion, it is good practice to keep the difference below 300mV.\n\nOne of the metal will be anodic (+) and will be attacked. The other one will be cathodic and will be protected.\nIn the table below, if the number is positive then the row is anodic and the column is cathodic. \n\nYou can use an interface metal, just like with the ENIG surface finish that uses nickel as an interface between gold and copper to prevent corrosion."), wxDefaultPosition, wxDefaultSize, 0 ); + m_staticText16->Wrap( -1 ); + bSizer6->Add( m_staticText16, 0, wxALL, 5 ); + + + this->SetSizer( bSizer6 ); + this->Layout(); +} + +PANEL_CORROSION_BASE::~PANEL_CORROSION_BASE() +{ +} diff --git a/pcb_calculator/calculator_panels/panel_corrosion_base.fbp b/pcb_calculator/calculator_panels/panel_corrosion_base.fbp new file mode 100644 index 0000000000..0b3212248f --- /dev/null +++ b/pcb_calculator/calculator_panels/panel_corrosion_base.fbp @@ -0,0 +1,277 @@ + + + + + + C++ + 1 + source_name + 0 + 0 + res + UTF-8 + connect + panel_corrosion_base + 1000 + none + + + 1 + panel_corrosion_base + + . + + 1 + 1 + 1 + 1 + UI + 0 + 0 + 0 + + 0 + wxAUI_MGR_DEFAULT + + + 1 + 1 + impl_virtual + + + 0 + wxID_ANY + + + PANEL_CORROSION_BASE + + 677,453 + CALCULATOR_PANEL; calculator_panels/calculator_panel.h; + + 0 + + + wxTAB_TRAVERSAL + + + bSizer6 + wxVERTICAL + none + + 5 + wxEXPAND | wxALL + 1 + + 1 + 1 + 1 + 1 + + + + + + + + 1 + 0 + 1 + + 1 + 0 + Dock + 0 + Left + 1 + + 1 + + 0 + 0 + wxID_ANY + + 0 + + + 0 + + 1 + m_scrolledWindow1 + 1 + + + protected + 1 + + Resizable + 5 + 5 + 1 + + ; ; forward_declare + 0 + + + + wxHSCROLL|wxVSCROLL + + + bSizer7 + wxVERTICAL + none + + 5 + wxALL|wxEXPAND + 1 + + 1 + 1 + 1 + 1 + + + + + 0 + 0 + + + + 1 + + + wxALIGN_LEFT + + wxALIGN_TOP + 0 + 1 + wxALIGN_CENTER + + "Copper (Cu)" + wxALIGN_CENTER + 1 + + + 1 + 0 + Dock + 0 + Left + 0 + 1 + 0 + 1 + 1 + 1 + + 1 + + + 1 + 0 + 0 + wxID_ANY + + + + 0 + 0 + + 0 + + + 0 + + 1 + m_table + 1 + + + protected + 1 + + Resizable + wxALIGN_CENTER + + "Copper (Cu)" + wxALIGN_CENTER + + 1 + 1 + + ; ; forward_declare + 0 + + + + + + + + + + + 5 + wxALL + 0 + + 1 + 1 + 1 + 1 + + + + + + + + 1 + 0 + 1 + + 1 + 0 + Dock + 0 + Left + 1 + + 1 + + 0 + 0 + wxID_ANY + When two metals are in contact, there will be a potential difference between them that will lead to corrosion. In order to avoid corrosion, it is good practice to keep the difference below 300mV. One of the metal will be anodic (+) and will be attacked. The other one will be cathodic and will be protected. In the table below, if the number is positive then the row is anodic and the column is cathodic. You can use an interface metal, just like with the ENIG surface finish that uses nickel as an interface between gold and copper to prevent corrosion. + 0 + + 0 + + + 0 + + 1 + m_staticText16 + 1 + + + protected + 1 + + Resizable + 1 + + + ; ; forward_declare + 0 + + + + + -1 + + + + + + diff --git a/pcb_calculator/calculator_panels/panel_corrosion_base.h b/pcb_calculator/calculator_panels/panel_corrosion_base.h new file mode 100644 index 0000000000..ef6288e59e --- /dev/null +++ b/pcb_calculator/calculator_panels/panel_corrosion_base.h @@ -0,0 +1,47 @@ +/////////////////////////////////////////////////////////////////////////// +// C++ code generated with wxFormBuilder (version 3.10.0-4761b0c5) +// http://www.wxformbuilder.org/ +// +// PLEASE DO *NOT* EDIT THIS FILE! +/////////////////////////////////////////////////////////////////////////// + +#pragma once + +#include +#include +#include +#include "calculator_panels/calculator_panel.h" +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +/////////////////////////////////////////////////////////////////////////// + + +/////////////////////////////////////////////////////////////////////////////// +/// Class PANEL_CORROSION_BASE +/////////////////////////////////////////////////////////////////////////////// +class PANEL_CORROSION_BASE : public CALCULATOR_PANEL +{ + private: + + protected: + wxScrolledWindow* m_scrolledWindow1; + wxGrid* m_table; + wxStaticText* m_staticText16; + + public: + + PANEL_CORROSION_BASE( wxWindow* parent, wxWindowID id = wxID_ANY, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxSize( 677,453 ), long style = wxTAB_TRAVERSAL, const wxString& name = wxEmptyString ); + + ~PANEL_CORROSION_BASE(); + +}; + diff --git a/pcb_calculator/pcb_calculator_frame.cpp b/pcb_calculator/pcb_calculator_frame.cpp index 36706eb3f1..8b699b2534 100644 --- a/pcb_calculator/pcb_calculator_frame.cpp +++ b/pcb_calculator/pcb_calculator_frame.cpp @@ -36,6 +36,7 @@ #include #include #include +#include #include #include #include @@ -114,6 +115,8 @@ PCB_CALCULATOR_FRAME::PCB_CALCULATOR_FRAME( KIWAY* aKiway, wxWindow* aParent ) : _( "Color Code" ) ); AddCalculator( new PANEL_BOARD_CLASS( m_treebook, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL ), _("Board Classes") ); + AddCalculator( new PANEL_CORROSION( m_treebook, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL ), + _( "Galvanic corrosion" ) ); LoadSettings( config() );