417 lines
11 KiB
C++
417 lines
11 KiB
C++
// PtProp.cpp : implementation file
|
|
//
|
|
|
|
#include "stdafx.h"
|
|
#include "femm.h"
|
|
#include "cdrawDoc.h"
|
|
#include "cd_PtProp.h"
|
|
#include "cd_NodeProp.h"
|
|
#include "cd_MatDlg.h"
|
|
#include "cd_BdryDlg.h"
|
|
#include "cd_CircProp.h"
|
|
|
|
#ifdef _DEBUG
|
|
#define new DEBUG_NEW
|
|
#undef THIS_FILE
|
|
static char THIS_FILE[] = __FILE__;
|
|
#endif
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
// cdCPtProp dialog
|
|
|
|
|
|
cdCPtProp::cdCPtProp(CWnd* pParent /*=NULL*/)
|
|
: CDialog(cdCPtProp::IDD, pParent)
|
|
{
|
|
//{{AFX_DATA_INIT(cdCPtProp)
|
|
// NOTE: the ClassWizard will add member initialization here
|
|
//}}AFX_DATA_INIT
|
|
}
|
|
|
|
|
|
void cdCPtProp::DoDataExchange(CDataExchange* pDX)
|
|
{
|
|
CDialog::DoDataExchange(pDX);
|
|
//{{AFX_DATA_MAP(cdCPtProp)
|
|
DDX_Control(pDX, IDC_NAME_LIST, m_namelist);
|
|
//}}AFX_DATA_MAP
|
|
}
|
|
|
|
|
|
BEGIN_MESSAGE_MAP(cdCPtProp, CDialog)
|
|
//{{AFX_MSG_MAP(cdCPtProp)
|
|
ON_BN_CLICKED(IDC_ADD_PROP, OnAddProp)
|
|
ON_BN_CLICKED(IDC_DEL_PROP, OnDelProp)
|
|
ON_BN_CLICKED(IDC_MOD_PROP, OnModProp)
|
|
//}}AFX_MSG_MAP
|
|
END_MESSAGE_MAP()
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
// cdCPtProp message handlers
|
|
|
|
void cdCPtProp::OnAddProp()
|
|
{
|
|
|
|
// Code to deal with adding a Point Property.
|
|
if (PropType==0){
|
|
CPointProp PProp;
|
|
CArray <CPointProp, CPointProp&> &nodeproplist=*pnodeproplist;
|
|
cdCNodeProp zDlg;
|
|
|
|
for(int nn=0;nn<nodeproplist.GetSize();nn++)
|
|
zDlg.namelist.Add(nodeproplist[nn].PointName);
|
|
nodeproplist.Add(PProp);
|
|
|
|
zDlg.m_vp=PProp.vp;
|
|
zDlg.m_qp=PProp.qp;
|
|
zDlg.m_nodename=PProp.PointName;
|
|
|
|
if(zDlg.DoModal()==IDOK){
|
|
int k=(int) nodeproplist.GetSize()-1;
|
|
nodeproplist[k].PointName=zDlg.m_nodename;
|
|
nodeproplist[k].vp=zDlg.m_vp;
|
|
nodeproplist[k].qp=zDlg.m_qp;
|
|
m_namelist.AddString(nodeproplist[k].PointName);
|
|
m_namelist.SetCurSel(k);
|
|
}
|
|
else nodeproplist.RemoveAt(nodeproplist.GetSize()-1);
|
|
}
|
|
|
|
if (PropType==3){
|
|
CCircuit CProp;
|
|
CArray <CCircuit, CCircuit&> &circproplist=*pcircproplist;
|
|
cdCCircProp zDlg;
|
|
for(int nn=0;nn<circproplist.GetSize();nn++)
|
|
zDlg.namelist.Add(circproplist[nn].CircName);
|
|
circproplist.Add(CProp);
|
|
|
|
zDlg.m_circname = CProp.CircName;
|
|
zDlg.m_circtype = CProp.CircType;
|
|
zDlg.m_qc = CProp.qc;
|
|
zDlg.m_vc = CProp.vc;
|
|
|
|
if(zDlg.DoModal()==IDOK){
|
|
int k=(int) circproplist.GetSize()-1;
|
|
circproplist[k].CircName=zDlg.m_circname;
|
|
circproplist[k].CircType=zDlg.m_circtype;
|
|
circproplist[k].qc=zDlg.m_qc;
|
|
circproplist[k].vc=zDlg.m_vc;
|
|
m_namelist.AddString(circproplist[k].CircName);
|
|
m_namelist.SetCurSel(k);
|
|
}
|
|
else circproplist.RemoveAt(circproplist.GetSize()-1);
|
|
}
|
|
|
|
// Code to deal with adding properties for segments...
|
|
|
|
if (PropType==1){
|
|
CArray <CBoundaryProp, CBoundaryProp&> &lineproplist=*plineproplist;
|
|
cdCBdryDlg zDlg;
|
|
for(int nn=0;nn<lineproplist.GetSize();nn++)
|
|
zDlg.namelist.Add(lineproplist[nn].BdryName);
|
|
CBoundaryProp MProp;
|
|
lineproplist.Add(MProp);
|
|
|
|
zDlg.m_vs = MProp.vs;
|
|
zDlg.m_qs = MProp.qs;
|
|
zDlg.m_c0 = MProp.c0;
|
|
zDlg.m_c1 = MProp.c1;
|
|
zDlg.BdryFormat=MProp.BdryFormat;
|
|
zDlg.m_BdryName=MProp.BdryName;
|
|
|
|
if(zDlg.DoModal()==IDOK){
|
|
int k=(int) lineproplist.GetSize()-1;
|
|
lineproplist[k].BdryName=zDlg.m_BdryName;
|
|
lineproplist[k].BdryFormat=zDlg.BdryFormat;
|
|
lineproplist[k].vs = zDlg.m_vs;
|
|
lineproplist[k].qs = zDlg.m_qs;
|
|
lineproplist[k].c0 = zDlg.m_c0;
|
|
lineproplist[k].c1 = zDlg.m_c1;
|
|
|
|
m_namelist.AddString(lineproplist[k].BdryName);
|
|
m_namelist.SetCurSel(k);
|
|
}
|
|
else lineproplist.RemoveAt(lineproplist.GetSize()-1);
|
|
}
|
|
|
|
// Code to deal with adding properties for blocks...
|
|
if (PropType==2){
|
|
CArray <CMaterialProp, CMaterialProp&> &blockproplist=*pblockproplist;
|
|
cdCMatDlg zDlg;
|
|
for(int nn=0;nn<blockproplist.GetSize();nn++)
|
|
zDlg.namelist.Add(blockproplist[nn].BlockName);
|
|
CMaterialProp MProp;
|
|
blockproplist.Add(MProp);
|
|
zDlg.m_ox=MProp.ox;
|
|
zDlg.m_oy=MProp.oy;
|
|
zDlg.m_ex=MProp.ex;
|
|
zDlg.m_ey=MProp.ey;
|
|
zDlg.m_ltx=MProp.ltx;
|
|
zDlg.m_lty=MProp.lty;
|
|
zDlg.m_BlockName=MProp.BlockName;
|
|
|
|
if(ProblemType==0){
|
|
zDlg.m_mu1label="x";
|
|
zDlg.m_mu2label="y";
|
|
zDlg.m_mu1label2="x";
|
|
zDlg.m_mu2label2="y";
|
|
zDlg.m_mu1label3="x-dir";
|
|
zDlg.m_mu2label3="y-dir";
|
|
}
|
|
else{
|
|
zDlg.m_mu1label="r";
|
|
zDlg.m_mu2label="z";
|
|
zDlg.m_mu1label2="r";
|
|
zDlg.m_mu2label2="z";
|
|
zDlg.m_mu1label3="r-dir";
|
|
zDlg.m_mu2label3="z-dir";
|
|
}
|
|
|
|
if(zDlg.DoModal()==IDOK){
|
|
int k=(int) blockproplist.GetSize()-1;
|
|
blockproplist[k].BlockName=zDlg.m_BlockName;
|
|
blockproplist[k].ox=zDlg.m_ox;
|
|
blockproplist[k].oy=zDlg.m_oy;
|
|
blockproplist[k].ex=zDlg.m_ex;
|
|
blockproplist[k].ey=zDlg.m_ey;
|
|
blockproplist[k].ltx=zDlg.m_ltx;
|
|
blockproplist[k].lty=zDlg.m_lty;
|
|
m_namelist.AddString(blockproplist[k].BlockName);
|
|
m_namelist.SetCurSel(k);
|
|
}
|
|
else blockproplist.RemoveAt(blockproplist.GetSize()-1);
|
|
}
|
|
}
|
|
|
|
void cdCPtProp::OnDelProp()
|
|
{
|
|
// TODO: Add your control notification handler code here
|
|
if (PropType==0){
|
|
CArray <CPointProp, CPointProp&> &nodeproplist=*pnodeproplist;
|
|
int k=m_namelist.GetCurSel();
|
|
if((k!=CB_ERR) && (nodeproplist.GetSize()!=0))
|
|
{
|
|
nodeproplist.RemoveAt(k);
|
|
m_namelist.DeleteString(k);
|
|
m_namelist.SetCurSel(0);
|
|
}
|
|
}
|
|
|
|
if (PropType==3){
|
|
CArray <CCircuit, CCircuit&> &circproplist=*pcircproplist;
|
|
int k=m_namelist.GetCurSel();
|
|
if((k!=CB_ERR) && (circproplist.GetSize()!=0))
|
|
{
|
|
circproplist.RemoveAt(k);
|
|
m_namelist.DeleteString(k);
|
|
m_namelist.SetCurSel(0);
|
|
}
|
|
}
|
|
|
|
if (PropType==1){
|
|
CArray <CBoundaryProp, CBoundaryProp&> &lineproplist=*plineproplist;
|
|
int k=m_namelist.GetCurSel();
|
|
if((k!=CB_ERR) && (lineproplist.GetSize()!=0))
|
|
{
|
|
lineproplist.RemoveAt(k);
|
|
m_namelist.DeleteString(k);
|
|
m_namelist.SetCurSel(0);
|
|
}
|
|
}
|
|
|
|
if (PropType==2){
|
|
CArray <CMaterialProp, CMaterialProp&> &blockproplist=*pblockproplist;
|
|
int k=m_namelist.GetCurSel();
|
|
if((k!=CB_ERR) && (blockproplist.GetSize()!=0))
|
|
{
|
|
blockproplist.RemoveAt(k);
|
|
m_namelist.DeleteString(k);
|
|
m_namelist.SetCurSel(0);
|
|
}
|
|
}
|
|
}
|
|
|
|
void cdCPtProp::OnModProp()
|
|
{
|
|
// TODO: Add your control notification handler code here
|
|
if (PropType==0){
|
|
CArray <CPointProp, CPointProp&> &nodeproplist=*pnodeproplist;
|
|
cdCNodeProp zDlg;
|
|
|
|
if (nodeproplist.GetSize()==0) return;
|
|
int k=m_namelist.GetCurSel();
|
|
if (k==CB_ERR) return;
|
|
|
|
zDlg.m_vp=nodeproplist[k].vp;
|
|
zDlg.m_qp=nodeproplist[k].qp;
|
|
zDlg.m_nodename=nodeproplist[k].PointName;
|
|
|
|
for(int nn=0;nn<nodeproplist.GetSize();nn++)
|
|
if (nn!=k) zDlg.namelist.Add(nodeproplist[nn].PointName);
|
|
|
|
if(zDlg.DoModal()==IDOK){
|
|
nodeproplist[k].PointName=zDlg.m_nodename;
|
|
nodeproplist[k].vp=zDlg.m_vp;
|
|
nodeproplist[k].qp=zDlg.m_qp;
|
|
m_namelist.InsertString(k,zDlg.m_nodename);
|
|
m_namelist.DeleteString(k+1);
|
|
m_namelist.SetCurSel(k);
|
|
}
|
|
}
|
|
|
|
if (PropType==3){
|
|
CArray <CCircuit, CCircuit&> &circproplist=*pcircproplist;
|
|
|
|
if (circproplist.GetSize()==0) return;
|
|
int k=m_namelist.GetCurSel();
|
|
if (k==CB_ERR) return;
|
|
|
|
cdCCircProp zDlg;
|
|
|
|
zDlg.m_circname = circproplist[k].CircName;
|
|
zDlg.m_circtype = circproplist[k].CircType;
|
|
zDlg.m_qc = circproplist[k].qc;
|
|
zDlg.m_vc = circproplist[k].vc;
|
|
for(int nn=0;nn<circproplist.GetSize();nn++)
|
|
if (nn!=k) zDlg.namelist.Add(circproplist[nn].CircName);
|
|
|
|
if(zDlg.DoModal()==IDOK){
|
|
circproplist[k].CircName=zDlg.m_circname;
|
|
circproplist[k].CircType=zDlg.m_circtype;
|
|
circproplist[k].qc=zDlg.m_qc;
|
|
circproplist[k].vc=zDlg.m_vc;
|
|
m_namelist.InsertString(k,zDlg.m_circname);
|
|
m_namelist.DeleteString(k+1);
|
|
m_namelist.SetCurSel(k);
|
|
}
|
|
}
|
|
|
|
if (PropType==1){
|
|
CArray <CBoundaryProp, CBoundaryProp&> &lineproplist=*plineproplist;
|
|
cdCBdryDlg zDlg;
|
|
|
|
if (lineproplist.GetSize()==0) return;
|
|
int k=m_namelist.GetCurSel();
|
|
if (k==CB_ERR) return;
|
|
|
|
zDlg.m_vs = lineproplist[k].vs;
|
|
zDlg.m_qs = lineproplist[k].qs;
|
|
zDlg.m_c0 = lineproplist[k].c0;
|
|
zDlg.m_c1 = lineproplist[k].c1;
|
|
zDlg.BdryFormat=lineproplist[k].BdryFormat;
|
|
zDlg.m_BdryName=lineproplist[k].BdryName;
|
|
for(int nn=0;nn<lineproplist.GetSize();nn++)
|
|
if (nn!=k) zDlg.namelist.Add(lineproplist[nn].BdryName);
|
|
|
|
if(zDlg.DoModal()==IDOK){
|
|
lineproplist[k].BdryName=zDlg.m_BdryName;
|
|
lineproplist[k].BdryFormat=zDlg.BdryFormat;
|
|
lineproplist[k].vs = zDlg.m_vs;
|
|
lineproplist[k].qs = zDlg.m_qs;
|
|
lineproplist[k].c0 = zDlg.m_c0;
|
|
lineproplist[k].c1 = zDlg.m_c1;
|
|
m_namelist.InsertString(k,zDlg.m_BdryName);
|
|
m_namelist.DeleteString(k+1);
|
|
m_namelist.SetCurSel(k);
|
|
}
|
|
}
|
|
|
|
if (PropType==2){
|
|
CArray <CMaterialProp, CMaterialProp&> &blockproplist=*pblockproplist;
|
|
cdCMatDlg zDlg;
|
|
|
|
if (blockproplist.GetSize()==0) return;
|
|
int k=m_namelist.GetCurSel();
|
|
if (k==CB_ERR) return;
|
|
|
|
zDlg.m_ox=blockproplist[k].ox;
|
|
zDlg.m_oy=blockproplist[k].oy;
|
|
zDlg.m_ex=blockproplist[k].ex;
|
|
zDlg.m_ey=blockproplist[k].ey;
|
|
zDlg.m_ltx=blockproplist[k].ltx;
|
|
zDlg.m_lty=blockproplist[k].lty;
|
|
zDlg.m_BlockName=blockproplist[k].BlockName;
|
|
|
|
for(int nn=0;nn<blockproplist.GetSize();nn++)
|
|
if(nn!=k) zDlg.namelist.Add(blockproplist[nn].BlockName);
|
|
|
|
if(ProblemType==0){
|
|
zDlg.m_mu1label="x";
|
|
zDlg.m_mu2label="y";
|
|
zDlg.m_mu1label2="x";
|
|
zDlg.m_mu2label2="y";
|
|
zDlg.m_mu1label3="x-dir";
|
|
zDlg.m_mu2label3="y-dir";
|
|
}
|
|
else{
|
|
zDlg.m_mu1label="r";
|
|
zDlg.m_mu2label="z";
|
|
zDlg.m_mu1label2="r";
|
|
zDlg.m_mu2label2="z";
|
|
zDlg.m_mu1label3="r-dir";
|
|
zDlg.m_mu2label3="z-dir";
|
|
}
|
|
if(zDlg.DoModal()==IDOK){
|
|
blockproplist[k].BlockName=zDlg.m_BlockName;
|
|
blockproplist[k].ox=zDlg.m_ox;
|
|
blockproplist[k].oy=zDlg.m_oy;
|
|
blockproplist[k].ex=zDlg.m_ex;
|
|
blockproplist[k].ey=zDlg.m_ey;
|
|
blockproplist[k].ltx=zDlg.m_ltx;
|
|
blockproplist[k].lty=zDlg.m_lty;
|
|
m_namelist.InsertString(k,zDlg.m_BlockName);
|
|
m_namelist.DeleteString(k+1);
|
|
m_namelist.SetCurSel(k);
|
|
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
void cdCPtProp::OnOK()
|
|
{
|
|
// TODO: Add extra validation here
|
|
|
|
CDialog::OnOK();
|
|
}
|
|
|
|
BOOL cdCPtProp::OnInitDialog()
|
|
{
|
|
int i;
|
|
|
|
CDialog::OnInitDialog();
|
|
|
|
// TODO: Add extra initialization here
|
|
|
|
if (PropType==0){
|
|
CArray <CPointProp, CPointProp&> &nodeproplist=*pnodeproplist;
|
|
for(i=0;i<nodeproplist.GetSize();i++)
|
|
m_namelist.AddString(nodeproplist[i].PointName);
|
|
if (nodeproplist.GetSize()>0) m_namelist.SetCurSel(0);
|
|
}
|
|
|
|
if (PropType==1){
|
|
CArray <CBoundaryProp, CBoundaryProp&> &lineproplist=*plineproplist;
|
|
for(i=0;i<lineproplist.GetSize();i++)
|
|
m_namelist.AddString(lineproplist[i].BdryName);
|
|
if (lineproplist.GetSize()>0) m_namelist.SetCurSel(0);
|
|
}
|
|
|
|
if (PropType==2){
|
|
CArray <CMaterialProp, CMaterialProp&> &blockproplist=*pblockproplist;
|
|
for(i=0;i<blockproplist.GetSize();i++)
|
|
m_namelist.AddString(blockproplist[i].BlockName);
|
|
if (blockproplist.GetSize()>0) m_namelist.SetCurSel(0);
|
|
}
|
|
|
|
if (PropType==3){
|
|
CArray <CCircuit, CCircuit&> &circproplist=*pcircproplist;
|
|
for(i=0;i<circproplist.GetSize();i++)
|
|
m_namelist.AddString(circproplist[i].CircName);
|
|
if (circproplist.GetSize()>0) m_namelist.SetCurSel(0);
|
|
}
|
|
|
|
return TRUE; // return TRUE unless you set the focus to a control
|
|
// EXCEPTION: OCX Property Pages should return FALSE
|
|
}
|