You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
kev/Drawer/GVision/FaultAmplitude/FaultAmplitudeDlg.cpp

533 lines
14 KiB
C++

1 month ago
// FaultAmplitudeDlg.cpp : ʵ<><CAB5><EFBFBD>ļ<EFBFBD>
//
#include "stdafx.h"
#include "FaultAmplitude.h"
#include "FaultAmplitudeDlg.h"
#include "afxdialogex.h"
#include "../FaultAmplitudeLib/FaultAmplitudeCreator.h"
#include "../BaseLib/GDfdMap.h"
#include "../DrawerIO/DrawerIO.h"
#include <string>
using namespace std;
#ifdef _DEBUG
#define new DEBUG_NEW
#endif
// <20><><EFBFBD><EFBFBD>Ӧ<EFBFBD>ó<EFBFBD><C3B3>򡰹<EFBFBD><F2A1B0B9>ڡ<EFBFBD><DAA1>˵<EFBFBD><CBB5><EFBFBD><EFBFBD><EFBFBD> CAboutDlg <20>Ի<EFBFBD><D4BB><EFBFBD>
class CAboutDlg : public CDialogEx
{
public:
CAboutDlg();
// <20>Ի<EFBFBD><D4BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
#ifdef AFX_DESIGN_TIME
enum { IDD = IDD_ABOUTBOX };
#endif
protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV ֧<><D6A7>
// ʵ<><CAB5>
protected:
DECLARE_MESSAGE_MAP()
};
CAboutDlg::CAboutDlg() : CDialogEx(IDD_ABOUTBOX)
{
}
void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
CDialogEx::DoDataExchange(pDX);
}
BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx)
END_MESSAGE_MAP()
// CFaultAmplitudeDlg <20>Ի<EFBFBD><D4BB><EFBFBD>
CFaultAmplitudeDlg::CFaultAmplitudeDlg(CWnd* pParent /*=NULL*/)
: CDialog(IDD_FAULTAMPLITUDE_DIALOG, pParent)
, m_strInputFltSurvey(_T(""))
, m_strInputDfg(_T(""))
, m_strFltNameFile(_T(""))
, m_fStep(100)
, m_fClrThresholds(10)
, m_fPillarWidth(20)
, m_fTextHeight(5)
, m_fPillarHeightRatio(10.0)
, m_strOutFigure(_T(""))
, m_strOutData(_T(""))
, m_iCalcOption(0)
, m_bLocalDirect(FALSE)
{
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
//m_fmc = new CFaultAmplitudeCreator();
}
CFaultAmplitudeDlg::~CFaultAmplitudeDlg()
{
//delete m_fmc;
}
void CFaultAmplitudeDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
DDX_Text(pDX, IDC_EDIT_INPUT_FLT_SURVEY, m_strInputFltSurvey);
DDX_Text(pDX, IDC_EDIT_INPUT_DFG, m_strInputDfg);
DDX_Control(pDX, IDC_COMBO_FAULT_LAYERS, m_controlFltLayer);
DDX_Text(pDX, IDC_EDIT_FAULT_NAME_FILE, m_strFltNameFile);
DDX_Control(pDX, IDC_COMBO_SURVEY_LAYERS, m_comboSurveyLayer);
DDX_Text(pDX, IDC_EDIT_STEP, m_fStep);
DDX_Text(pDX, IDC_EDIT_THRESHOLDS, m_fClrThresholds);
DDX_Text(pDX, IDC_EDIT_PILLAR_WIDTH, m_fPillarWidth);
DDX_Text(pDX, IDC_EDIT_TEXT_LENGTH, m_fTextHeight);
DDX_Text(pDX, IDC_EDIT_PILLAR_HEIGHT_RATIO, m_fPillarHeightRatio);
DDX_Text(pDX, IDC_EDIT_OUTPUT_FIGURE, m_strOutFigure);
DDX_Text(pDX, IDC_EDIT_OUTPUT_DATA, m_strOutData);
DDX_Radio(pDX, IDC_RADIO3, m_iCalcOption);
DDX_Control(pDX, IDC_MFCCOLORBUTTON1, m_cbtnLow);
DDX_Control(pDX, IDC_MFCCOLORBUTTON2, m_cbtnHigh);
DDX_Check(pDX, IDC_CHECK_LOCAL_DIRECT, m_bLocalDirect);
}
BEGIN_MESSAGE_MAP(CFaultAmplitudeDlg, CDialog)
ON_WM_SYSCOMMAND()
ON_WM_PAINT()
ON_WM_QUERYDRAGICON()
//ON_BN_CLICKED(IDC_BUTTON_INPUT_FLT, &CFaultAmplitudeDlg::OnBnClickedButtonInputFlt)
ON_BN_CLICKED(IDC_BUTTON_INPUT_FLT_SURVEY, &CFaultAmplitudeDlg::OnBnClickedButtonInputFltSurvey)
ON_BN_CLICKED(IDC_BUTTON_INPUT_DFG, &CFaultAmplitudeDlg::OnBnClickedButtonInputDfg)
ON_BN_CLICKED(IDC_BUTTON_INPUT_FAULT_NAME_FILE, &CFaultAmplitudeDlg::OnBnClickedButtonInputFaultNameFile)
ON_BN_CLICKED(IDC_BUTTON_OUTPUT_FIGURE, &CFaultAmplitudeDlg::OnBnClickedButtonOutputFigure)
ON_BN_CLICKED(IDC_BUTTON_OUTPUT_DATA, &CFaultAmplitudeDlg::OnBnClickedButtonOutputData)
ON_BN_CLICKED(IDC_RADIO3, &CFaultAmplitudeDlg::OnBnClickedRadio3)
ON_BN_CLICKED(IDC_RADIO4, &CFaultAmplitudeDlg::OnBnClickedRadio4)
ON_BN_CLICKED(IDOK, &CFaultAmplitudeDlg::OnBnClickedOk)
END_MESSAGE_MAP()
// CFaultAmplitudeDlg <20><>Ϣ<EFBFBD><CFA2><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
BOOL CFaultAmplitudeDlg::OnInitDialog()
{
CDialog::OnInitDialog();
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>...<2E><><EFBFBD>˵<EFBFBD><CBB5><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӵ<EFBFBD>ϵͳ<CFB5>˵<EFBFBD><CBB5>С<EFBFBD>
// IDM_ABOUTBOX <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ϵͳ<CFB5><CDB3><EFBFBD>Χ<EEB7B6>ڡ<EFBFBD>
ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
ASSERT(IDM_ABOUTBOX < 0xF000);
CMenu* pSysMenu = GetSystemMenu(FALSE);
if (pSysMenu != NULL)
{
BOOL bNameValid;
CString strAboutMenu;
bNameValid = strAboutMenu.LoadString(IDS_ABOUTBOX);
ASSERT(bNameValid);
if (!strAboutMenu.IsEmpty())
{
pSysMenu->AppendMenu(MF_SEPARATOR);
pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
}
}
// <20><><EFBFBD>ô˶Ի<CBB6><D4BB><EFBFBD><EFBFBD><EFBFBD>ͼ<EFBFBD><20><>Ӧ<EFBFBD>ó<EFBFBD><C3B3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ڲ<EFBFBD><DAB2>ǶԻ<C7B6><D4BB><EFBFBD>ʱ<EFBFBD><CAB1><EFBFBD><EFBFBD><EFBFBD>ܽ<EFBFBD><DCBD>Զ<EFBFBD>
// ִ<>д˲<D0B4><CBB2><EFBFBD>
SetIcon(m_hIcon, TRUE); // <20><><EFBFBD>ô<EFBFBD>ͼ<EFBFBD><CDBC>
SetIcon(m_hIcon, FALSE); // <20><><EFBFBD><EFBFBD>Сͼ<D0A1><CDBC>
// TODO: <20>ڴ<EFBFBD><DAB4><EFBFBD><EFBFBD>Ӷ<EFBFBD><D3B6><EFBFBD><EFBFBD>ij<EFBFBD>ʼ<EFBFBD><CABC><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
FillLayerCombos();
m_cbtnLow.SetColor(RGB(0, 0, 255));
m_cbtnHigh.SetColor(RGB(255, 0, 0));
switch (m_iCalcOption)
{
case 0:
GetDlgItem(IDC_COMBO_SURVEY_LAYERS)->EnableWindow(FALSE);
GetDlgItem(IDC_EDIT_STEP)->EnableWindow(TRUE);
break;
case 1:
GetDlgItem(IDC_COMBO_SURVEY_LAYERS)->EnableWindow(TRUE);
GetDlgItem(IDC_EDIT_STEP)->EnableWindow(FALSE);
break;
default:
GetDlgItem(IDC_COMBO_SURVEY_LAYERS)->EnableWindow(FALSE);
GetDlgItem(IDC_EDIT_STEP)->EnableWindow(FALSE);
break;
}
return TRUE; // <20><><EFBFBD>ǽ<EFBFBD><C7BD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>õ<EFBFBD><C3B5>ؼ<EFBFBD><D8BC><EFBFBD><EFBFBD><EFBFBD><EFBFBD>򷵻<EFBFBD> TRUE
}
void CFaultAmplitudeDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
if ((nID & 0xFFF0) == IDM_ABOUTBOX)
{
CAboutDlg dlgAbout;
dlgAbout.DoModal();
}
else
{
CDialog::OnSysCommand(nID, lParam);
}
}
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ի<EFBFBD><D4BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>С<EFBFBD><D0A1><EFBFBD><EFBFBD>ť<EFBFBD><C5A5><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><D2AA><EFBFBD><EFBFBD><EFBFBD>Ĵ<EFBFBD><C4B4><EFBFBD>
// <20><><EFBFBD><EFBFBD><EFBFBD>Ƹ<EFBFBD>ͼ<EFBFBD><20><><EFBFBD><EFBFBD>ʹ<EFBFBD><CAB9><EFBFBD>ĵ<EFBFBD>/<2F><>ͼģ<CDBC>͵<EFBFBD> MFC Ӧ<>ó<EFBFBD><C3B3><EFBFBD><EFBFBD><EFBFBD>
// <20><EFBFBD>ɿ<EFBFBD><C9BF><EFBFBD><EFBFBD>Զ<EFBFBD><D4B6><EFBFBD><EFBFBD>ɡ<EFBFBD>
void CFaultAmplitudeDlg::OnPaint()
{
if (IsIconic())
{
CPaintDC dc(this); // <20><><EFBFBD>ڻ<EFBFBD><DABB>Ƶ<EFBFBD><C6B5><EFBFBD><E8B1B8><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
// ʹͼ<CAB9><CDBC><EFBFBD>ڹ<EFBFBD><DAB9><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>о<EFBFBD><D0BE><EFBFBD>
int cxIcon = GetSystemMetrics(SM_CXICON);
int cyIcon = GetSystemMetrics(SM_CYICON);
CRect rect;
GetClientRect(&rect);
int x = (rect.Width() - cxIcon + 1) / 2;
int y = (rect.Height() - cyIcon + 1) / 2;
// <20><><EFBFBD><EFBFBD>ͼ<EFBFBD><CDBC>
dc.DrawIcon(x, y, m_hIcon);
}
else
{
CDialog::OnPaint();
}
}
COLORREF CFaultAmplitudeDlg::GetLowColor(void)
{
if (!this->GetSafeHwnd())
return RGB(255, 255, 255);
return m_cbtnLow.GetColor();
}
COLORREF CFaultAmplitudeDlg::GetHighColor(void)
{
if (!this->GetSafeHwnd())
return RGB(255, 255, 255);
return m_cbtnHigh.GetColor();
}
//<2F><><EFBFBD>û<EFBFBD><C3BB>϶<EFBFBD><CFB6><EFBFBD>С<EFBFBD><D0A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʱϵͳ<CFB5><CDB3><EFBFBD>ô˺<C3B4><CBBA><EFBFBD>ȡ<EFBFBD>ù<EFBFBD><C3B9><EFBFBD>
//<2F><>ʾ<EFBFBD><CABE>
HCURSOR CFaultAmplitudeDlg::OnQueryDragIcon()
{
return static_cast<HCURSOR>(m_hIcon);
}
void CFaultAmplitudeDlg::FillLayerCombos(void)
{
m_comboSurveyLayer.Clear();
m_controlFltLayer.Clear();
m_comboSurveyLayer.ResetContent();
m_controlFltLayer.ResetContent();
//if (!m_fmc->GetDfd())
// return;
//GDfdMap* pdfd = m_fmc->GetDfd();
//
//pdfd->GetLayers(m_layers);
//if (m_layers.empty())
// return;
//
//for (int i = 0; i < m_layers.size(); i++)
//{
// m_comboSurveyLayer.AddString((LPCTSTR)(m_layers[i].c_str()));
// m_controlFltLayer.AddString((LPCTSTR)(m_layers[i].c_str()));
//}
//
//if (m_layers.size() > 0)
//{
// m_comboSurveyLayer.SetCurSel(0);
// m_controlFltLayer.SetCurSel(0);
//}
}
bool CFaultAmplitudeDlg::ReadDfd(void)
{
//if (m_fmc->ReadDfdMap(m_strInputFltSurvey.GetBuffer()))
// return true;
return false;
}
bool CFaultAmplitudeDlg::ReadDfg(void)
{
//if (m_fmc->ReadDfg(m_strInputDfg.GetBuffer()))
// return true;
return false;
}
void CFaultAmplitudeDlg::OnBnClickedButtonInputFltSurvey()
{
UpdateData(TRUE);
CString filter;
filter = "DFD<EFBFBD>ļ<EFBFBD>(*.dfd)|*.dfd|<7C><><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>(*.*)|*.*||";
CFileDialog dlg(TRUE, NULL, NULL, OFN_HIDEREADONLY, filter);
if (dlg.DoModal() == IDOK)
{
m_strInputFltSurvey = dlg.GetPathName();
}
else
m_strInputFltSurvey = "";
BeginWaitCursor();
if(ReadDfd())
FillLayerCombos();
EndWaitCursor();
this->UpdateData(FALSE);
}
void CFaultAmplitudeDlg::OnBnClickedButtonInputDfg()
{
UpdateData(TRUE);
CString filter;
filter = "DFG<EFBFBD>ļ<EFBFBD>(*.dfg)|*.dfg|<7C><><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>(*.*)|*.*||";
CFileDialog dlg(TRUE, NULL, NULL, OFN_HIDEREADONLY, filter);
if (dlg.DoModal() == IDOK)
{
m_strInputDfg = dlg.GetPathName();
}
else
m_strInputDfg = "";
this->UpdateData(FALSE);
}
void CFaultAmplitudeDlg::OnBnClickedButtonInputFaultNameFile()
{
UpdateData(TRUE);
CString filter;
filter = "Text<EFBFBD>ļ<EFBFBD>(*.txt)|*.txt|<7C><><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>(*.*)|*.*||";
CFileDialog dlg(TRUE, NULL, NULL, OFN_HIDEREADONLY, filter);
if (dlg.DoModal() == IDOK)
{
m_strFltNameFile = dlg.GetPathName();
}
else
m_strFltNameFile = "";
this->UpdateData(FALSE);
}
void CFaultAmplitudeDlg::OnBnClickedButtonOutputFigure()
{
UpdateData(TRUE);
CString filter;
filter = "DFD<EFBFBD>ļ<EFBFBD>(*.dfd)|*.dfd|<7C><><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>(*.*)|*.*||";
CFileDialog dlg(FALSE, NULL, NULL, OFN_HIDEREADONLY, filter);
if (dlg.DoModal() == IDOK)
{
m_strOutFigure = dlg.GetPathName();
}
else
m_strOutFigure = "";
this->UpdateData(FALSE);
}
void CFaultAmplitudeDlg::OnBnClickedButtonOutputData()
{
UpdateData(TRUE);
CString filter;
filter = "CSV<EFBFBD>ļ<EFBFBD>(*.csv)|*.csv|<7C><><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>(*.*)|*.*||";
CFileDialog dlg(FALSE, NULL, NULL, OFN_HIDEREADONLY, filter);
if (dlg.DoModal() == IDOK)
{
m_strOutData = dlg.GetPathName();
}
else
m_strOutData = "";
this->UpdateData(FALSE);
}
void CFaultAmplitudeDlg::OnBnClickedRadio3()
{
this->UpdateData(TRUE);
switch (m_iCalcOption)
{
case 0:
GetDlgItem(IDC_COMBO_SURVEY_LAYERS)->EnableWindow(FALSE);
GetDlgItem(IDC_EDIT_STEP)->EnableWindow(TRUE);
GetDlgItem(IDC_CHECK_LOCAL_DIRECT)->EnableWindow(TRUE);
break;
case 1:
GetDlgItem(IDC_COMBO_SURVEY_LAYERS)->EnableWindow(TRUE);
GetDlgItem(IDC_EDIT_STEP)->EnableWindow(FALSE);
GetDlgItem(IDC_CHECK_LOCAL_DIRECT)->EnableWindow(FALSE);
break;
default:
GetDlgItem(IDC_COMBO_SURVEY_LAYERS)->EnableWindow(FALSE);
GetDlgItem(IDC_EDIT_STEP)->EnableWindow(FALSE);
GetDlgItem(IDC_CHECK_LOCAL_DIRECT)->EnableWindow(FALSE);
break;
}
this->UpdateData(FALSE);
}
void CFaultAmplitudeDlg::OnBnClickedRadio4()
{
this->UpdateData(TRUE);
switch (m_iCalcOption)
{
case 0:
GetDlgItem(IDC_COMBO_SURVEY_LAYERS)->EnableWindow(FALSE);
GetDlgItem(IDC_EDIT_STEP)->EnableWindow(TRUE);
GetDlgItem(IDC_CHECK_LOCAL_DIRECT)->EnableWindow(TRUE);
break;
case 1:
GetDlgItem(IDC_COMBO_SURVEY_LAYERS)->EnableWindow(TRUE);
GetDlgItem(IDC_EDIT_STEP)->EnableWindow(FALSE);
GetDlgItem(IDC_CHECK_LOCAL_DIRECT)->EnableWindow(FALSE);
break;
default:
GetDlgItem(IDC_COMBO_SURVEY_LAYERS)->EnableWindow(FALSE);
GetDlgItem(IDC_EDIT_STEP)->EnableWindow(FALSE);
GetDlgItem(IDC_CHECK_LOCAL_DIRECT)->EnableWindow(FALSE);
break;
}
this->UpdateData(FALSE);
}
void CFaultAmplitudeDlg::ReadParameters(void)
{
//m_fmc->SetOutPaths(m_strOutFigure, m_strOutData);
//m_controlFltLayer.GetLBText(m_controlFltLayer.GetCurSel(), m_fmc->m_strFltLayer);
//m_comboSurveyLayer.GetLBText(m_comboSurveyLayer.GetCurSel(), m_fmc->m_strSurveyLayer);
//
//m_fmc->m_strFltNameFile = m_strFltNameFile;
//m_fmc->m_iCalcMethod = m_iCalcOption; // 0=
//m_fmc->m_pillarStep= m_fStep; //
//m_fmc->m_thresholdValue= m_fClrThresholds; //
//m_fmc->m_clrLow= GetLowColor(); //С
//m_fmc->m_clrHigh= GetHighColor(); //<2F><>
//m_fmc->m_PillarWidth= m_fPillarWidth; //<2F><>
//m_fmc->m_PillarHeightRatio= m_fPillarHeightRatio;
//m_fmc->m_TextHeight= m_fTextHeight; //<2F><><EFBFBD><EFBFBD>
//m_fmc->m_bLocalFltDirect = m_bLocalDirect; //<2F><><EFBFBD>ӷ<EFBFBD><D3B7><EFBFBD>
}
void CFaultAmplitudeDlg::OnBnClickedOk()
{
// TODO: <20>ڴ<EFBFBD><DAB4><EFBFBD><EFBFBD>ӿؼ<D3BF>֪ͨ<CDA8><D6AA><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
//CDialog::OnOK();
this->UpdateData(TRUE);
//BeginWaitCursor();
//this->ReadDfg();
//ReadParameters();
//CString inputFile("C:\\GeoIntelligent\\Test\\̫ƽ<CCAB>͹<EFBFBD><CDB9><EFBFBD>4\\FaultAnalyze\\FaultAmplitude\\Stratum\\P.dfd");
//CString resultFile("C:\\GeoIntelligent\\Test\\̫ƽ<CCAB>͹<EFBFBD><CDB9><EFBFBD>4\\FaultAnalyze\\FaultAmplitude\\Stratum\\P_Amp.kev");
//CString statisticFile("C:\\GeoIntelligent\\Test\\̫ƽ<CCAB>͹<EFBFBD><CDB9><EFBFBD>4\\FaultAnalyze\\FaultAmplitude\\Stratum\\P_Stat.csv");
CString inputFile("C:\\temp\\7<EFBFBD><EFBFBD>28<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ѵ<EFBFBD><EFBFBD>Ŀ\\FaultAnalyze\\FaultAmplitude\\Stratum\\<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ر<EFBFBD><EFBFBD><EFBFBD>T1<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͼ-.dfd");
CString resultFile("C:\\temp\\7<EFBFBD><EFBFBD>28<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ѵ<EFBFBD><EFBFBD>Ŀ\\FaultAnalyze\\FaultAmplitude\\Stratum\\K1_Amp.kev");
CString statisticFile("C:\\temp\\7<EFBFBD><EFBFBD>28<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ѵ<EFBFBD><EFBFBD>Ŀ\\FaultAnalyze\\FaultAmplitude\\Stratum\\K1_Stat.csv");
CString faultLayer("<EFBFBD>ϲ<EFBFBD>\\T1-<2D>ϲ<EFBFBD>");
bool calByStep = true;
double calStep = 100;
double divideValue = 10;
double pillarWidth = 20;
double pillarScale = 5;
double textHeight = 5;
int heighColor = 255;
int lowColor = 16711680;
bool bLocalFltDirect = false;
//bool bWithIncline = true;
//double inclineScale = 20;
bool bWithIncline = false;
double inclineScale = 10;
int inclineColor = 16711680;
CString surveyLayer("<EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
CString faultNames("");
CFaultAmplitudeCreator faCreator;
//MessageBox(nullptr, inputFile, "openFile", 0);
if (faCreator.ReadDfdMap(inputFile) == false)
{
return;
}
//MessageBox(nullptr, "Opened", "openFile", 0);
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>
CDrawerIO drawerIo;
CXy* pXy = new CXy;
pXy->m_bRealTimeDraw = false;
if (drawerIo.OpenFile(inputFile, pXy) == false) {
delete pXy;
return;
}
//MessageBox(nullptr, "drawerIo.OpenFile", "openFile", 0);
CPtrList* pDataAll = pXy->GetValueList();
POSITION pos = pDataAll->GetHeadPosition();
int nEleType = 0;
COne *pOne;
CMesh* pMesh = nullptr;
bool bSuccess = false;
while (pos)
{
pOne = (COne *)(pDataAll->GetNext(pos));
nEleType = pOne->GetType();
// <20><><EFBFBD><EFBFBD>
if (nEleType == DOUBLEFOX_MESH)
{
pMesh = (CMesh*)pOne->value;
CGrid* pGrid = pMesh->GetMesh();
faCreator.CreateDfg(pGrid->xnum(), pGrid->ynum(), pGrid->xmin(), pGrid->ymin(), pGrid->dx(), pGrid->dy()
, ((CDimension2D*)pGrid)->u);
faCreator.SetZRange(pGrid->range[0], pGrid->range[1]);
bSuccess = true;
break;
}
}
delete pXy;
faCreator.SetOutPaths(resultFile, statisticFile);
faCreator.m_strFltLayer = faultLayer;
faCreator.m_strSurveyLayer = surveyLayer;
//faCreator.m_strFltNameFile = m_strFltNameFile; // <20>ϲ<EFBFBD><CFB2><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>
faCreator.m_iCalcMethod = calByStep ? 0 : 1; // 0=
faCreator.m_pillarStep = (float)calStep; //
faCreator.m_thresholdValue = divideValue; //
faCreator.m_clrLow = lowColor; //С
faCreator.m_clrHigh = heighColor; // <20><>
faCreator.m_PillarWidth = pillarWidth; // <20><>
faCreator.m_PillarHeightRatio = pillarScale;
faCreator.m_TextHeight = textHeight; // <20><><EFBFBD><EFBFBD>
faCreator.m_strFltNames = faultNames; // <20>ϲ<EFBFBD><CFB2><EFBFBD><EFBFBD><EFBFBD>
faCreator.m_bLocalFltDirect = bLocalFltDirect; //<2F><><EFBFBD>ӷ<EFBFBD><D3B7><EFBFBD>
faCreator.m_bWithIncline = bWithIncline; //
faCreator.m_inclineScale = inclineScale;
faCreator.m_clrIncline = inclineColor;
if (faCreator.Execute())
AfxMessageBox("Complete");
else
AfxMessageBox("Failed");
//EndWaitCursor();
}