Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1683372
  • 博文数量: 584
  • 博客积分: 13857
  • 博客等级: 上将
  • 技术积分: 11883
  • 用 户 组: 普通用户
  • 注册时间: 2009-12-16 09:34

分类: WINDOWS

2011-03-25 15:09:38

    新一代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
}
 
阅读(891) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~