/////////////////////////////////////////////////////////////////////////////////
//
// This file is part of SACAMOS, cable models for EMI simulations in SPICE.
// It was developed by the University of Nottingham and the Netherlands Aerospace
// Centre (NLR) for ESA under contract number 4000112765/14/NL/HK.
//
// Copyright (C) 2015 - 2018 University of Nottingham
//
// SACAMOS 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.
//
// SACAMOS 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.
//
// A copy of the GNU General Public License version 3 can be found in the
// file GNU_GPL_v3 in the root or at .
//
// wxWidgets is currently licenced under the "wxWindows Library Licence".
// A copy of the wxWindows Library Licence, Version 3.1 can be found in the file
// wxWindows_Library_Licence_v3-1 in the root or at:
//
//
// The University of Nottingham can be contacted at: ggiemr@nottingham.ac.uk
//
// File Contents:
//
// NAME
// DCONN.cpp
//
// DESCRIPTION
// GUI for the construction of cable_spec file for cable type: Dconnector
//
// AUTHOR(S)
// Steve Greedy
//
/////////////////////////////////////////////////////////////////////////////////
#include "DCONN.h"
//(*InternalHeaders(DCONN)
#include
#include
#include
//*)
//(*IdInit(DCONN)
const long DCONN::ID_STATICTEXT1 = wxNewId();
const long DCONN::ID_TEXTCTRL1 = wxNewId();
const long DCONN::ID_STATICTEXT2 = wxNewId();
const long DCONN::ID_TEXTCTRL2 = wxNewId();
const long DCONN::ID_STATICTEXT3 = wxNewId();
const long DCONN::ID_TEXTCTRL3 = wxNewId();
const long DCONN::ID_STATICTEXT4 = wxNewId();
const long DCONN::ID_TEXTCTRL4 = wxNewId();
const long DCONN::ID_STATICTEXT5 = wxNewId();
const long DCONN::ID_TEXTCTRL5 = wxNewId();
const long DCONN::ID_STATICTEXT6 = wxNewId();
const long DCONN::ID_CHECKBOX1 = wxNewId();
const long DCONN::ID_STATICTEXT7 = wxNewId();
const long DCONN::ID_COMBOBOX1 = wxNewId();
const long DCONN::ID_STATICTEXT8 = wxNewId();
const long DCONN::ID_CHECKBOX2 = wxNewId();
const long DCONN::ID_BUTTON1 = wxNewId();
const long DCONN::ID_BUTTON2 = wxNewId();
const long DCONN::ID_BUTTON3 = wxNewId();
const long DCONN::ID_PANEL1 = wxNewId();
//*)
BEGIN_EVENT_TABLE(DCONN,wxDialog)
//(*EventTable(DCONN)
//*)
END_EVENT_TABLE()
DCONN::DCONN(wxWindow* parent,wxWindowID id,const wxPoint& pos,const wxSize& size)
{
//(*Initialize(DCONN)
wxStaticBoxSizer* StaticBoxSizer2;
wxFlexGridSizer* FlexGridSizer4;
wxFlexGridSizer* FlexGridSizer3;
wxFlexGridSizer* FlexGridSizer2;
wxBoxSizer* BoxSizer2;
wxStaticBoxSizer* StaticBoxSizer3;
wxBoxSizer* BoxSizer1;
wxStaticBoxSizer* StaticBoxSizer1;
wxFlexGridSizer* FlexGridSizer1;
Create(parent, wxID_ANY, _("SACAMOS: D-SUB CONNECTOR MODEL"), wxDefaultPosition, wxDefaultSize, wxDEFAULT_DIALOG_STYLE, _T("wxID_ANY"));
FlexGridSizer1 = new wxFlexGridSizer(0, 2, 0, 0);
StaticBoxSizer1 = new wxStaticBoxSizer(wxHORIZONTAL, this, _("D-SUB Connector Parameters"));
FlexGridSizer2 = new wxFlexGridSizer(0, 1, 0, 0);
BoxSizer1 = new wxBoxSizer(wxHORIZONTAL);
StaticText1 = new wxStaticText(this, ID_STATICTEXT1, _("Connector Name"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT1"));
BoxSizer1->Add(StaticText1, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
TextCtrl1 = new wxTextCtrl(this, ID_TEXTCTRL1, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_TEXTCTRL1"));
BoxSizer1->Add(TextCtrl1, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
FlexGridSizer2->Add(BoxSizer1, 1, wxALL|wxEXPAND, 5);
StaticBoxSizer3 = new wxStaticBoxSizer(wxHORIZONTAL, this, _("General Properties"));
FlexGridSizer3 = new wxFlexGridSizer(0, 2, 0, 0);
StaticText2 = new wxStaticText(this, ID_STATICTEXT2, _("Conductor Radius"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT2"));
FlexGridSizer3->Add(StaticText2, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
TextCtrl2 = new wxTextCtrl(this, ID_TEXTCTRL2, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_TEXTCTRL2"));
FlexGridSizer3->Add(TextCtrl2, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
StaticText3 = new wxStaticText(this, ID_STATICTEXT3, _("Conductor Separation X (m)"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT3"));
FlexGridSizer3->Add(StaticText3, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
TextCtrl3 = new wxTextCtrl(this, ID_TEXTCTRL3, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_TEXTCTRL3"));
FlexGridSizer3->Add(TextCtrl3, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
StaticText4 = new wxStaticText(this, ID_STATICTEXT4, _("Conductor Separation Y (m)"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT4"));
FlexGridSizer3->Add(StaticText4, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
TextCtrl4 = new wxTextCtrl(this, ID_TEXTCTRL4, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_TEXTCTRL4"));
FlexGridSizer3->Add(TextCtrl4, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
StaticText5 = new wxStaticText(this, ID_STATICTEXT5, _("Shield Offset (m)"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT5"));
FlexGridSizer3->Add(StaticText5, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
TextCtrl5 = new wxTextCtrl(this, ID_TEXTCTRL5, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_TEXTCTRL5"));
FlexGridSizer3->Add(TextCtrl5, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
StaticBoxSizer3->Add(FlexGridSizer3, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
FlexGridSizer2->Add(StaticBoxSizer3, 0, wxALL|wxEXPAND, 5);
FlexGridSizer4 = new wxFlexGridSizer(0, 2, 0, 0);
StaticText6 = new wxStaticText(this, ID_STATICTEXT6, _("Use Laplace"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT6"));
FlexGridSizer4->Add(StaticText6, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
CheckBox1 = new wxCheckBox(this, ID_CHECKBOX1, _("Yes"), wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_CHECKBOX1"));
CheckBox1->SetValue(true);
CheckBox1->Disable();
FlexGridSizer4->Add(CheckBox1, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
StaticText7 = new wxStaticText(this, ID_STATICTEXT7, _("View Mesh"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT7"));
FlexGridSizer4->Add(StaticText7, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
ComboBox1 = new wxComboBox(this, ID_COMBOBOX1, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0, 0, 0, wxDefaultValidator, _T("ID_COMBOBOX1"));
FlexGridSizer4->Add(ComboBox1, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
StaticText8 = new wxStaticText(this, ID_STATICTEXT8, _("Refine Laplace Mesh"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT8"));
FlexGridSizer4->Add(StaticText8, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
CheckBox2 = new wxCheckBox(this, ID_CHECKBOX2, _("Yes"), wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_CHECKBOX2"));
CheckBox2->SetValue(false);
CheckBox2->Disable();
FlexGridSizer4->Add(CheckBox2, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
FlexGridSizer2->Add(FlexGridSizer4, 1, wxALL|wxEXPAND, 5);
BoxSizer2 = new wxBoxSizer(wxHORIZONTAL);
Button1 = new wxButton(this, ID_BUTTON1, _("SAVE"), wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_BUTTON1"));
BoxSizer2->Add(Button1, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
Button2 = new wxButton(this, ID_BUTTON2, _("BUILD"), wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_BUTTON2"));
BoxSizer2->Add(Button2, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
Button3 = new wxButton(this, ID_BUTTON3, _("CLOSE"), wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_BUTTON3"));
BoxSizer2->Add(Button3, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
FlexGridSizer2->Add(BoxSizer2, 1, wxALL|wxEXPAND, 5);
StaticBoxSizer1->Add(FlexGridSizer2, 1, wxALL|wxEXPAND, 5);
FlexGridSizer1->Add(StaticBoxSizer1, 1, wxALL|wxEXPAND, 5);
StaticBoxSizer2 = new wxStaticBoxSizer(wxHORIZONTAL, this, _("Cross Section"));
Panel1 = new wxPanel(this, ID_PANEL1, wxDefaultPosition, wxSize(500,500), wxTAB_TRAVERSAL, _T("ID_PANEL1"));
Panel1->SetBackgroundColour(wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW));
Panel1->SetToolTip(_("Double Click to Reset Schematic"));
StaticBoxSizer2->Add(Panel1, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
FlexGridSizer1->Add(StaticBoxSizer2, 1, wxALL|wxALIGN_TOP|wxALIGN_CENTER_HORIZONTAL, 5);
SetSizer(FlexGridSizer1);
FlexGridSizer1->Fit(this);
FlexGridSizer1->SetSizeHints(this);
Connect(ID_TEXTCTRL2,wxEVT_COMMAND_TEXT_UPDATED,(wxObjectEventFunction)&DCONN::OnTextCtrl2Text);
Connect(ID_TEXTCTRL3,wxEVT_COMMAND_TEXT_UPDATED,(wxObjectEventFunction)&DCONN::OnTextCtrl3Text);
Connect(ID_TEXTCTRL4,wxEVT_COMMAND_TEXT_UPDATED,(wxObjectEventFunction)&DCONN::OnTextCtrl4Text);
Connect(ID_TEXTCTRL5,wxEVT_COMMAND_TEXT_UPDATED,(wxObjectEventFunction)&DCONN::OnTextCtrl5Text);
Connect(ID_COMBOBOX1,wxEVT_COMMAND_COMBOBOX_SELECTED,(wxObjectEventFunction)&DCONN::OnComboBox1Selected);
Connect(ID_CHECKBOX2,wxEVT_COMMAND_CHECKBOX_CLICKED,(wxObjectEventFunction)&DCONN::OnCheckBox2Click);
Connect(ID_BUTTON1,wxEVT_COMMAND_BUTTON_CLICKED,(wxObjectEventFunction)&DCONN::OnButton1Click);
Connect(ID_BUTTON2,wxEVT_COMMAND_BUTTON_CLICKED,(wxObjectEventFunction)&DCONN::OnButton2Click);
Connect(ID_BUTTON3,wxEVT_COMMAND_BUTTON_CLICKED,(wxObjectEventFunction)&DCONN::OnButton3Click);
Panel1->Connect(wxEVT_PAINT,(wxObjectEventFunction)&DCONN::OnPanel1Paint,0,this);
Panel1->Connect(wxEVT_LEFT_DCLICK,(wxObjectEventFunction)&DCONN::OnPanel1LeftDClick,0,this);
Connect(wxID_ANY,wxEVT_INIT_DIALOG,(wxObjectEventFunction)&DCONN::OnInit);
Connect(wxEVT_PAINT,(wxObjectEventFunction)&DCONN::OnPaint);
//*)
}
DCONN::~DCONN()
{
//(*Destroy(DCONN)
//*)
}
void DCONN::OnInit(wxInitDialogEvent& event)
{
TextCtrl2->Bind(wxEVT_SET_FOCUS,(wxObjectEventFunction)&DCONN::OnHighlightSchematic, this);
TextCtrl3->Bind(wxEVT_SET_FOCUS,(wxObjectEventFunction)&DCONN::OnHighlightSchematic, this);
TextCtrl4->Bind(wxEVT_SET_FOCUS,(wxObjectEventFunction)&DCONN::OnHighlightSchematic, this);
TextCtrl5->Bind(wxEVT_SET_FOCUS,(wxObjectEventFunction)&DCONN::OnHighlightSchematic, this);
}
void DCONN::OnPaint(wxPaintEvent& event)
{
if (EDIT_EXISTING==true) EditExistingCable();
}
void DCONN::SetPathToMOD(wxString Path, wxString Name)
{
pathToMOD << Path;
MODname << Name;
}
void DCONN::OnButton1Click(wxCommandEvent& event)
{
int IsError = 0;
wxString fileName = TextCtrl1->GetValue();
TextCtrl1->SetBackgroundColour(wxColor(255,255,255));
if (fileName == "")
{
wxMessageBox("Please Specify a Cable Name" , _("Missing Cable Name"));
return;
}
check_is_empty(TextCtrl2, &IsError);
check_is_empty(TextCtrl3, &IsError);
check_is_empty(TextCtrl4, &IsError);
check_is_empty(TextCtrl5, &IsError);
if (IsError ==1)
{
return;
}
if ( IsError == 1)
{
wxMessageBox("Please fix highlighted errors" , _("Non numeric entry"));
return;
}
WriteCableFile(fileName);
Button1->Disable();
}
void DCONN::OnButton2Click(wxCommandEvent& event)
{
//clean up directory
clean_temp_files();
//CABLE BUIDER
wxString fileName = TextCtrl1->GetValue();
wxString command_line;
wxString separator(wxFileName::GetPathSeparator());
std::stringstream stream;
stream <<"." + separator
<< "cable_model_builder"
<< " "
<< ".." + separator + MODname + separator + "CABLE" + separator
<< fileName ;
command_line << stream.str().c_str();
wxExecute (command_line, wxEXEC_SYNC);;
// Display Run Status
RUN_STATUS *run_status = new RUN_STATUS(this);
run_status->ShowModal();
Button1->Enable();
if (CheckBox1->GetValue())
{
wxString pattern (("*.msh.vtk")) ;
wxString file;
ComboBox1->Clear();
file = wxFindFirstFile(pattern);
while ( !file.empty())
{
wxString meshfile = file;
size_t extindex = meshfile.find_last_of (".");
meshfile = meshfile.substr(0, extindex);
extindex = meshfile.find_last_of (".");
meshfile = meshfile.substr(0, extindex);
meshfile = meshfile.substr(2,meshfile.length());
ComboBox1->Append(meshfile);
file = wxFindNextFile();
}
CheckBox2->Enable();
}
}
void DCONN::OnButton3Click(wxCommandEvent& event)
{
//clean up directory
clean_temp_files();
Close();
}
void DCONN::OnTextCtrl2Text(wxCommandEvent& event)
{
int IsError = 0;
check_is_numeric_list(TextCtrl2, &IsError);
}
void DCONN::OnTextCtrl3Text(wxCommandEvent& event)
{
int IsError = 0;
check_is_numeric_list(TextCtrl3, &IsError);
}
void DCONN::OnTextCtrl4Text(wxCommandEvent& event)
{
int IsError = 0;
check_is_numeric_list(TextCtrl4, &IsError);
}
void DCONN::OnTextCtrl5Text(wxCommandEvent& event)
{
int IsError = 0;
check_is_numeric_list(TextCtrl5, &IsError);
}
void DCONN::WriteCableFile(wxString fileName)
{
ofstream cableFile;
wxString separator(wxFileName::GetPathSeparator());
wxString fullFileName = pathToMOD + separator + "CABLE" + separator + fileName + ".cable_spec";
cableFile.open (fullFileName);
if (cableFile.is_open())
{
// minimum requirements for type Cylindrical
cableFile <<"# MOD_cable_lib_dir \n";
cableFile <<".." << separator << MODname << separator << "CABLE" << separator <<"\n";
cableFile <<"Dconnector\n";
cableFile <<"10 #number of conductors \n";
cableFile <<"4 #number of parameters \n";
cableFile << TextCtrl2->GetValue() <<" # parameter 1: conductor radius\n";
cableFile << TextCtrl3->GetValue() <<" # parameter 2: conductor pitch (separation in x)\n";
cableFile << TextCtrl4->GetValue() <<" # parameter 3: conductor separation in y \n";
cableFile << TextCtrl5->GetValue() <<" # offset from conductors to shell \n";
cableFile <<"0 # number of frequency dependent parameters\n";
cableFile <<"0 # number of transfer impedance models \n";
cableFile <<"use_laplace \n";
}
if (CheckBox2->GetValue())
{
//cableFile << "Laplace_boundary_constant\n";
//cableFile << MESH_PARAM1 <<"\n";
cableFile << "Laplace_surface_mesh_constant\n";
cableFile << MESH_PARAM2 <<"\n";
CheckBox2 ->SetValue(false);
}
cableFile.close();
}
void DCONN::OnPanel1Paint(wxPaintEvent& event)
{
dconnSchematic();
}
void DCONN::dconnSchematic()
{
int size_h, size_v;
Panel1->GetSize(&size_h, &size_v );
float shell_top_x, shell_top_x1, shell_top_y,
shell_bot_x, shell_bot_x1, shell_bot_y;
wxClientDC dc(Panel1);
dc.Clear();
// Draw centre lines
dc.SetPen( wxPen( wxColor(224,224,224),1 , wxDOT_DASH) );
dc.DrawLine( 0, size_v/2, size_h,size_v/2 );
dc.DrawLine( size_h/2, 0, size_h/2, size_v);
dc.SetTextForeground(*wxBLUE);
dc.DrawText("D Connector", 10, 15);
float conductor_radius, conductor_separation_x, conductor_separation_y, shell_offset;
conductor_radius = 0.04 * size_h;
conductor_separation_x = 0.16 * size_h;
conductor_separation_y = 0.16 * size_v;
shell_offset = 0.05 * size_h;
dc.SetPen( wxPen( wxColor(192,192,192),1 ) );
dc.SetBrush(wxBrush(wxColor(224,224,224), wxSOLID));
dc.DrawCircle( wxPoint(size_h/2,size_v/2 - conductor_separation_x/2), conductor_radius );
dc.DrawCircle( wxPoint(size_h/2 - conductor_separation_x,size_v/2 - conductor_separation_y/2), conductor_radius );
dc.DrawCircle( wxPoint(size_h/2 - 2 * conductor_separation_x,size_v/2 - conductor_separation_y/2), conductor_radius );
dc.DrawCircle( wxPoint(size_h/2 + 2 * conductor_separation_x,size_v/2 - conductor_separation_y/2), conductor_radius );
dc.DrawCircle( wxPoint(size_h/2 - conductor_separation_x/2,size_v/2 + conductor_separation_y/2), conductor_radius );
dc.DrawCircle( wxPoint(size_h/2 - 1.5 *conductor_separation_x,size_v/2 + conductor_separation_y/2), conductor_radius );
dc.DrawCircle( wxPoint(size_h/2 + 1.5 *conductor_separation_x,size_v/2 + conductor_separation_y/2), conductor_radius );
dc.SetPen( wxPen( wxColor(192,192,192),4 , wxDOT) );
dc.SetBrush(wxBrush(wxColor(224,224,224), wxSOLID));
dc.DrawLine( size_h/2 + 2 * conductor_radius,size_v/2 - conductor_separation_y/2, size_h/2 + 1.5 * conductor_separation_x,size_v/2 - conductor_separation_y/2 );
dc.DrawLine( size_h/2 + conductor_radius,size_v/2 + conductor_separation_y/2, size_h/2 + conductor_separation_x,size_v/2 + conductor_separation_y/2 );
dc.SetPen( wxPen( wxColor(192,192,192),4) );
shell_top_x = size_h/2 - (2.0 * conductor_separation_x);
shell_top_x1= size_h/2 + (2.0 * conductor_separation_x);
shell_bot_x = size_h/2 - (1.5 * conductor_separation_x);
shell_bot_x1= size_h/2 + (1.5 * conductor_separation_x);
shell_top_y = size_v/2 - conductor_radius - conductor_separation_y/2 - shell_offset;
shell_bot_y= size_v/2 + conductor_radius + conductor_separation_y/2 + shell_offset;
dc.DrawLine( shell_top_x, shell_top_y, shell_top_x1, shell_top_y);
dc.DrawLine( shell_bot_x, shell_bot_y, shell_bot_x1, shell_bot_y);
float theta_rad = atan(0.5* conductor_separation_x/conductor_separation_y);
float theta_deg = 360 * theta_rad/(2.0 * PI);
float x_diff = (conductor_radius + shell_offset) * cos(theta_rad);
float y_diff = (conductor_radius + shell_offset) * sin(theta_rad);
dc.DrawLine((size_h/2 - 2.0 * conductor_separation_x) - x_diff, size_v/2 - conductor_separation_y/2 + y_diff,
(size_h/2 - 1.5 * conductor_separation_x) - x_diff, size_v/2 + conductor_separation_y/2 + y_diff);
dc.DrawLine((size_h/2 + 2.0 * conductor_separation_x) + x_diff, size_v/2 - conductor_separation_y/2 + y_diff,
(size_h/2 + 1.5 * conductor_separation_x) + x_diff, size_v/2 + conductor_separation_y/2 + y_diff);
dc.SetBrush(wxBrush(wxColor(224,224,224), wxTRANSPARENT));
dc.DrawEllipticArc(size_h/2 - 2.0 * conductor_separation_x - conductor_radius - shell_offset, shell_top_y,
2.0 * (conductor_radius + shell_offset), 2.0 * (conductor_radius + shell_offset)
, 90, 180 + theta_deg);
dc.DrawEllipticArc(size_h/2 - 1.5 * conductor_separation_x - conductor_radius - shell_offset, shell_bot_y - 2.0 * (conductor_radius + shell_offset),
2.0 * (conductor_radius + shell_offset), 2.0 * (conductor_radius + shell_offset)
, 180 + theta_deg, 270);
dc.DrawEllipticArc(size_h/2 + 2.0 * conductor_separation_x - conductor_radius - shell_offset, shell_top_y,
2.0 * (conductor_radius + shell_offset), 2.0 * (conductor_radius + shell_offset)
, 0 - theta_deg, 90);
dc.DrawEllipticArc(size_h/2 + 1.5 * conductor_separation_x - conductor_radius - shell_offset, shell_bot_y - 2.0 * (conductor_radius + shell_offset),
2.0 * (conductor_radius + shell_offset), 2.0 * (conductor_radius + shell_offset)
, 270, 360-theta_deg);
}
void DCONN::OnHighlightSchematic(wxCommandEvent& event)
{
dconnSchematic();
int ID = event.GetId();
event.Skip(true);
int size_h, size_v;
Panel1->GetSize(&size_h, &size_v );
float conductor_radius, conductor_separation_x, conductor_separation_y, shell_offset;
conductor_radius = 0.04 * size_h;
conductor_separation_x = 0.16 * size_h;
conductor_separation_y = 0.16 * size_v;
shell_offset = 0.05 * size_h;
float x, y;
wxClientDC dc(Panel1);
wxPoint arrowHead[3];
if ( ID == ID_TEXTCTRL2)
{
x = conductor_radius * 0.7071;
y = conductor_radius * 0.7071;
dc.SetPen(wxPen(wxColor(51,51,255), 3));
dc.SetBrush(wxBrush(wxColor(51,51,255), wxSOLID));
dc.DrawCircle( wxPoint(size_h/2,size_v/2 - conductor_separation_y/2),3 );
dc.DrawLine( size_h/2, size_v/2 - conductor_separation_y/2, size_h/2+x,size_v/2 - conductor_separation_y/2 - y);
arrowHead[0] = wxPoint(size_h/2+x,size_v/2 - conductor_separation_y/2 - y);
arrowHead[1] = wxPoint(size_h/2+x - 5,size_v/2 - conductor_separation_y/2 - y);
arrowHead[2] = wxPoint(size_h/2+x,size_v/2 - conductor_separation_y/2 - y + 5);
dc.DrawPolygon(WXSIZEOF(arrowHead), arrowHead);
}
if ( ID == ID_TEXTCTRL3)
{
dc.SetPen(wxPen(wxColor(51,51,255), 3));
dc.SetBrush(wxBrush(wxColor(51,51,255), wxSOLID));
dc.DrawLine(size_h/2, size_v/2 - conductor_separation_y/2,
size_h/2 - conductor_separation_x, size_v/2 - conductor_separation_y/2);
arrowHead[0] = wxPoint(size_h/2, size_v/2 - conductor_separation_y/2);
arrowHead[1] = wxPoint(size_h/2 - 5, size_v/2 - conductor_separation_y/2 - 5);
arrowHead[2] = wxPoint(size_h/2 - 5, size_v/2 - conductor_separation_y/2 + 5);
dc.DrawPolygon(WXSIZEOF(arrowHead), arrowHead);
arrowHead[0] = wxPoint(size_h/2 - conductor_separation_x, size_v/2 - conductor_separation_y/2);
arrowHead[1] = wxPoint(size_h/2 - conductor_separation_x + 5, size_v/2 - conductor_separation_y/2 - 5);
arrowHead[2] = wxPoint(size_h/2 - conductor_separation_x + 5, size_v/2 - conductor_separation_y/2 + 5);
dc.DrawPolygon(WXSIZEOF(arrowHead), arrowHead);
}
if ( ID == ID_TEXTCTRL4)
{
dc.SetPen(wxPen(wxColor(51,51,255), 3, wxDOT_DASH));
dc.SetBrush(wxBrush(wxColor(51,51,255), wxSOLID));
dc.DrawLine(size_h/2, size_v/2 - conductor_separation_y/2,
size_h/2 - conductor_separation_x, size_v/2 - conductor_separation_y/2);
dc.SetPen(wxPen(wxColor(51,51,255), 3));
dc.DrawLine(size_h/2 - conductor_separation_x/2, size_v/2 + conductor_separation_y/2,
size_h/2 - conductor_separation_x/2, size_v/2 - conductor_separation_y/2);
arrowHead[0] = wxPoint(size_h/2 - conductor_separation_x/2, size_v/2 + conductor_separation_y/2);
arrowHead[1] = wxPoint(size_h/2 - conductor_separation_x/2 - 5, size_v/2 + conductor_separation_y/2 - 5);
arrowHead[2] = wxPoint(size_h/2 - conductor_separation_x/2 + 5, size_v/2 + conductor_separation_y/2 - 5);
dc.DrawPolygon(WXSIZEOF(arrowHead), arrowHead);
arrowHead[0] = wxPoint(size_h/2 - conductor_separation_x/2, size_v/2 - conductor_separation_y/2);
arrowHead[1] = wxPoint(size_h/2 - conductor_separation_x/2 - 5, size_v/2 - conductor_separation_y/2 + 5);
arrowHead[2] = wxPoint(size_h/2 - conductor_separation_x/2 + 5, size_v/2 - conductor_separation_y/2 + 5);
dc.DrawPolygon(WXSIZEOF(arrowHead), arrowHead);
}
if ( ID == ID_TEXTCTRL5)
{
dc.SetPen(wxPen(wxColor(51,51,255), 3));
dc.SetBrush(wxBrush(wxColor(51,51,255), wxSOLID));
dc.DrawLine(size_h/2, size_v/2 - conductor_separation_y/2 - conductor_radius,
size_h/2, size_v/2 - conductor_separation_y/2 - conductor_radius - shell_offset);
arrowHead[0] = wxPoint(size_h/2, size_v/2 - conductor_separation_y/2 - conductor_radius);
arrowHead[1] = wxPoint(size_h/2 - 5, size_v/2 - conductor_separation_y/2 - conductor_radius - 5);
arrowHead[2] = wxPoint(size_h/2 + 5, size_v/2 - conductor_separation_y/2 - conductor_radius - 5);
dc.DrawPolygon(WXSIZEOF(arrowHead), arrowHead);
arrowHead[0] = wxPoint(size_h/2, size_v/2 - conductor_separation_y/2 - conductor_radius - shell_offset);
arrowHead[1] = wxPoint(size_h/2 - 5, size_v/2 - conductor_separation_y/2 - conductor_radius - shell_offset + 5);
arrowHead[2] = wxPoint(size_h/2 + 5, size_v/2 - conductor_separation_y/2 - conductor_radius - shell_offset + 5);
dc.DrawPolygon(WXSIZEOF(arrowHead), arrowHead);
}
}
void DCONN::OnPanel1LeftDClick(wxMouseEvent& event)
{
dconnSchematic();
}
void DCONN::OnComboBox1Selected(wxCommandEvent& event)
{
wxString meshToView;
meshToView<GetValue();
draw_mesh(Panel1,meshToView, scale);
}
void DCONN::OnCheckBox2Click(wxCommandEvent& event)
{
if (CheckBox2->GetValue())
{
MESH_PARAM *winMESH_PARAM = new MESH_PARAM(this);
winMESH_PARAM->TextCtrl1->Disable();
winMESH_PARAM->TextCtrl3->Disable();
winMESH_PARAM->TextCtrl4->Disable();
if ( winMESH_PARAM->ShowModal() == wxID_OK )
{
MESH_PARAM2 = winMESH_PARAM->TextCtrl2->GetValue();
}
winMESH_PARAM->Destroy();
}
WriteCableFile (TextCtrl1->GetValue());
}
void DCONN::EditExistingCable()
{
Close();
}