新一代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中加入头文件afxdisp.h
二是在InitInstance函数中激活OLE控制容器:
AfxEnableContainer();
如果在利用AppWizard创建应用程序是未指定OLE控制选项,则可以手工加入以上两行代码。
在生成应用框架后,首先应向应用程序加入OCX控件对应的类,如远程数据控件的缺省名为RDC,而数据表格的缺省名为MSDBGRID。加入的过程是选择Project菜单项,选择Add to Project,选择Components and Controls项,选择Registered ActiveX Controls项,
双击你要加入的构件。
然后,通常是在对话框中加入OCX控制,这时应在对话框中单击右键,选择Insert ActiveX Controls,选择你要加入的控件。这里以远程数据控件为例。
可以在设计时设定属性,当然,在运行时刻再设置属性值更具有灵活性。属性中比较关键的是这几个:
(1) CursotDriver:(2)DataSourceName (3)SQL。具体的设置见所附的程序。
以下程序是一个无模式对话框的源代码:此程序段实现了一个与FOXPRO数据源相连接的远程数据控件和一个与远程数据库控件相连的浏览数据库用的表格。数据源(DataSource)名称为“档案”,其中包含几个表(Table),程序中选择的是表2。用户当然也可以很轻松的在运行时刻改变连接对应的SQL属性,以便能够浏览同一数据库的不同表格,或是不同数据库的不同表格。数据源的建立方法为:控制面板->32位ODBC->ADD…。
// Datatab.cpp : implementation file
#include "stdafx.h"
#include "Datatab.h"
#include <afxcmn.h>
#include <afxcview.h>
#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
}