📄 dlghebing.cpp
字号:
// DlgHeBing.cpp : implementation file
//
#include "stdafx.h"
#include "RT.h"
#include "DlgHeBing.h"
#include "Matrix.h"
#include "Complex.h"
#include "PandL.h"
#include<stdio.h>
#include<iostream.h>
#include<fstream.h>
#include<stdlib.h>
#include<iomanip.h>
#include<cstring>
#include<string.h>
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// DlgHeBing dialog
DlgHeBing::DlgHeBing(CWnd* pParent /*=NULL*/)
: CDialog(DlgHeBing::IDD, pParent)
{
//{{AFX_DATA_INIT(DlgHeBing)
m_open1 = _T("");
m_open2 = _T("");
//}}AFX_DATA_INIT
}
void DlgHeBing::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(DlgHeBing)
DDX_Text(pDX, IDC_EDIT_OPEN1, m_open1);
DDX_Text(pDX, IDC_EDIT_OPEN2, m_open2);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(DlgHeBing, CDialog)
//{{AFX_MSG_MAP(DlgHeBing)
ON_BN_CLICKED(IDC_BUT_OPEN1, OnButOpen1)
ON_BN_CLICKED(IDC_BUT_OPEN2, OnButOpen2)
ON_BN_CLICKED(IDC_BUT_SAVE, OnButSave)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// DlgHeBing message handlers
void DlgHeBing::OnButOpen1()
{
// TODO: Add your control notification handler code here
CString fileName;
char* szFilter = "Text Files (*.txt)|*.txt|All Files (*.*)|*.*||";
CFileDialog dlg(TRUE, "txt", TEXT("name.txt"),
OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT ,szFilter);
dlg.DoModal();
fileName = dlg.GetFileName();
char FileFormat[4]="";
if(fileName[0]=='\0')
{
return;
}
for(int i=0;i<80;i++)
{
if(fileName[i]=='.')
{
for(int j=0;j<3;j++)
{
FileFormat[j]=fileName[i+1];
i++;
}
break;
}
}
if(!(FileFormat[0]=='t'||FileFormat[0]=='T'))
{
MessageBox("你选择的不是txt格式的文件!","Waring!",MB_ICONSTOP);
return;
}
if(!(FileFormat[1]=='x'||FileFormat[1]=='X'))
{
MessageBox("你选择的不是txt格式的文件!","Waring!",MB_ICONSTOP);
return;
}
if(!(FileFormat[2]=='t'||FileFormat[2]=='T'))
{
MessageBox("你选择的不是txt格式的文件!","Waring!",MB_ICONSTOP);
return;
}
m_open1=fileName;
Invalidate();
UpdateData(FALSE);
}
void DlgHeBing::OnButOpen2()
{
// TODO: Add your control notification handler code here
CString fileName;
char* szFilter = "Text Files (*.txt)|*.txt|All Files (*.*)|*.*||";
CFileDialog dlg(TRUE, "txt", TEXT("name.txt"),
OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT ,szFilter);
dlg.DoModal();
fileName = dlg.GetFileName();
char FileFormat[4]="";
if(fileName[0]=='\0')
{
return;
}
for(int i=0;i<80;i++)
{
if(fileName[i]=='.')
{
for(int j=0;j<3;j++)
{
FileFormat[j]=fileName[i+1];
i++;
}
break;
}
}
if(!(FileFormat[0]=='t'||FileFormat[0]=='T'))
{
MessageBox("你选择的不是txt格式的文件!","Waring!",MB_ICONSTOP);
return;
}
if(!(FileFormat[1]=='x'||FileFormat[1]=='X'))
{
MessageBox("你选择的不是txt格式的文件!","Waring!",MB_ICONSTOP);
return;
}
if(!(FileFormat[2]=='t'||FileFormat[2]=='T'))
{
MessageBox("你选择的不是txt格式的文件!","Waring!",MB_ICONSTOP);
return;
}
m_open2=fileName;
Invalidate();
UpdateData(FALSE);
}
void DlgHeBing::OnButSave()
{
// TODO: Add your control notification handler code here
UpdateData(TRUE);
int i,j,k,indexTemp,indexTemp2;
double xTemp,xTemp2;
i=0;j=0;k=0;xTemp=0;indexTemp=0;xTemp2=0;indexTemp2=0;
// double rtFirst[3],rtMax[3],rtLast[3],rtFirst2[3],rtMax2[3],rtLast2[3];
/* for(int t=0;t<3;t++)
{
rtFirst[t]=0;
rtMax[t]=0;
rtLast[t]=0;
rtFirst2[t]=0;
rtMax2[t]=0;
rtLast2[t]=0;
}*/
//---------------------------------------------------------------
CALine Line,Line1,Line2;
CString strName = m_open1;
Line.LoadTXTFile(strName);
/* rtFirst[0]=Line.m_LineList2[0]->m_PointList2[0]->pt3.x;
rtFirst[1]=Line.m_LineList2[0]->m_PointList2[0]->pt3.y;
rtFirst[2]=Line.m_LineList2[0]->m_PointList2[0]->pt3.z;
for(i=0;i<Line.m_LineList2.GetSize();i++)
{
if(Line.m_LineList2[i]->m_PointList2[0]->pt3.x>xTemp)
{
xTemp=Line.m_LineList2[i]->m_PointList2[0]->pt3.x;
indexTemp=i;
}
}
rtMax[0]=Line.m_LineList2[indexTemp]->m_PointList2[0]->pt3.x;
rtMax[1]=Line.m_LineList2[indexTemp]->m_PointList2[0]->pt3.y;
rtMax[2]=Line.m_LineList2[indexTemp]->m_PointList2[0]->pt3.z;
i=Line.m_LineList2.GetSize();
rtLast[0]=Line.m_LineList2[i-1]->m_PointList2[0]->pt3.x;
rtLast[1]=Line.m_LineList2[i-1]->m_PointList2[0]->pt3.y;
rtLast[2]=Line.m_LineList2[i-1]->m_PointList2[0]->pt3.z;*/
//------------------------------------------------------------------------
CString strName2 = m_open2;
Line2.LoadTXTFile(strName2);
/* rtFirst2[0]=Line2.m_LineList2[0]->m_PointList2[0]->pt3.x;
rtFirst2[1]=Line2.m_LineList2[0]->m_PointList2[0]->pt3.y;
rtFirst2[2]=Line2.m_LineList2[0]->m_PointList2[0]->pt3.z;
for(i=0;i<Line2.m_LineList2.GetSize();i++)
{
if(Line2.m_LineList2[i]->m_PointList2[0]->pt3.x>xTemp2)
{
xTemp2=Line2.m_LineList2[i]->m_PointList2[0]->pt3.x;
indexTemp2=i;
}
}
rtMax2[0]=Line2.m_LineList2[indexTemp2]->m_PointList2[0]->pt3.x;
rtMax2[1]=Line2.m_LineList2[indexTemp2]->m_PointList2[0]->pt3.y;
rtMax2[2]=Line2.m_LineList2[indexTemp2]->m_PointList2[0]->pt3.z;
i=Line2.m_LineList2.GetSize();
rtLast2[0]=Line2.m_LineList2[i-1]->m_PointList2[0]->pt3.x;
rtLast2[1]=Line2.m_LineList2[i-1]->m_PointList2[0]->pt3.y;
rtLast2[2]=Line2.m_LineList2[i-1]->m_PointList2[0]->pt3.z;*/
//----------------------------------------------------------------------
/* if(rtFirst[0]=rtMax[0])
{
if(rtFirst2[0]<rtMax2[0]&&rtLast2[0]<rtMax2[0])
{
for(i=indexTemp2;i<Line2.m_LineList2.GetSize();i++)
{
if(Line2.m_LineList2[i]->m_PointList2[0]->pt3.x<rtFirst[0]-0.005)
{
Line2.m_LineList2.RemoveAt(i);
}
}
}
}*/
//----------------------------------------------------------------------
//
CLine* line3=NULL;
CPointtest* point=NULL;
for(i=0;i<Line2.m_LineList2.GetSize();i++)
{
line3=new CLine();
for(j=0;j<Line2.m_LineList2[i]->m_PointList2.GetSize();j++)
{
point=new CPointtest();
point->pt3.x=Line2.m_LineList2[i]->m_PointList2[j]->pt3.x;
point->pt3.y=Line2.m_LineList2[i]->m_PointList2[j]->pt3.y;
point->pt3.z=Line2.m_LineList2[i]->m_PointList2[j]->pt3.z;
line3->m_PointList2.Add(point);
}
Line.Add(line3);
}
//-------------------------------------------------------------------
char save[200]="";
CFileDialog dlgs(FALSE,"txt",NULL,
OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT,
"txt File(*.txt)|*.txt", NULL );
if(dlgs.DoModal()==IDOK){
CString strSaveName= dlgs.GetPathName();
strcat( save, strSaveName);
}
ofstream outstuf; //建立输出文件流对象
outstuf.open(save,ios::out); //连接文件,指定打开方式
/* outstuf<<"first line:"<<endl;
outstuf<<rtFirst[0]<<" "<<rtFirst[1]<<" "<<rtFirst[2]<<endl;
outstuf<<rtMax[0]<<" "<<rtMax[1]<<" "<<rtMax[2]<<endl;
outstuf<<rtLast[0]<<" "<<rtLast[1]<<" "<<rtLast[2]<<endl;
outstuf<<"second line:"<<endl;
outstuf<<rtFirst2[0]<<" "<<rtFirst2[1]<<" "<<rtFirst2[2]<<endl;
outstuf<<rtMax2[0]<<" "<<rtMax2[1]<<" "<<rtMax2[2]<<endl;
outstuf<<rtLast2[0]<<" "<<rtLast2[1]<<" "<<rtLast2[2]<<endl;
outstuf<<endl;*/
int NumberOfPoint=0;
for(i=0;i<Line.m_LineList2.GetSize();i++) //数组m[i][j]初始化
{
NumberOfPoint=NumberOfPoint+Line.m_LineList2[i]->m_PointList2.GetSize();
}
outstuf<<"total number of line:"<<" "<<Line.m_LineList2.GetSize()<<" "<<"total number of point:"<<" "<<NumberOfPoint<<endl;
for( i=0;i<Line.m_LineList2.GetSize();i++) //数组m[i][j]初始化
{
outstuf<<endl;
outstuf <<"line"<<" "<<i+1<<" "<<"point"<<" "<<Line.m_LineList2[i]->m_PointList2.GetSize()<<endl;
for( j=0;j<Line.m_LineList2[i]->m_PointList2.GetSize();j++)
{
outstuf <<Line.m_LineList2[i]->m_PointList2[j]->pt3.x <<" "<<Line.m_LineList2[i]->m_PointList2[j]->pt3.y<<" "<<Line.m_LineList2[i]->m_PointList2[j]->pt3.z<<"\n";
}
}
outstuf.close(); //关闭文件
MessageBox("转换已成功谢谢使用!","Thanks!",MB_ICONSTOP);
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -