212 lines
5.0 KiB
C++
212 lines
5.0 KiB
C++
|
|
// AutomatedCheckingSystem_ATPDlg.cpp: 实现文件
|
|
//
|
|
|
|
#include "pch.h"
|
|
#include "framework.h"
|
|
#include "AutomatedCheckingSystem_ATP.h"
|
|
#include "AutomatedCheckingSystem_ATPDlg.h"
|
|
#include "afxdialogex.h"
|
|
|
|
#ifdef _DEBUG
|
|
#define new DEBUG_NEW
|
|
#endif
|
|
|
|
|
|
// 用于应用程序“关于”菜单项的 CAboutDlg 对话框
|
|
|
|
class CAboutDlg : public CDialogEx
|
|
{
|
|
public:
|
|
CAboutDlg();
|
|
|
|
// 对话框数据
|
|
#ifdef AFX_DESIGN_TIME
|
|
enum { IDD = IDD_ABOUTBOX };
|
|
#endif
|
|
|
|
protected:
|
|
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持
|
|
|
|
// 实现
|
|
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()
|
|
|
|
|
|
// CAutomatedCheckingSystemATPDlg 对话框
|
|
|
|
|
|
|
|
CAutomatedCheckingSystemATPDlg::CAutomatedCheckingSystemATPDlg(CWnd* pParent /*=nullptr*/)
|
|
: CDialogEx(IDD_AUTOMATEDCHECKINGSYSTEM_ATP_DIALOG, pParent)
|
|
{
|
|
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
|
|
}
|
|
|
|
void CAutomatedCheckingSystemATPDlg::DoDataExchange(CDataExchange* pDX)
|
|
{
|
|
CDialogEx::DoDataExchange(pDX);
|
|
}
|
|
|
|
BEGIN_MESSAGE_MAP(CAutomatedCheckingSystemATPDlg, CDialogEx)
|
|
ON_WM_SYSCOMMAND()
|
|
ON_WM_PAINT()
|
|
ON_WM_QUERYDRAGICON()
|
|
ON_BN_CLICKED(IDC_BUTTON_TEST, &CAutomatedCheckingSystemATPDlg::OnBnClickedButtonTest)
|
|
END_MESSAGE_MAP()
|
|
|
|
|
|
// CAutomatedCheckingSystemATPDlg 消息处理程序
|
|
|
|
BOOL CAutomatedCheckingSystemATPDlg::OnInitDialog()
|
|
{
|
|
CDialogEx::OnInitDialog();
|
|
|
|
// 将“关于...”菜单项添加到系统菜单中。
|
|
|
|
// IDM_ABOUTBOX 必须在系统命令范围内。
|
|
ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
|
|
ASSERT(IDM_ABOUTBOX < 0xF000);
|
|
|
|
CMenu* pSysMenu = GetSystemMenu(FALSE);
|
|
if (pSysMenu != nullptr)
|
|
{
|
|
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);
|
|
}
|
|
}
|
|
|
|
// 设置此对话框的图标。 当应用程序主窗口不是对话框时,框架将自动
|
|
// 执行此操作
|
|
SetIcon(m_hIcon, TRUE); // 设置大图标
|
|
SetIcon(m_hIcon, FALSE); // 设置小图标
|
|
|
|
// TODO: 在此添加额外的初始化代码
|
|
|
|
return TRUE; // 除非将焦点设置到控件,否则返回 TRUE
|
|
}
|
|
|
|
void CAutomatedCheckingSystemATPDlg::OnSysCommand(UINT nID, LPARAM lParam)
|
|
{
|
|
if ((nID & 0xFFF0) == IDM_ABOUTBOX)
|
|
{
|
|
CAboutDlg dlgAbout;
|
|
dlgAbout.DoModal();
|
|
}
|
|
else
|
|
{
|
|
CDialogEx::OnSysCommand(nID, lParam);
|
|
}
|
|
}
|
|
|
|
// 如果向对话框添加最小化按钮,则需要下面的代码
|
|
// 来绘制该图标。 对于使用文档/视图模型的 MFC 应用程序,
|
|
// 这将由框架自动完成。
|
|
|
|
void CAutomatedCheckingSystemATPDlg::OnPaint()
|
|
{
|
|
if (IsIconic())
|
|
{
|
|
CPaintDC dc(this); // 用于绘制的设备上下文
|
|
|
|
SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
|
|
|
|
// 使图标在工作区矩形中居中
|
|
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;
|
|
|
|
// 绘制图标
|
|
dc.DrawIcon(x, y, m_hIcon);
|
|
}
|
|
else
|
|
{
|
|
CDialogEx::OnPaint();
|
|
}
|
|
}
|
|
|
|
//当用户拖动最小化窗口时系统调用此函数取得光标
|
|
//显示。
|
|
HCURSOR CAutomatedCheckingSystemATPDlg::OnQueryDragIcon()
|
|
{
|
|
return static_cast<HCURSOR>(m_hIcon);
|
|
}
|
|
|
|
|
|
|
|
void CAutomatedCheckingSystemATPDlg::OnBnClickedButtonTest()
|
|
{
|
|
COleVariant
|
|
covTrue((short)TRUE),
|
|
covFalse((short)FALSE),
|
|
covOptional((long)DISP_E_PARAMNOTFOUND, VT_ERROR);
|
|
|
|
CApplication app;
|
|
|
|
if (!app.CreateDispatch(TEXT("Excel.Application")))
|
|
{
|
|
AfxMessageBox(TEXT("Couldn't start Excel and get Application object."));
|
|
return;
|
|
}
|
|
|
|
app.put_Visible(TRUE);
|
|
|
|
CWorkbooks books;
|
|
CWorkbook book;
|
|
CWorksheets sheets;
|
|
CWorksheet sheet;
|
|
CRange range;
|
|
CFont0 font;
|
|
|
|
books = app.get_Workbooks();
|
|
book = books.Add(covOptional);
|
|
|
|
|
|
|
|
sheets = book.get_Sheets();
|
|
sheet = sheets.get_Item(COleVariant((short)1));
|
|
|
|
range = sheet.get_Range(COleVariant(TEXT("A1")), COleVariant(TEXT("A1")));
|
|
range.put_Value2(COleVariant(TEXT("Average precipation (mm)")));
|
|
|
|
range.put_RowHeight(COleVariant((short)50));
|
|
range.put_ColumnWidth(COleVariant((short)100));
|
|
|
|
range = sheet.get_Range(COleVariant(TEXT("A1")), COleVariant(TEXT("C1")));
|
|
range.Merge(covOptional);
|
|
range = sheet.get_Range(COleVariant(TEXT("B2")), COleVariant(TEXT("B2")));
|
|
range.put_Value2(COleVariant(TEXT("Acapulco")));
|
|
range = sheet.get_Range(COleVariant(TEXT("C2")), COleVariant(TEXT("C2")));
|
|
range.put_Value2(COleVariant(TEXT("Amsterdam")));
|
|
|
|
CShapes shapes = sheet.get_Shapes();
|
|
range = sheet.get_Range(COleVariant(TEXT("B16")), COleVariant(TEXT("J26")));
|
|
|
|
shapes.AddPicture(TEXT("D:\\Test1.jpg"), false, true, (float)range.get_Left().dblVal, (float)range.get_Top().dblVal,
|
|
(float)range.get_Width().dblVal, (float)range.get_Height().dblVal);
|
|
|
|
|
|
}
|