⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 wdycform.cpp

📁 这是本人两年前兼职为某个公司做的石油钻进设计软件
💻 CPP
字号:
// WdycForm.cpp : implementation file
//

#include "stdafx.h"
#include "cvenus.h"
#include "WdycForm.h"

#include "ShwrjCalFuction.h"
#include "Preview.h"
#include "resource.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CWdycForm

IMPLEMENT_DYNCREATE(CWdycForm, CFormView)

CWdycForm::CWdycForm()
	: CFormView(CWdycForm::IDD)
{
	//{{AFX_DATA_INIT(CWdycForm)
		// NOTE: the ClassWizard will add member initialization here
	//}}AFX_DATA_INIT
}

CWdycForm::~CWdycForm()
{
}

void CWdycForm::DoDataExchange(CDataExchange* pDX)
{
	CFormView::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CWdycForm)
	DDX_Control(pDX, IDC_SPREAD1, m_SJSR);
	//}}AFX_DATA_MAP
}


BEGIN_MESSAGE_MAP(CWdycForm, CFormView)
	ON_WM_CONTEXTMENU()
	//{{AFX_MSG_MAP(CWdycForm)
	ON_WM_CREATE()
	ON_COMMAND(ID_SHWRJ_OPEN, OnShwrjOpen)
	ON_COMMAND(ID_SHWRJ_CALC, OnShwrjCalc)
	ON_COMMAND(ID_SHWRJ_SAVE, OnShwrjSave)
	ON_COMMAND(ID_SHWRJ_PRINTPREVIEW, OnShwrjPrintpreview)
	ON_COMMAND(ID_SHWRJ_PRINT, OnShwrjPrint)
	ON_WM_SIZE()
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CWdycForm diagnostics

#ifdef _DEBUG
void CWdycForm::AssertValid() const
{
	CFormView::AssertValid();
}

void CWdycForm::Dump(CDumpContext& dc) const
{
	CFormView::Dump(dc);
}
#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CWdycForm message handlers

int CWdycForm::OnCreate(LPCREATESTRUCT lpCreateStruct) 
{
	if (CFormView::OnCreate(lpCreateStruct) == -1)
		return -1;
	
	// TODO: Add your specialized creation code here
	GetParentFrame()->SetWindowText(_T("水合物形成温度预测"));
	
	return 0;
}

void CWdycForm::OnInitialUpdate() 
{
	CFormView::OnInitialUpdate();
	
/*	int i,j;

	m_SJSR.SetMaxRows(8);
	m_SJSR.SetMaxCols(5);
    
	m_SJSR.SetDisplayColHeaders(FALSE);//取消表头
	m_SJSR.SetDisplayRowHeaders(FALSE);//取消表头
    m_SJSR.SetGridShowHoriz(FALSE);//不显示网格线
	m_SJSR.SetGridShowVert(FALSE);//不显示网格线

	m_SJSR.SetRow(-1);
	m_SJSR.SetCol(-1);
	m_SJSR.SetAction(3);
	m_SJSR.SetFontName("宋体");
	m_SJSR.SetFontSize(12);

	m_SJSR.SetCol(3);
	m_SJSR.SetRow(1);
	m_SJSR.SetColWidth(3,12);
	m_SJSR.SetRowHeight(1,15);
	m_SJSR.SetValue("参数输入");

   //设置表格不可编辑
	for(i=1;i<=5;i++)
	   for(j=1;j<=8;j++)
	   {
			m_SJSR.SetCol(i);
			m_SJSR.SetRow(j);
		    m_SJSR.SetCellType(5);
	   }
	
    // 设置单元格线样式
    for(i=1;i<=5;i++)
	   for(j=2;j<=4;j++)
	   {
			m_SJSR.SetCol(i);
			m_SJSR.SetRow(j);
			m_SJSR.SetCellBorderType(16);//单元格为实框
			m_SJSR.SetCellBorderStyle(1);//实线
			m_SJSR.SetCellBorderColor(RGB(0,0,0));//单元格边框颜色
			m_SJSR.SetAction(16);//激活
	   }

	
	m_SJSR.SetCol(1);
	m_SJSR.SetRow(2);
	m_SJSR.SetColWidth(1,12);
	m_SJSR.SetRowHeight(2,20);
	m_SJSR.SetValue("参数名称");
    
	m_SJSR.SetCol(1);
	m_SJSR.SetRow(3);
	m_SJSR.SetText("气体相对密度");
	m_SJSR.SetCol(1);
	m_SJSR.SetRow(4);
	m_SJSR.SetText("压力");
    m_SJSR.SetCol(1);
	m_SJSR.SetRow(4);

	m_SJSR.SetCol(2);
	m_SJSR.SetRow(2);
	m_SJSR.SetColWidth(2,10);
	m_SJSR.SetRowHeight(2,20);
	
	m_SJSR.SetValue("单位");
	m_SJSR.SetRow(3);
	m_SJSR.SetText("");
	m_SJSR.SetRow(4);
	m_SJSR.SetText("MPa");

	m_SJSR.SetCol(3);
	m_SJSR.SetRow(2);
	m_SJSR.SetColWidth(3,8);
	
	m_SJSR.SetValue("最小值");
	m_SJSR.SetRow(3);
	m_SJSR.SetText("0.55");
	m_SJSR.SetRow(4);
	m_SJSR.SetText("0");

	m_SJSR.SetCol(4);
	m_SJSR.SetRow(2);
	m_SJSR.SetColWidth(4,8);
	
	m_SJSR.SetValue("最大值");
	m_SJSR.SetRow(3);
	m_SJSR.SetText("1");
	m_SJSR.SetRow(4);
	m_SJSR.SetText("42");

	m_SJSR.SetCol(5);
	m_SJSR.SetRow(2);
	m_SJSR.SetColWidth(5,10);
	
	m_SJSR.SetValue("参数值");
    for(i=3;i<=4;i++)
	{
		m_SJSR.SetRow(i);
		m_SJSR.SetCellType(2);
		m_SJSR.SetTypeFloatDecimalPlaces(3);
		m_SJSR.SetTypeFloatMin(0);
		m_SJSR.SetTypeFloatMax(99999);
	}	

	m_SJSR.SetCol(3);
	m_SJSR.SetRow(6);
	m_SJSR.SetColWidth(3,10);
	m_SJSR.SetValue("计算结果");

	m_SJSR.SetCol(2);
	m_SJSR.SetRow(7);
	m_SJSR.SetColWidth(2,10);
	m_SJSR.SetValue("温度预测值");

	m_SJSR.SetCol(4);
	m_SJSR.SetRow(7);
	m_SJSR.SetCellType(5);
	m_SJSR.SetValue("℃");

	m_SJSR.SetCol(2);
	m_SJSR.SetRow(7);
    m_SJSR.SetCol2(2);
	m_SJSR.SetRow2(7);
	m_SJSR.SetBlockMode(TRUE);
	m_SJSR.SetCellBorderType(16);
	m_SJSR.SetCellBorderStyle(1);
	m_SJSR.SetCellBorderColor(RGB(0,0,0));
	m_SJSR.SetAction(16);
    m_SJSR.SetBlockMode(FALSE);

	m_SJSR.SetCol(3);
	m_SJSR.SetRow(7);
    m_SJSR.SetCol2(3);
	m_SJSR.SetRow2(7);
	m_SJSR.SetBlockMode(TRUE);
	m_SJSR.SetCellBorderType(16);
	m_SJSR.SetCellBorderStyle(1);
	m_SJSR.SetCellBorderColor(RGB(0,0,0));
	m_SJSR.SetAction(16);
    m_SJSR.SetBlockMode(FALSE);

	m_SJSR.SetCol(4);
	m_SJSR.SetRow(7);
    m_SJSR.SetCol2(4);
	m_SJSR.SetRow2(7);
	m_SJSR.SetBlockMode(TRUE);
	m_SJSR.SetCellBorderType(16);
	m_SJSR.SetCellBorderStyle(1);
	m_SJSR.SetCellBorderColor(RGB(0,0,0));
	m_SJSR.SetAction(16);
    m_SJSR.SetBlockMode(FALSE);

    m_SJSR.SetRow(8);
    m_SJSR.SetValue("  ");	
*/
}

BEGIN_EVENTSINK_MAP(CWdycForm, CFormView)
    //{{AFX_EVENTSINK_MAP(CWdycForm)
	ON_EVENT(CWdycForm, IDC_SPREAD1, 4 /* Change */, OnChangeSpread1, VTS_I4 VTS_I4)
	//}}AFX_EVENTSINK_MAP
END_EVENTSINK_MAP()

void CWdycForm::OnChangeSpread1(long Col, long Row) 
{
   double x1;
   double zxz1,zdz1;
   CString Temp1;
   m_SJSR.SetCol(5);
   m_SJSR.SetRow(3);   
   Temp1=m_SJSR.GetText();   
   x1=atof(Temp1);
   m_SJSR.SetCol(3);
   m_SJSR.SetRow(3);   
   zxz1=atof(m_SJSR.GetText());
   m_SJSR.SetCol(4);
   m_SJSR.SetRow(3);   
   zdz1=atof(m_SJSR.GetText());   

  if(x1>=zxz1&&x1<=zdz1)
  {
	  if(x1==1.0)
	  {
		  m_SJSR.SetCol(3);
		  m_SJSR.SetRow(4);   
		  m_SJSR.SetText("0.42");
		  m_SJSR.SetCol(4);
		  m_SJSR.SetRow(4);   
		  m_SJSR.SetText("27.57");
	  }
	  if(x1>=0.9&&x1<1.0)
	   {
		  m_SJSR.SetCol(3);
		  m_SJSR.SetRow(4);   
		  m_SJSR.SetText("0.49");
		  m_SJSR.SetCol(4);
		  m_SJSR.SetRow(4);   
		  m_SJSR.SetText("27.57");
	   }
	   if(x1>=0.8&&x1<0.9)
	   {
		  m_SJSR.SetCol(3);
		  m_SJSR.SetRow(4);   
		  m_SJSR.SetText("0.56");
		  m_SJSR.SetCol(4);
		  m_SJSR.SetRow(4);   
		  m_SJSR.SetText("27.57");
	   }
	   if(x1>=0.7&&x1<0.8)
	   {
		  m_SJSR.SetCol(3);
		  m_SJSR.SetRow(4);   
		  m_SJSR.SetText("0.69");
		  m_SJSR.SetCol(4);
		  m_SJSR.SetRow(4);   
		  m_SJSR.SetText("27.57");
	   }
	   if(x1>=0.6&&x1<0.7)
	   {
		  m_SJSR.SetCol(3);
		  m_SJSR.SetRow(4);   
		  m_SJSR.SetText("1.035");
		  m_SJSR.SetCol(4);
		  m_SJSR.SetRow(4);   
		  m_SJSR.SetText("27.57");
	   }
	   if(x1>=0.55&&x1<0.6)
	   {
		  m_SJSR.SetCol(3);
		  m_SJSR.SetRow(4);   
		  m_SJSR.SetText("2.758");
		  m_SJSR.SetCol(4);
		  m_SJSR.SetRow(4);   
		  m_SJSR.SetText("27.57");
	   }
  }
  else
  {
      AfxMessageBox("密度输入数据非法");
	  m_SJSR.SetCol(5);
	  m_SJSR.SetRow(3);   
	  m_SJSR.SetText("");
	  m_SJSR.SetRow(2);   
	  m_SJSR.SetAction(0);		
  }	
	
}

void CWdycForm::OnShwrjOpen() 
{
	CString fileDialogFilter1="温度预测数据文件(*.WDYC)|*.WDYC||";
	const char fileDialogExt1[] = "WDYC";
	CFileDialog fileDialog1(TRUE,fileDialogExt1,NULL,OFN_FILEMUSTEXIST, fileDialogFilter1);
    if(fileDialog1.DoModal()==IDOK)
	{
	    CString filename1=fileDialog1.GetPathName();		
	    m_SJSR.LoadFromFile(filename1);		
	}
    UpdateData(FALSE);		
	
}

void CWdycForm::OnShwrjCalc() 
{
   CString Temp1,Temp2;
   double  wd,xx,md,yl,y;
   double zxz2,zdz2;
   char Temp3[30];
   m_SJSR.SetCol(5);
   m_SJSR.SetRow(3);   
   Temp1=m_SJSR.GetText();
	if(Temp1.IsEmpty())
	{
		AfxMessageBox(IDS_ERROR_SHW_INPUT);
		m_SJSR.SetAction(0);		
		return;
	}
   m_SJSR.SetRow(4);   
   Temp2=m_SJSR.GetText();
	if(Temp2.IsEmpty())
	{
		AfxMessageBox(IDS_ERROR_SHW_INPUT);
		m_SJSR.SetAction(0);		
		return;
	}
	 //Call 计算不生成水化物的最低温度,zdwd( y, rg)
   y=atof(Temp2);
   yl=y*1000.00/6.895;
   md=atof(Temp1);
 
   //取各项参数范围

   m_SJSR.SetCol(3);
   m_SJSR.SetRow(4);   
   zxz2=atof(m_SJSR.GetText());
   m_SJSR.SetCol(4);
   m_SJSR.SetRow(4);   
   zdz2=atof(m_SJSR.GetText());   
   
   if(y>=zxz2&&y<=zdz2)
   {
	   wd=zdwd(yl,md);//单位为F
	   xx=(wd - 32) * 5 / 9;//输出数据C  
	  //输出结果
	   gcvt(xx,7,Temp3);
	   m_SJSR.SetCol(2);
	   m_SJSR.SetRow(7);
	   m_SJSR.SetValue(Temp3);
   }
   else
   {
      AfxMessageBox("压力输入数据非法");
	  m_SJSR.SetCol(5);
	  m_SJSR.SetRow(4);   
	  m_SJSR.SetText("");
	  m_SJSR.SetAction(0);		
   }
	
}

void CWdycForm::OnShwrjSave() 
{
	UpdateData(TRUE);
	CString fileDialogFilter1="温度预测数据文件(*.WDYC)|*.WDYC||";
	const char fileDialogExt1[] = "WDYC";
	CFileDialog fileDialog1(FALSE,fileDialogExt1,NULL,OFN_FILEMUSTEXIST, fileDialogFilter1);
    if(fileDialog1.DoModal()==IDOK)
	{
	    CString filename1=fileDialog1.GetPathName();		
	    m_SJSR.SaveToFile(filename1,FALSE);		
	}		
	
}

void CWdycForm::OnShwrjPrintpreview() 
{
	CPreview dlg(&m_SJSR);
	dlg.DoModal();
	
}

void CWdycForm::OnShwrjPrint() 
{
    m_SJSR.SetAction(13);		
	
}

void CWdycForm::OnContextMenu(CWnd*, CPoint point)
{
	// CG: This block was added by the Pop-up Menu component	{		if (point.x == -1 && point.y == -1){			//keystroke invocation			CRect rect;			GetClientRect(rect);			ClientToScreen(rect);			point = rect.TopLeft();			point.Offset(5, 5);		}		CMenu menu;		VERIFY(menu.LoadMenu(IDR_POPUP_SHWRJ));		CMenu* pPopup = menu.GetSubMenu(0);		ASSERT(pPopup != NULL);		CWnd* pWndPopupOwner = this;//		while (pWndPopupOwner->GetStyle() & WS_CHILD)//			pWndPopupOwner = pWndPopupOwner->GetParent();		pPopup->TrackPopupMenu(TPM_LEFTALIGN | TPM_RIGHTBUTTON, point.x, point.y,			pWndPopupOwner);	}
}

void CWdycForm::OnSize(UINT nType, int cx, int cy) 
{
	CFormView::OnSize(nType, cx, cy);
	
	// TODO: Add your message handler code here
	if(m_SJSR.m_hWnd != NULL)
	{
		CRect rc;	
		GetClientRect(&rc);
		m_SJSR.SetWindowPos(NULL, rc.left, rc.top, rc.Width(), rc.Height(), NULL);
	}
	
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -