如何用VC++和Visual Foxpro进行ActiveX数据通讯

原创 2001年02月12日 18:29:00

如何用VC++和Visual Foxpro进行ActiveX数据通讯

粟利民 孙强

摘要 本文描述了如何利用自动服务器Active Automation,在VC++中与Visual Foxpro进行数据通讯的方法。通过自动服务器,圆满地解决了各种数据类型的交换问题。

关键词 VC++,Visual Foxpro,ActiveX Automation,数据通讯

在进行软件开发的过程中,如何在不同的编程工具之间进行数据交换和通讯,需要进行不断的探索和总结。我们在开发机械CAD仿真软件的过程中,遇到了在VC++中读取和修改Visual Foxpro中数据的问题。经过许多次的试验,我们通过采用自动服务器(ActiveX Automation)的方法圆满解决了这个问题。

自动服务器,以前称为OLE Automation,后来称为ActiveX OLE Automation,就是编写能被其他程序调用的代码。其他程序不是以DLL的孤立方式而是直接调用自动服务器的用户代码。这其中比较难理解的概念是:自动服务器用户代码向其他应用程序揭示了属性(变量)和方法(函数)。

以下将以整型和双精度(对浮点型同样适用)的数据传递为例,讲述如何用ActiveX Automation在VC++和Visual Foxpro之间进行数据通讯,例子中的编程工具为VC++ 5.0和Visual Foxpro 5.0。

一.在Visual Foxpro中创建自动服务器

1.在Visual Foxpro中定义服务器类(此例中为CDATA类)

首先在某目录下新建一工程,在工程管理器中选择代码栏,同一目录下新建一程序(如MyServer.prg),并在此程序文件中定义服务器类。

*File Name: MyServer.prg

DEFINE CLASS CData AS Custom OLEPUBLIC

*对VC++而言, para1为整型, para2为double型

para1=123

para2=123.123

PROCEDURE ChangeData

this.para1=this.para1*2

this.para2=this.para2*2

RETURN

ENDPROC

ENDDEFINE

2.将上述程序联编为可执行程序(如MyServer.exe)

选中程序MyServer,点击“连编”按钮,选择“连编可执行程序”选项,并按确定,便可生成可执行程序。

二.在VC++中对自动服务器进行测试

1.关闭Visual Foxpro,在VC++中选择菜单项“File-New”,再选择“Projects”中的“MFC AppWizard (exe)”选项,随后按默认方式生成“Dialog Based”的工程项目(此例中工程名为MyTest)。

2.在MyTest.cpp中的APP类的InitInstance()函数开头加入OLE使能

BOOL CMyTestApp::InitInstance()

{

BOOL OleEnable=AfxOleInit();

if(!OleEnable) return FALSE;

……

}

3.在ClassWizard中选“Automation”中的“Add Class-From a type library”。在“Import from type library”对话框中找到刚才所创建的Visual Foxpro工程目录下的tlb文件(如MyServer.tlb)并选择“打开”按钮,会有提示说明将要从Lib中生成CDATA类,点击OK按钮加以确认,将自动在项目中加入与CDATA类有关的文件MyServer.cpp和MyServer.h。在ClassView中可查看CDATA类的函数,如GetPara1()、SetPara1()和CHANGEDATA()等。这里要注意类名CDATA和函数名CHANGEDATA()的大小写请参看具体的头文件MyServer.h。

4.在对话框类(此例中为CMyTestDlg)的头文件MyTestDlg.h的开头部分,将CDATA类的头文件MyServer.h包含进来。随后定义CDATA类的实例m_data作为对话框类的成员变量。

// MyTestDlg.h : header file

#include "myserver.h"

……

class CMyTestDlg : public CDialog

{

// Construction

public:

CMyTestDlg(CWnd* pParent = NULL); // standard constructor

private:

CDATA m_data; //定义CDATA类的实例m_data

……

}

……

5.在对话框的初始化部分(如InitDialog()函数中)加入

m_data.CreateDispatch(“MyServer.CDATA);

6.使用自动服务器的通讯编程

此例中,我们在对话框中设置一命令按钮“Test”,通过点击该按钮来对自动服务器进行测试。

void CMyTestDlg::OnButtonTest()

{

//首先利用CDATA类的GetPara1()等取值函数取出Foxpro中的变量值,

//再利用CDATA类SetPara1()等赋值函数来修改Foxpro中的这些变量值

//也可以在VC++中调用CDATA类的函数CHANGEDATA()来修改变量值

//定义tagVARIANT型变量,请参看有关tagVARINAT的帮助

tagVARIANT mypara1, mypara2;

mypara1=m_data.GetPara1(); //读取Foxpro中的变量值para1

mypara2=m_data.GetPara2(); //读取Foxpro中的变量值para2

//检验读取数据是否正确(Foxpro设定为123和123.123)

if(mypara1.iVal==123)

MessageBox("mypara1.iVal=123");

if(mypara2.dblVal==123.123)

MessageBox("mypara2.dblVal=123.123");



//修改这些变量值(也可用调用CHANGEDATA()的方式来修改变量值)

mypara1.iVal=mypara1.iVal*2; //整型变量乘以2

mypara2.dblVal=mypara2.dblVal*2.0; //double型变量也乘以2

m_data.SetPara1(mypara1); //向Foxpro赋值

m_data.SetPara2(mypara2);

//再次读取Foxpro中的变量值

mypara1=m_data.GetPara1();

mypara2=m_data.GetPara2();

//检验修改数据是否正确(应改为246和246.246)

if(mypara1.iVal==246)

MessageBox("mypara1.iVal=246");

if(mypara2.dblVal==246.246)

MessageBox("mypara2.dblVal=246.246");

}

上面讲述在VC++中如何与Visual Foxpro进行整型和双精度型变量的数据通讯的方法。通过查看tagVARIANT结构的帮助文件,可以看到其中有一个成员为VARTYPE vt。可以说vt是非常重要的,在VC++中读取Foxpro中的数据后,vt的值就决定了其数据的类型。在上例中,mypara1.vt等于3而mypara2.vt等于5,表示它们的数据类型分别为整型和双精度型。在VC++中也可根据tagVARIANT变量的vt值来判断所读取的数据的确切类型。我们还可以看到,不同类型的数据,在VC++中的访问方式也有所不同。如整型用iVal,而双精度型用dblVal,上例中分别为mypara1.iVal和mypara2.dblVal。

以上是我们软件开发小组在实际编程中总结出的数据通讯的方法,有关其他类型如字符串的数据传递则比较复杂些。鉴于篇幅的问题,在此我们不再一一陈述,有兴趣的同行和朋友可与我们联系,共同探讨和交流编程的心得和方法技巧。

 

如何用VC++和Visual Foxpro进行ActiveX数据通讯

2001年02月12日 18:29:00 如何用VC++和Visual Foxpro进行ActiveX数据通讯 粟利民 孙强 摘要 本文描述了如何利用自动服务器Active Automatio...
  • softart
  • softart
  • 2007年10月27日 07:50
  • 247

Visual foxpro 命令大全和函数大全

Visual foxpro 命令大全和函数大全 ? 在下一行显示表达式串 ?? 在当前行显示表达式串 @... 将数据按用户设定的格式显示在屏幕上或在打印机上打印 ACCEPT 把一个字符...
  • mrwu9902
  • mrwu9902
  • 2010年03月17日 15:25
  • 2779

Visual Foxpro 6.0教程

下载地址:网盘下载          本书从培养应用型、技能型人才的角度出发,系统地介绍了Visual FoxPro 6.0数据库系统的基础理论及应用系统及应用系统开发知识。全书共11章,其中第1章-...
  • cf406061841
  • cf406061841
  • 2017年08月31日 01:13
  • 216

Visual FoxPro数据库加密算法的研究与实现

摘  要:对于最初给定的随机种子,随机函数都会生成一个相同的数列。数据库数据随机加密,是一种利用随机函数的随机数序列与数据库数据进行异或等运算、实现数据库数据加密的方法。本文对数据库数据随机加密算法进...
  • feiyafei2008
  • feiyafei2008
  • 2010年05月25日 15:22
  • 1012

5.如何处理“不能退出FoxPro”的情况

5如何处理“不能退出FoxPro”的情况难度系数 êêê人气指数 90%问题详述为什么在程序连编后,单击Visual FoxPro的主窗口关闭按钮,提示“不能退出FoxPro”呢?专家解答由于在Vis...
  • zhanghongju
  • zhanghongju
  • 2009年07月14日 19:40
  • 4224

Visual FoxPRO 更新两表的语句

因工作需要,需使用VF对两表更新其中某(几)个字段中的数据,很久没用了,经测试成功,语句如下:select 1use 2008gzzk.067inde on l2 to aselect 2use bo...
  • _NET2004
  • _NET2004
  • 2008年12月25日 14:06
  • 2191

Visual FoxPro权威指南写作原稿及光盘下载

自从微软宣布停止开发Visual FoxPro之后,此类图书的出版也成了难题,但是至今仍有许多VFP的坚守者,到处搜罗这本7年前的图书。故放上本书的写作原稿,以飨读者。下载地址:http://down...
  • zhanghongju
  • zhanghongju
  • 2014年08月22日 03:58
  • 5123

Visual FoxPro9.0构建管理系统图解

开发者网络 > 开发工具 > 开发专栏 > VFP > 正文   Visual FoxPro是一个有着广泛用户基础的著名数据库管理系统软件。过去,人们传说自6.0版本以后不会再发行新的版本了,可微软公...
  • ark1111
  • ark1111
  • 2005年03月02日 11:19
  • 1142

Visual FoxPro 6.0~9.0解决方案与范例大全写作原稿及光盘下载

自从微软宣布停止开发Visual FoxPro之后,此类图书的出版也成了难题,但是至今仍有许多VFP的坚守者,到处搜罗这本8年前的图书。特此奉上写作原稿,看起来会比淘宝上的扫描版本会舒服很多。下载地址...
  • zhanghongju
  • zhanghongju
  • 2014年11月11日 22:20
  • 4446

C#数据库连接字符串——Visual FoxPro

ODBC DSN ODBC without DSN -- Database container (dbc) ODBC without DSN -- Free table directory OleDb...
  • mymhj
  • mymhj
  • 2010年05月07日 14:33
  • 1103
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:如何用VC++和Visual Foxpro进行ActiveX数据通讯
举报原因:
原因补充:

(最多只允许输入30个字)