新一代32位操作系统WINDOWS 95舍弃了VBX控件,取而代之的是OCX控件。OCX控件具有
功能强大,界面美观的特点,然而许多参考书中并没有详细阐述OCX控件的使用方法,使
得一些如数据库表格,远程数据控件等接口复杂的OCX难于使用。这里将详细阐述OCX的
使用方法。
首先提醒读者要注意的是:使用OCX构件之前,必须登记注册,否则不能使用。安装
VISUAL C++时,系统自动注册登记软件附带的OCX控件。如果不幸没有登记,那么请使用
REGSVR32应用程序来注册。以VISUAL C++ 5.0为例,用AppWizard生成MFC应用程序分为
六个步骤,其中第三个步骤中可以指定支持OLE控制,也就是我们要使用的OCX控件(是
OLE的一种)。如果指定该选项,则AppWizard将自动向应用程序添加以下两处代码。
一处是为了说明OLE自动类如ColeDispathcDriver,自动向Stdafx.h中加入头文件a
fxdisp.h
二是在InitInstance函数中激活OLE控制容器:
AfxEnableContainer();
如果在利用AppWizard创建应用程序是未指定OLE控制选项,则可以手工加入以上两行代
码。
在生成应用框架后,首先应向应用程序加入OCX控件对应的类,如远程数据控件的缺
省名为RDC,而数据表格的缺省名为MSDBGRID。加入的过程是选择Project菜单项,选择
Add to Project,选择Components and Controls项,选择Registered ActiveX Contro
ls项,
双击你要加入的构件。
然后,通常是在对话框中加入OCX控制,这时应在对话框中单击右键,选择Insert
ActiveX Controls,选择你要加入的控件。这里以远程数据控件为例。
可以在设计时设定属性,当然,在运行时刻再设置属性值更具有灵活性。属性中比较关
键的是这几个:
(1) CursotDriver:(2)DataSourceName (3)SQL。具体的设置见所附的程序。
以下程序是一个无模式对话框的源代码:此程序段实现了一个与FOXPRO数据源相连接的
远程数据控件和一个与远程数据库控件相连的浏览数据库用的表格。数据源(DataSourc
e)名称为“档案”,其中包含几个表(Table),程序中选择的是表2。用户当然也可以
很轻松的在运行时刻改变连接对应的SQL属性,以便能够浏览同一数据库的不同表格,或
是不同数据库的不同表格。数据源的建立方法为:控制面板->32位ODBC->ADD…。
// Datatab.cpp : implementation file
#include "stdafx.h"
#include "Datatab.h"
#include
#include
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
//////////////////////////////////////// CDatatab dialog
CDatatab::CDatatab(CView * pView):CDialog()
{
m_pView = pView;
}
BOOL CDatatab::Create()
{
return CDialog::Create(CDatatab::IDD);
}
CDatatab::CDatatab(CWnd* pParent /*=NULL*/)
: CDialog(CDatatab::IDD, pParent)
{
//{{AFX_DATA_INIT(CDatatab)
//}}AFX_DATA_INIT
}
void CDatatab::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CDatatab)
DDX_Control(pDX, IDC_REMOTEDATACTL1, m_rdc1);
DDX_Control(pDX, IDC_DBGRID1, m_grid1);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CDatatab, CDialog)
//{{AFX_MSG_MAP(CDatatab)
ON_WM_CLOSE()
ON_WM_PAINT()
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////// CDatatab message handlers
void CDatatab::OnClose()
{
// TODO: Add your message handler code here and/or call default
DestroyWindow();
CDialog::OnClose();
}
void CDatatab::OnPaint()
{
CPaintDC dc(this); // device context for painting
// TODO: Add your message handler code here
// Do not call CDialog::OnPaint() for painting messages
}
BOOL CDatatab::OnInitDialog()
{
CDialog::OnInitDialog();
// TODO: Add extra initialization here
m_rdc1.SetDataSourceName("档案");
m_rdc1.SetSql(_T("SELECT 姓名 年龄 出生日期,from 表2"));
m_rdc1.SetCaption("数据仓库");
m_rdc1.SetUserName(_T("admin"));
m_rdc1.SetPassword(_T(""));
m_rdc1.SetCursorDriver(1);
m_rdc1.Refresh();
LPUNKNOWN pCursor=GetDlgItem(IDC_REMOTEDATACTL1)->GetDSCCursor();
ASSERT(pCursor!=NULL);
m_grid1.SetDataSource(pCursor); //bind the grid
m_grid1.BindProperty(0x9,GetDlgItem(IDC_REMOTEDATACTL1));
return TRUE; // return TRUE unless you set the focus to a control
// EXCEPTION: OCX Property Pages should return FALSE
}
阅读(914) | 评论(0) | 转发(1) |