📄 sxqthslform.cpp
字号:
// SxqthslForm.cpp : implementation file
//
#include "stdafx.h"
#include "cvenus.h"
#include "SxqthslForm.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
/////////////////////////////////////////////////////////////////////////////
// CSxqthslForm
IMPLEMENT_DYNCREATE(CSxqthslForm, CFormView)
CSxqthslForm::CSxqthslForm()
: CFormView(CSxqthslForm::IDD)
{
//{{AFX_DATA_INIT(CSxqthslForm)
// NOTE: the ClassWizard will add member initialization here
//}}AFX_DATA_INIT
}
CSxqthslForm::~CSxqthslForm()
{
}
void CSxqthslForm::DoDataExchange(CDataExchange* pDX)
{
CFormView::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CSxqthslForm)
DDX_Control(pDX, IDC_SPREAD1, m_SJSR);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CSxqthslForm, CFormView)
ON_WM_CONTEXTMENU()
//{{AFX_MSG_MAP(CSxqthslForm)
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()
/////////////////////////////////////////////////////////////////////////////
// CSxqthslForm diagnostics
#ifdef _DEBUG
void CSxqthslForm::AssertValid() const
{
CFormView::AssertValid();
}
void CSxqthslForm::Dump(CDumpContext& dc) const
{
CFormView::Dump(dc);
}
#endif //_DEBUG
/////////////////////////////////////////////////////////////////////////////
// CSxqthslForm message handlers
BEGIN_EVENTSINK_MAP(CSxqthslForm, CFormView)
//{{AFX_EVENTSINK_MAP(CSxqthslForm)
ON_EVENT(CSxqthslForm, IDC_SPREAD1, 4 /* Change */, OnChangeSpread1, VTS_I4 VTS_I4)
//}}AFX_EVENTSINK_MAP
END_EVENTSINK_MAP()
void CSxqthslForm::OnChangeSpread1(long Col, long Row)
{
double YL;
m_SJSR.SetCol(5);
m_SJSR.SetRow(4);
YL=atof(m_SJSR.GetText());
if(YL>=0.1&&YL<0.2)
{
m_SJSR.SetCol(3);
m_SJSR.SetRow(5);
m_SJSR.SetText("-50");
m_SJSR.SetCol(4);
m_SJSR.SetRow(5);
m_SJSR.SetText("108");
}
if(YL>=0.2&&YL<0.3)
{
m_SJSR.SetCol(3);
m_SJSR.SetRow(5);
m_SJSR.SetText("-50");
m_SJSR.SetCol(4);
m_SJSR.SetRow(5);
m_SJSR.SetText("132");
}
if(YL>=0.3&&YL<0.4)
{
m_SJSR.SetCol(3);
m_SJSR.SetRow(5);
m_SJSR.SetText("-50");
m_SJSR.SetCol(4);
m_SJSR.SetRow(5);
m_SJSR.SetText("144");
}
if(YL>=0.4&&YL<0.6)
{
m_SJSR.SetCol(3);
m_SJSR.SetRow(5);
m_SJSR.SetText("-40");
m_SJSR.SetCol(4);
m_SJSR.SetRow(5);
m_SJSR.SetText("156");
}
if(YL>=0.6&&YL<1.0)
{
m_SJSR.SetCol(3);
m_SJSR.SetRow(5);
m_SJSR.SetText("-40");
m_SJSR.SetCol(4);
m_SJSR.SetRow(5);
m_SJSR.SetText("168");
}
if(YL>=1.0&&YL<1.5)
{
m_SJSR.SetCol(3);
m_SJSR.SetRow(5);
m_SJSR.SetText("-40");
m_SJSR.SetCol(4);
m_SJSR.SetRow(5);
m_SJSR.SetText("180");
}
if(YL>=1.5&&YL<2.0)
{
m_SJSR.SetCol(3);
m_SJSR.SetRow(5);
m_SJSR.SetText("-40");
m_SJSR.SetCol(4);
m_SJSR.SetRow(5);
m_SJSR.SetText("180");
}
if(YL>=2.0&&YL<3.0)
{
m_SJSR.SetCol(3);
m_SJSR.SetRow(5);
m_SJSR.SetText("-30");
m_SJSR.SetCol(4);
m_SJSR.SetRow(5);
m_SJSR.SetText("180");
}
if(YL>=3.0&&YL<5.0)
{
m_SJSR.SetCol(3);
m_SJSR.SetRow(5);
m_SJSR.SetText("-30");
m_SJSR.SetCol(4);
m_SJSR.SetRow(5);
m_SJSR.SetText("180");
}
if(YL>=5.0&&YL<10.0)
{
m_SJSR.SetCol(3);
m_SJSR.SetRow(5);
m_SJSR.SetText("-30");
m_SJSR.SetCol(4);
m_SJSR.SetRow(5);
m_SJSR.SetText("180");
}
if(YL>=10.0&&YL<15.0)
{
m_SJSR.SetCol(3);
m_SJSR.SetRow(5);
m_SJSR.SetText("-20");
m_SJSR.SetCol(4);
m_SJSR.SetRow(5);
m_SJSR.SetText("180");
}
if(YL>=15.0&&YL<20.0)
{
m_SJSR.SetCol(3);
m_SJSR.SetRow(5);
m_SJSR.SetText("-20");
m_SJSR.SetCol(4);
m_SJSR.SetRow(5);
m_SJSR.SetText("180");
}
if(YL>=20.0&&YL<30.0)
{
m_SJSR.SetCol(3);
m_SJSR.SetRow(5);
m_SJSR.SetText("20");
m_SJSR.SetCol(4);
m_SJSR.SetRow(5);
m_SJSR.SetText("180");
}
if(YL>=30.0&&YL<40.0)
{
m_SJSR.SetCol(3);
m_SJSR.SetRow(5);
m_SJSR.SetText("20");
m_SJSR.SetCol(4);
m_SJSR.SetRow(5);
m_SJSR.SetText("180");
}
if(YL>=40.0&&YL<50.0)
{
m_SJSR.SetCol(3);
m_SJSR.SetRow(5);
m_SJSR.SetText("20");
m_SJSR.SetCol(4);
m_SJSR.SetRow(5);
m_SJSR.SetText("180");
}
if(YL>=50.0&&YL<60.0)
{
m_SJSR.SetCol(3);
m_SJSR.SetRow(5);
m_SJSR.SetText("30");
m_SJSR.SetCol(4);
m_SJSR.SetRow(5);
m_SJSR.SetText("180");
}
if(YL>=60.0&&YL<=70.0)
{
m_SJSR.SetCol(3);
m_SJSR.SetRow(5);
m_SJSR.SetText("30");
m_SJSR.SetCol(4);
m_SJSR.SetRow(5);
m_SJSR.SetText("180");
}
}
int CSxqthslForm::OnCreate(LPCREATESTRUCT lpCreateStruct)
{
if (CFormView::OnCreate(lpCreateStruct) == -1)
return -1;
// TODO: Add your specialized creation code here
GetParentFrame()->SetWindowText(_T("酸性气体含水量"));
return 0;
}
void CSxqthslForm::OnInitialUpdate()
{
CFormView::OnInitialUpdate();
// TODO: Add your specialized code here and/or call the base class
/* int i,j;
m_SJSR.SetMaxRows(13);
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<=13;j++)
{
m_SJSR.SetCol(i);
m_SJSR.SetRow(j);
m_SJSR.SetCellType(5);
}
// 设置单元格线样式
for(i=1;i<=5;i++)
for(j=2;j<=9;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.SetColWidth(1,25);
m_SJSR.SetRowHeight(1,20);
m_SJSR.SetRow(2);
m_SJSR.SetValue("参数名称");
m_SJSR.SetRow(3);
m_SJSR.SetText("天然气相对密度");
m_SJSR.SetRow(4);
m_SJSR.SetText("压力");
m_SJSR.SetRow(5);
m_SJSR.SetText("温度");
m_SJSR.SetRow(6);
m_SJSR.SetText("盐含量");
m_SJSR.SetRow(7);
m_SJSR.SetText("非酸性组分摩尔分数之和");
m_SJSR.SetRow(8);
m_SJSR.SetText("硫化氢摩尔分数");
m_SJSR.SetRow(9);
m_SJSR.SetText("二氧化碳摩尔分数");
m_SJSR.SetCol(2);
m_SJSR.SetColWidth(2,15);
m_SJSR.SetRowHeight(2,20);
m_SJSR.SetRow(2);
m_SJSR.SetValue("单位");
m_SJSR.SetRow(3);
m_SJSR.SetText("无因次");
m_SJSR.SetRow(4);
m_SJSR.SetText("MPa");
m_SJSR.SetRow(5);
m_SJSR.SetText("℃");
m_SJSR.SetRow(6);
m_SJSR.SetText("%");
m_SJSR.SetRow(7);
m_SJSR.SetText("");
m_SJSR.SetRow(8);
m_SJSR.SetText("");
m_SJSR.SetRow(9);
m_SJSR.SetText("");
m_SJSR.SetCol(3);
m_SJSR.SetColWidth(3,8);
m_SJSR.SetRow(2);
m_SJSR.SetValue("最小值");
m_SJSR.SetRow(3);
m_SJSR.SetText("0.55");
m_SJSR.SetRow(4);
m_SJSR.SetText("0");
m_SJSR.SetRow(5);
m_SJSR.SetText("0");
m_SJSR.SetRow(6);
m_SJSR.SetText("0");
m_SJSR.SetRow(7);
m_SJSR.SetText("0");
m_SJSR.SetRow(8);
m_SJSR.SetText("0");
m_SJSR.SetRow(9);
m_SJSR.SetText("0");
m_SJSR.SetCol(4);
m_SJSR.SetColWidth(4,8);
m_SJSR.SetRow(2);
m_SJSR.SetValue("最大值");
m_SJSR.SetRow(3);
m_SJSR.SetText("1.0");
m_SJSR.SetRow(4);
m_SJSR.SetText("70");
m_SJSR.SetRow(5);
m_SJSR.SetText("180");
m_SJSR.SetRow(6);
m_SJSR.SetText("50");
m_SJSR.SetRow(7);
m_SJSR.SetText("1");
m_SJSR.SetRow(8);
m_SJSR.SetText("0.0065");
m_SJSR.SetRow(9);
m_SJSR.SetText("1");
m_SJSR.SetCol(5);
m_SJSR.SetColWidth(5,12);
m_SJSR.SetRow(2);
m_SJSR.SetValue("参数值");
for(i=3;i<=9;i++)
{
m_SJSR.SetRow(i);
m_SJSR.SetCellType(2);
m_SJSR.SetTypeFloatDecimalPlaces(5);
m_SJSR.SetTypeFloatMin(-40);
m_SJSR.SetTypeFloatMax(99999);
}
m_SJSR.SetCol(3);
m_SJSR.SetRow(11);
m_SJSR.SetColWidth(3,10);
m_SJSR.SetValue("计算结果");
m_SJSR.SetCol(2);
m_SJSR.SetRow(12);
m_SJSR.SetColWidth(2,10);
m_SJSR.SetValue("含水量");
m_SJSR.SetCol(4);
m_SJSR.SetRow(12);
m_SJSR.SetCellType(5);
m_SJSR.SetValue("g/m^3");
m_SJSR.SetCol(2);
m_SJSR.SetRow(12);
m_SJSR.SetCol2(2);
m_SJSR.SetRow2(12);
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(12);
m_SJSR.SetCol2(3);
m_SJSR.SetRow2(12);
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(12);
m_SJSR.SetCol2(4);
m_SJSR.SetRow2(12);
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(13);
m_SJSR.SetValue(" ");
*/
}
void CSxqthslForm::OnShwrjOpen()
{
CString fileDialogFilter1="酸性气体含水量(*.SXHL)|*.SXHL||";
const char fileDialogExt1[] = "SXHL";
CFileDialog fileDialog1(TRUE,fileDialogExt1,NULL,OFN_FILEMUSTEXIST, fileDialogFilter1);
if(fileDialog1.DoModal()==IDOK)
{
CString filename1=fileDialog1.GetPathName();//+fileDialog.GetFileName();
m_SJSR.LoadFromFile(filename1);
}
UpdateData(FALSE);
}
void CSxqthslForm::OnShwrjCalc()
{
double wh1,wh2,wh,wc1,wc2,wc,whc,t,p,w,y,yh,yc;
double s,w0,cr,cs,xx;
//含酸性气体组分(硫化氢或二氧化碳)的天然气含水量
//y--非酸性组分摩尔分数之和
//yh--硫化氢摩尔分数
//yc--二氧化碳摩尔分数
//wh--纯硫化氢在给定温度、压力下的含水量
//wc--纯二氧化碳在给定温度、压力下的含水量
//输入数据t(K),p(MPa),yh,yc,y
//输出数据whc
CString Temp1,Temp2,Temp4,Temp5,Temp6,Temp7,Temp8;
char Temp3[30];
m_SJSR.SetCol(5);
m_SJSR.SetRow(3);
Temp1=m_SJSR.GetText();
xx = atof(Temp1);
m_SJSR.SetRow(4);
Temp4=m_SJSR.GetText();
p=atof(Temp4);
m_SJSR.SetRow(5);
Temp2=m_SJSR.GetText();
t=atof(Temp2);
m_SJSR.SetRow(6);
Temp5=m_SJSR.GetText();
s=atof(Temp5);
m_SJSR.SetRow(7);
Temp6=m_SJSR.GetText();
y=atof(Temp6);
m_SJSR.SetRow(8);
Temp7=m_SJSR.GetText();
yh=atof(Temp7);
m_SJSR.SetRow(9);
Temp8=m_SJSR.GetText();
yc=atof(Temp8);
//判断数据有效性
int i;
double zxz[10],zdz[10],qz[10],zfz;
zfz=y+yh+yc;
for(i=3;i<=9;i++)
{
m_SJSR.SetRow(i);
m_SJSR.SetCol(3);
zxz[i]=atof(m_SJSR.GetText());
m_SJSR.SetCol(4);
zdz[i]=atof(m_SJSR.GetText());
m_SJSR.SetCol(5);
qz[i]=atof(m_SJSR.GetText());
}
if(qz[3]>zxz[3]&&qz[3]<=zdz[3]&&qz[4]>zxz[4]&&qz[4]<=zdz[4]&&qz[5]>zxz[5]&&qz[5]<=zdz[5]&&qz[6]>zxz[6]&&qz[6]<=zdz[6]&&qz[7]>zxz[7]&&qz[7]<=zdz[7]&&qz[8]>zxz[8]&&qz[8]<=zdz[8]&&qz[9]>zxz[9]&&qz[9]<=zdz[9]&&zfz==1.0)
{
w0=hslt(t,p);
cr=crt(xx,t);
cs=0.9999-0.003315*s-0.0003444*pow(s,2)+0.000007714*pow(s,3)-0.00000011046*pow(s,4);
w=w0*cr*cs;
wh1 = -194.71 + 0.89295 * t + 0.002088 * pow(t,2) - 0.000015517 * pow(t,3) + 0.00000001973 * pow(t,4);
wh2 = -0.071715 * p + 0.0009279 * pow(p,2) - 0.000004889 * pow(p,3) + 0.000000009146 * pow(p,4);
wh = wh1 + wh2;
wc1 = -2.1553 - 0.018766 * t + 0.00003203 * pow(t,2) + 0.0000005322 * pow(t,3) - 0.0000000009472 * pow(t,4);
wc2 = -0.052825 * p + 0.0006786 * pow(p,2) - 0.000003696 * pow(p,3) + 0.000000007076 * pow(p,4);
wc = wc1 + wc2;
whc = w * y + wh * yh + wc * yc;
//输出结果
if (whc<0)
AfxMessageBox("不符合生产实际,请验证数据后再计算");
else
{
gcvt(whc,7,Temp3);
m_SJSR.SetCol(2);
m_SJSR.SetRow(12);
m_SJSR.SetValue(Temp3);
}
}
else
{
AfxMessageBox("输入数据非法,请验证再计算");
}
}
void CSxqthslForm::OnShwrjSave()
{
UpdateData(TRUE);
CString fileDialogFilter1="酸性气体含水量(*.SXHL)|*.SXHL||";
const char fileDialogExt1[] = "SXHL";
CFileDialog fileDialog1(FALSE,fileDialogExt1,NULL,OFN_FILEMUSTEXIST, fileDialogFilter1);
if(fileDialog1.DoModal()==IDOK)
{
CString filename1=fileDialog1.GetPathName();//+fileDialog.GetFileName();
m_SJSR.SaveToFile(filename1,FALSE);
}
}
void CSxqthslForm::OnShwrjPrintpreview()
{
// TODO: Add your command handler code here
CPreview dlg(&m_SJSR);
dlg.DoModal();
}
void CSxqthslForm::OnShwrjPrint()
{
// TODO: Add your command handler code here
m_SJSR.SetAction(13);
}
void CSxqthslForm::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 CSxqthslForm::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 + -