运行visual studio2010
2新建项目
3在d出的窗口中选中MFC Activex控件
4输入工程名和存储位置,点击确定
5在d出的窗口中点击完成,就完成了工程的创建
2、给OCX添加方法
打开类视图,选中_DMyOCX
右键添加方法
在d出的窗口中编辑方法的属性及参数
点击下一步,并且完成
在MyOCXCtrl.cpp文件中就可看到我们添加的方法了
C一般不能直接调用C++函数库,需要将C++库封装成C接口后,才可以使用C调用。下面举例,说明一个封装策略:
//code in add.cxx
#include "add.h"
int sample::method()
{
cout<<"method is called!\n"
}
//code in add.h
#include
using namespace std
class sample
{
public:
int method()
}
将上面的两个文件生成动态库libadd.so放到 /usr/lib目录下,编译命令如下:
sudo g++ -fpic -shared -g -o /usr/lib/libadd.so add.cxx -I ./
由于在C中不能识别类,所以要将上面类的成员函数,要封装成C接口函数才能被调用。下面进行封装,将输出接口转换成C接口。
//code in mylib.cxx
#include "add.h"
#ifndef _cplusplus
#define _cplusplus
#include "mylib.h"
#endif
int myfunc()
{
sample ss
ss.method()
return 0
}
//code in mylib.h
#ifdef _cplusplus
extern "C"
{
#endif
int myfunc()
#ifdef _cplusplus
}
#endif
在linux下,gcc编译器并没用变量_cplusplus来区分是C代码还是C++ 代码(没有宏定义),如果使用gcc编译器,这里我们可以自己定义一个变量_cplusplus用于区分C和C++代码,所以在mylib.cxx中定义 了一个变量_cplusplus用于识别是否需要“extern "C"”将函数接口封装成C接口。但是如果使用g++编译器则不需要专门定义_cplusplus,编译命令如下:
g++ -fpic -shared -g -o mylib.so mylib.cxx -la -I ./
main.c
#include
#include
#include "mylib.h"
int
main()
{
int (*dlfunc)()
void *handle//定义一个句柄
handle = dlopen("./mylib.so", RTLD_LAZY)//获得库句柄
dlfunc = dlsym(handle, "myfunc")//获得函数入口
(*dlfunc)()
dlclose(handle)
return 0
}
编译命令如下:
gcc -o main main.c ./mylib.so -ldl
下面就可以执行了。
需要说明的是,由于main.c 和 mylib.cxx都需要包含mylib.h,并且要将函数myfunc封装成C接口函数输出需要“extern "C"”,而C又不识别“extern "C"”,所以需要定义_cplusplus来区别处理mylib.h中的函数myfunc。
在main.c的main函数中直接调用myfunc()函数也能执行,这里介绍的是常规调用库函数的方法。
1、控件的事件一般都是由对外的接口引发到,这里定一个接口先:该接口有一个字符串参数,表示调用者将传入一个字符串,传进来后,我们将取得字符串的长度。
2、添加事件:
事件应该是属于窗口的,所以在Ctrl类上单击右键-》添加:
3、添加一个事件“hello”:
该事件的参数是刚才那个字符串处理的结果,这里是long型。
4、在接口实现里调用事件函数:
[cpp] view plaincopy
// COcxEventCtrl 消息处理程序
LONG COcxEventCtrl::MyInterface(LPCTSTR strValue)
{
AFX_MANAGE_STATE(AfxGetStaticModuleState())
CString str = strValue
int len = str.GetLength()
hello(len)
return 0
}
事件函数的名字就是事件名称,参数就是在添加事件时候设置的参数。这里我们计算了字符串的长度,然后把结果给了事件函数。控件里面要做到就做完了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)