利用activex控件实现对表格的显示与操作

发表于:2007-07-14来源:作者:点击数: 标签:
安红 在许多软件系统中,表格控件在对数据进行浏 览、编辑等操作方面都有良好表现。遗憾的是,Visual C++并没有提供直接支持表格操作的通用控制类。不 过,我们可以通过注册VisualC++5.O的ActiveX 控件中的Microsoft FlexGrid Control,version5.0 控件并添加
安红

  在许多软件系统中,表格控件在对数据进行浏
览、编辑等操作方面都有良好表现。遗憾的是,Visual
C++并没有提供直接支持表格操作的通用控制类。不
过,我们可以通过注册VisualC++5.O的ActiveX
控件中的Microsoft FlexGrid Control,version5.0
控件并添加到项目中来实现对表格的显示及操作。下
面将结合具体实例,介绍如何在对话框中加入表格控
件并实现对表格数据的显示、修改和保存。文中程序
是在中文WindowsNT4.0环境下,用VisualC++·5.0
编写的。
  1.在对话框中加入表他控件
  启动VisualC++5.0,利用AppWizard建立应
用程序框架。在AppWizard第一步(Stepl)选择基
于对话框(Dialogbased)的应用程序类型。·在
AppWizard第二步(Step2)选中ActiveX Controls
复选框,表示本应用程序支持ActiveX控件。其他均
接受缺省设置,按下"OK"按钮后AppWizard将自动
生成一个以对话框为主窗口的应用程序工程
Testtmp。
  单击Project菜单,选择Add To Project菜单
项,再单击Components and Controls菜单项,出现
Components and Controls Gallery对话框,双击
Registered ActiveX Controls列表项,在随后的列
表框中选择Mcrosoft FlexGrid Control,version
5.0控件;然后按下lnsert按钮,则该表格控件类
及相关文件便插入到当前工程文件中。同时该控件将
出现在对话框编辑器的控件工具栏中,可以像其他控
件那样拖放到正在建立的对话框中。
  在ResourceView中,选中IDD_TESTTMP_DIALOG
对话框并单击鼠标右键,在Properties对话框中将
Language属性改为Chinese(P.R.C)。然后打开
IDD_TESTTMP_DIALOG对话框并适当调整其大小,拖
动控件工具栏上的表格控件到该对话框的适当位置,
可通过修改表格控件属性确定表格的行、列数目。
2:  显示表格数据
  以显示天线方向图数据为例。假设天线方向图
数据以二进制格式保存在文件AEA02000.D01中,要
显示在表格中的数据包括序号、方位角和增益值三
项。利用ClassWizard为主窗口类CTesttmpDlg的表
格控件添加控件变量WGrid,然后在该类的对话框
初始化函数OnInitDialog()中做如下处理:
  (1) 打开天线方向图文件,将数据保存在结构
中。
(2)生成表格标题栏名称、行高及行宽
char Title[3][30]  =
(  _T("序号 NO"),
   _T("方位 AZ (度)°),
   _T("增益 GAIN  (dB)"),
for(i  = O;i<3;i++)
{m_Grid.SetRow(0);  //定位到第1行
m_Grid.SetCol(i);    //定位到第i列
m_Grid.SetText(Title[i]);    //设置标题栏名称
      m_Grid,SetColwidth(0,750);  //设置第1列表格项宽度
      m_Grid.SetColAlignment(0.  3);  //设置第1列标题名称以居中方
                                        式排列
  (3)根据天线方向图文件的记录数灵活设置表
格控件的行数及行高。
      m_Grid.SetRows(sTianF.BCount+l);    //设置表格控 件的行数
      for(int  i= O;  i < sTianF.BCount+1 ;i++)
m_Grid.SetRowHeight(i,270);//设置第I行的高度
(4)将天线方向图数据逐行显示在表格控件中。
Char cStr[8];
for(i=1;   i  < STianF.BCOUnt+1;i++)
m_Grid.SetRow(i);    //定位到第i行
m_Grid.SetCol(0);    //定位到第1列
Sprintf(CStr,"%d",i);    //将序号转化为字符型
m_Grid.SetText(CStr);  //在第i行第1列显示序号
Sprintf(CStr,"%d%,sTianF.STianX[i-1].iAz/10);  //将方
        位角数据从整理转化为字符型
m_Grid.SetCol(1);    //定位到第2 列
m_Grid.SetText(cStr);    //在第i行第2 列显示方位角数据
sprintf(cStr,"%5.2f",sTianFn.sTianX[i-l].dPower);//将
增益值从浮点型转化为字符型
m_Grid.SetCol(2);//定位到第3列
m_Grid.SetText(cStr);//在第i行第3列显示天线增益数据
(3)修改并保存表格数据
假设只对天线方向图中的增益数据做修改,而其他数据不能被修改

  在ResourceView中,打开IDD_TESTTMP_DIALOG
对话框,选中控件工具栏上的编辑控件插入到该对话
框的适当位置。在ClassWizard中为CTesttmpDlg的
编辑控件添加控件变量m_Edit,然后在该类的对话
框初始化函数OnInitDialog()中添加如下代码:
  m_Edit.ShowWindow(SW_HIDE);//隐藏该编辑控件
(1)修改表格数据

  在ClassWizard中为表格控件添加Click消息响
应函数 OnClickGrid(),为编辑控件添加
EN_KILLFOCUS消息响应函数OnKillfocusEdit()。
在消息响应函数mClickGrid()中做如下处理:
·做边界检查,如果鼠标击中的表格项是标题
行、表格第1、2列,则立即返回。

.计算鼠标击中的表格项的行宽width和行高
height,以及该表格项左上角在对话框客户区上的屏幕坐标x和y值。
  ·激活编辑控件并显示在表格的相应位置上以便接受输入数据的修改。
CString S;

  
  S=m_Grid.GetText();//取得该表格项显示的数据
  m_Edit.MoveWindow(X,y,Width,height);//改变编辑控作的显示位
                 置及大小
  m_Edit.ShowWindow(SW_SHow);//设置该编辑控件为可见状态
  m_Edit.EnableWindow(TRUE);//激活该编辑控件窗口
m_Edlt.SetFocus();//设置输入焦点
  m_Edit.SetWindowText(S);//将表格项数据显不在该编辑控件窗口
  在消息响应函数OnKillfocusEdit()中做如下处
理:
· 藏编辑控件并使控件窗口无效。
·如果最新键入的数据与表格项原显示数据不
同,则用新数据代替原数据。
  
  m_Grid.SetText(str);//重新设置表格项数据
  (2)保存表格数据
  在ClassWizard中,为"保存"按钮添加
BN_CLICKED消息响应函数OnSave(),.然后在消息响应函数OnSave()中做如下处理:
  ·逐行获取天线方向图的增益数据并保存在结构中。
  CString cstr;
or(int  i  = l;  i < sTianF.BCount+l;  i++)
m_Grid.SetRow(i);    //定位到第i行
m_Grid.SetCol(2);    //定位到第3列
cstr = m_Grid.GetText();    //获取该行列的表格项数据
sTian.sTianx[i-1].dPower=atof(cstr);//将数据保存
                   到结构中
将结构数据写到文件AEA02000.D01中保存起来
最后生成的用户界面如图1所示。

序号 方位 增益
1 -122 ...
2 ...   
3 ... ...
4     
5 ...   
6     
7     
8     
9     
10     
11     
12

原文转自:http://www.ltesting.net