|
|
|
|
|
|
|
|
|
|
|
// 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();
|
|
|
|
|
|
}
|