打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
MFCGridCtrl的使用方法
MFCGridCtrl的使用方法
2013-06-29 16:53 14741人阅读 评论(4)  举报
 分类:
C++(12) 
http://www.codeproject.com/KB/miscctrl/gridctrl.aspx下载Keith Rule的源码,包括他的实例源码
1、新建基于Dialog的MFC工程GridCtrlTest
2、将GridCtrl.cpp、GridCtrl.h等文件加到工程中,并编译
我添加GridCtrl_src下文件后,VS2010编译报错:
gridctrltest\memdc.h(26): error C2011: “CMemDC”:“class”类型重定义
我认为微软已经实现了他们自己的CMemDC 类库,所以使用Keith Rule到memory DC库会报重定义错误。
解决办法重命名CMemDC为GCMemDC,记得同时修改MemDC.h及GridCtrl.cpp所有用到的CMemDC项。
编译通过。
3、在对话框CGridCtrlTestDlg中增加Custom Control,就是工具箱中的人头像
并设置Custom Control的属性:
注意:Class项的值一定要是MFCGridCtrl,不然就无法将控件关联起来。
4、在文件GridCtrlTestDlg.h为类CGridCtrlTestDlg增加成员
#pragma once
#include "GridCtrl.h"
// CGridCtrlTestDlg 对话框
class CGridCtrlTestDlg : public CDialogEx
{
// 构造
public:
CGridCtrlTestDlg(CWnd* pParent = NULL); // 标准构造函数
CGridCtrl m_pGrid;
void GridCtrlInit();
// 对话框数据
enum { IDD = IDD_GRIDCTRLTEST_DIALOG };
5、在GridCtrlTestDlg.cpp文件里的函数DoDataExchange增加映射:
void CGridCtrlTestDlg::DoDataExchange(CDataExchange* pDX)
{
CDialogEx::DoDataExchange(pDX);
DDX_GridControl(pDX, IDC_MY_GRIDCTRL, m_pGrid);
}
6、让控件显示起来,在OnInitDialog函数里初始化GridCtrl
BOOL CGridCtrltest2Dlg::OnInitDialog()
{
CDialogEx::OnInitDialog();
// 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动
//  执行此操作
SetIcon(m_hIcon, TRUE);   // 设置大图标
SetIcon(m_hIcon, FALSE);  // 设置小图标
// TODO: 在此添加额外的初始化代码
GridCtrlInit();
return TRUE;  // 除非将焦点设置到控件,否则返回 TRUE
}
文件最后添加GridCtrlInit()实现函数
void CGridCtrltest2Dlg::GridCtrlInit()
{
m_pGrid.SetEditable(true);
m_pGrid.SetTextBkColor(RGB(0xFF, 0xFF, 0xE0));//黄色背景
m_pGrid.SetRowCount(8); //初始为10行
m_pGrid.SetColumnCount(8); //初始化为11列
m_pGrid.SetFixedRowCount(1); //表头为一行
m_pGrid.SetFixedColumnCount(1); //表头为一列
for (int row = 0; row < m_pGrid.GetRowCount(); row++)
for (int col = 0; col < m_pGrid.GetColumnCount(); col++)
{
//设置表格显示属性
GV_ITEM Item;
Item.mask = GVIF_TEXT|GVIF_FORMAT;
Item.row = row;
Item.col = col;
m_pGrid.SetRowHeight(row,25); //设置各行高
m_pGrid.SetColumnWidth(0,64); //设置0列宽
m_pGrid.SetColumnWidth(col,64); //设置各列宽
if(row==0&&col==0) //第(0,0)格
{
Item.nFormat = DT_CENTER|DT_WORDBREAK;
Item.strText.Format(_T("报表显示"),col);
}
else if (row < 1) //设置0行表头显示
{
Item.nFormat = DT_CENTER|DT_WORDBREAK;
Item.strText.Format(_T(" 项目%d"),col);
}
else if (col < 1) //设置0列表头显示
{
if(row< m_pGrid.GetRowCount())
{
Item.nFormat = DT_CENTER|DT_VCENTER|DT_SINGLELINE|DT_END_ELLIPSIS;
Item.strText.Format(_T("第%d次"),row);
}
}
else
{
Item.nFormat = DT_CENTER|DT_VCENTER|DT_SINGLELINE|DT_END_ELLIPSIS;
Item.strText.Format(_T(""),2);
}
m_pGrid.SetItem(&Item);
}
}
运行结果效果如下:
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
ASPxGridView动态创建表格列编辑模板
将DataTable行列转换通用方法
DataSet导出到Excel比较完整的解决方案(二)--服务器端生成文件
PS 滤镜算法原理
DataSet导出到Excel
成功el-form label设置line-height
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服