/* * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2011-2014 Jean-Pierre Charras * Copyright (C) 2004-2021 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 <http://www.gnu.org/licenses/>. */ /** * @file UnitSelector.cpp * a wxChoiceBox to select units in Pcb_Calculator */ #include "unit_selector.h" #include "units_scales.h" UNIT_SELECTOR_LEN::UNIT_SELECTOR_LEN( wxWindow *parent, wxWindowID id, const wxPoint& pos, const wxSize& size, const wxArrayString& choices, long style ) : UNIT_SELECTOR( parent, id, pos, size, choices, style ) { Append( _( "mm" ) ); Append( _( "um" ) ); Append( _( "cm" ) ); Append( _( "mil" ) ); Append( _( "inch" ) ); } /* * Function GetUnitScale * return the scaling factor to convert users units * to normalized units (meter) */ double UNIT_SELECTOR_LEN::GetUnitScale() { switch( GetCurrentSelection() ) { case 0: return UNIT_MM; break; case 1: return UNIT_MICRON; break; case 2: return UNIT_CM; break; case 3: return UNIT_MIL; break; case 4: return UNIT_INCH; break; } return 1.0; } UNIT_SELECTOR_THICKNESS::UNIT_SELECTOR_THICKNESS( wxWindow *parent, wxWindowID id, const wxPoint& pos, const wxSize& size, const wxArrayString& choices, long style ) : UNIT_SELECTOR( parent, id, pos, size, choices, style ) { Append( wxT( "mm" ) ); Append( wxT( "µm" ) ); Append( wxT( "cm" ) ); Append( wxT( "mil" ) ); Append( wxT( "inch" ) ); Append( wxT( "oz/ft²" ) ); } /* * Function GetUnitScale * return the scaling factor to convert users units * to normalized units (meter) including copper oz/ft^2 */ double UNIT_SELECTOR_THICKNESS::GetUnitScale() { switch( GetCurrentSelection() ) { case 0: return UNIT_MM; break; case 1: return UNIT_MICRON; break; case 2: return UNIT_CM; break; case 3: return UNIT_MIL; break; case 4: return UNIT_INCH; break; case 5: return UNIT_OZSQFT; break; } return 1.0; } UNIT_SELECTOR_FREQUENCY::UNIT_SELECTOR_FREQUENCY( wxWindow *parent, wxWindowID id, const wxPoint& pos, const wxSize& size, const wxArrayString& choices, long style ): UNIT_SELECTOR( parent, id, pos, size, choices, style ) { Append( _( "GHz" ) ); Append( _( "MHz" ) ); Append( _( "kHz" ) ); Append( _( "Hz" ) ); } /* * Function GetUnitScale * return the scaling factor to convert users units * to normalized units (herz ) */ double UNIT_SELECTOR_FREQUENCY::GetUnitScale() { switch( GetCurrentSelection() ) { case 0: return UNIT_GHZ; case 1: return UNIT_MHZ; case 2: return UNIT_KHZ; case 3: return 1.0; } return 1.0; } UNIT_SELECTOR_ANGLE::UNIT_SELECTOR_ANGLE( wxWindow *parent, wxWindowID id, const wxPoint& pos, const wxSize& size, const wxArrayString& choices, long style ) : UNIT_SELECTOR( parent, id, pos, size, choices, style ) { Append( _( "rad" ) ); Append( _( "deg" ) ); } /* * Function GetUnitScale * return the scaling factor to convert users units * to normalized units ( radian ) */ double UNIT_SELECTOR_ANGLE::GetUnitScale() { switch( GetCurrentSelection() ) { case 0: return UNIT_RADIAN; break; case 1: return UNIT_DEGREE; break; } return 1.0; } UNIT_SELECTOR_RESISTOR::UNIT_SELECTOR_RESISTOR( wxWindow *parent, wxWindowID id, const wxPoint& pos, const wxSize& size, const wxArrayString& choices, long style ) : UNIT_SELECTOR( parent, id, pos, size, choices, style ) { Append( wxT( "Ω" ) ); Append( wxT( "kΩ" ) ); } /* * Function GetUnitScale * return the scaling factor to convert users units * to normalized units ( ohm ) */ double UNIT_SELECTOR_RESISTOR::GetUnitScale() { switch( GetCurrentSelection() ) { case 0: return UNIT_OHM; break; case 1: return UNIT_KOHM; break; } return 1.0; }