/* * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2023 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 #include #include #include #include #include PANEL_SETUP_TUNING_PATTERNS::PANEL_SETUP_TUNING_PATTERNS( wxWindow* aParent, EDA_DRAW_FRAME* aFrame, PNS::MEANDER_SETTINGS& aTrackSettings, PNS::MEANDER_SETTINGS& aDiffPairSettings, PNS::MEANDER_SETTINGS& aSkewSettings ) : PANEL_SETUP_TUNING_PATTERNS_BASE( aParent ), m_track_minA( aFrame, m_track_minALabel, m_track_minACtrl, m_track_minAUnits ), m_track_maxA( aFrame, m_track_maxALabel, m_track_maxACtrl, m_track_maxAUnits ), m_track_spacing( aFrame, m_track_spacingLabel, m_track_spacingCtrl, m_track_spacingUnits ), m_track_r( aFrame, m_track_rLabel, m_track_rCtrl, m_track_rUnits ), m_dp_minA( aFrame, m_dp_minALabel, m_dp_minACtrl, m_dp_minAUnits ), m_dp_maxA( aFrame, m_dp_maxALabel, m_dp_maxACtrl, m_dp_maxAUnits ), m_dp_spacing( aFrame, m_dp_spacingLabel, m_dp_spacingCtrl, m_dp_spacingUnits ), m_dp_r( aFrame, m_dp_rLabel, m_dp_rCtrl, m_dp_rUnits ), m_skew_minA( aFrame, m_skew_minALabel, m_skew_minACtrl, m_skew_minAUnits ), m_skew_maxA( aFrame, m_skew_maxALabel, m_skew_maxACtrl, m_skew_maxAUnits ), m_skew_spacing( aFrame, m_skew_spacingLabel, m_skew_spacingCtrl, m_skew_spacingUnits ), m_skew_r( aFrame, m_skew_rLabel, m_skew_rCtrl, m_skew_rUnits ), m_trackSettings( aTrackSettings ), m_dpSettings( aDiffPairSettings ), m_skewSettings( aSkewSettings ) { m_singleTrackLegend->SetBitmap( KiBitmapBundle( BITMAPS::tune_single_track_length_legend ) ); m_diffPairLegend->SetBitmap( KiBitmapBundle( BITMAPS::tune_diff_pair_length_legend ) ); m_skewLegend->SetBitmap( KiBitmapBundle( BITMAPS::tune_diff_pair_skew_legend ) ); m_track_r.SetUnits( EDA_UNITS::PERCENT ); m_dp_r.SetUnits( EDA_UNITS::PERCENT ); m_skew_r.SetUnits( EDA_UNITS::PERCENT ); } bool PANEL_SETUP_TUNING_PATTERNS::TransferDataToWindow() { m_track_minA.SetValue( m_trackSettings.m_minAmplitude ); m_track_maxA.SetValue( m_trackSettings.m_maxAmplitude ); m_track_spacing.SetValue( m_trackSettings.m_spacing ); m_track_cornerCtrl->SetSelection( m_trackSettings.m_cornerStyle == PNS::MEANDER_STYLE_ROUND ? 1 : 0 ); m_track_r.SetValue( m_trackSettings.m_cornerRadiusPercentage ); m_track_singleSided->SetValue( m_trackSettings.m_singleSided ); m_dp_minA.SetValue( m_dpSettings.m_minAmplitude ); m_dp_maxA.SetValue( m_dpSettings.m_maxAmplitude ); m_dp_spacing.SetValue( m_dpSettings.m_spacing ); m_dp_cornerCtrl->SetSelection( m_dpSettings.m_cornerStyle == PNS::MEANDER_STYLE_ROUND ? 1 : 0 ); m_dp_r.SetValue( 100 ); m_dp_singleSided->SetValue( m_dpSettings.m_singleSided ); m_skew_minA.SetValue( m_skewSettings.m_minAmplitude ); m_skew_maxA.SetValue( m_skewSettings.m_maxAmplitude ); m_skew_spacing.SetValue( m_skewSettings.m_spacing ); m_skew_cornerCtrl->SetSelection( m_skewSettings.m_cornerStyle == PNS::MEANDER_STYLE_ROUND ? 1 : 0 ); m_skew_r.SetValue( m_skewSettings.m_cornerRadiusPercentage ); return true; } bool PANEL_SETUP_TUNING_PATTERNS::TransferDataFromWindow() { m_trackSettings.m_minAmplitude = m_track_minA.GetIntValue(); m_trackSettings.m_maxAmplitude = m_track_maxA.GetIntValue(); m_trackSettings.m_spacing = m_track_spacing.GetIntValue(); m_trackSettings.m_cornerStyle = m_track_cornerCtrl->GetSelection() ? PNS::MEANDER_STYLE_ROUND : PNS::MEANDER_STYLE_CHAMFER; m_trackSettings.m_cornerRadiusPercentage = m_track_r.GetIntValue(); m_trackSettings.m_singleSided = m_track_singleSided->GetValue(); m_dpSettings.m_minAmplitude = m_dp_minA.GetIntValue(); m_dpSettings.m_maxAmplitude = m_dp_maxA.GetIntValue(); m_dpSettings.m_spacing = m_dp_spacing.GetIntValue(); m_dpSettings.m_cornerStyle = m_dp_cornerCtrl->GetSelection() ? PNS::MEANDER_STYLE_ROUND : PNS::MEANDER_STYLE_CHAMFER; // TODO: fix diff-pair meandering so we can use non-100% radii m_dpSettings.m_cornerRadiusPercentage = 100; m_dpSettings.m_singleSided = m_dp_singleSided->GetValue(); m_skewSettings.m_minAmplitude = m_skew_minA.GetIntValue(); m_skewSettings.m_maxAmplitude = m_skew_maxA.GetIntValue(); m_skewSettings.m_spacing = m_skew_spacing.GetIntValue(); m_skewSettings.m_cornerStyle = m_skew_cornerCtrl->GetSelection() ? PNS::MEANDER_STYLE_ROUND : PNS::MEANDER_STYLE_CHAMFER; m_skewSettings.m_cornerRadiusPercentage = m_skew_r.GetIntValue(); return true; } void PANEL_SETUP_TUNING_PATTERNS::ImportSettingsFrom( BOARD* aBoard ) { PNS::MEANDER_SETTINGS savedTrackSettings = m_trackSettings; PNS::MEANDER_SETTINGS savedDPSettings = m_dpSettings; PNS::MEANDER_SETTINGS savedSkewSettings = m_skewSettings; m_trackSettings = aBoard->GetDesignSettings().m_singleTrackMeanderSettings; m_dpSettings = aBoard->GetDesignSettings().m_diffPairMeanderSettings; m_skewSettings = aBoard->GetDesignSettings().m_skewMeanderSettings; TransferDataToWindow(); m_trackSettings = savedTrackSettings; m_dpSettings = savedDPSettings; m_skewSettings = savedSkewSettings; }