为了说明问题,预先约定:控件1,控件2控件1和控件2都是我自己用vc编写的ocx控件,且这两个控件提供给用户使用时都不需要显示出对话框,我在做这两个控件时都用的时vc的默认选项。在控件2中调用了控件1中的方法,我是在控件2中通过Project->Add to Project->Components and controlls 选项加入已注册的控件1,我在控件2中的方法里面要调用控件1的方法,于是在****Ctrl类里面定义了一个控件1的对象m_activeX1。
问题是:我要用控件1的方法时是不是必须要用m_active1.Create(.....)?
如果一定要用create,那么create中的参数该怎么设置?尤其是CWnd *这个参数?因为我的这两个控件都不可见。
问题是:我要用控件1的方法时是不是必须要用m_active1.Create(.....)?
如果一定要用create,那么create中的参数该怎么设置?尤其是CWnd *这个参数?因为我的这两个控件都不可见。
解决方案 »
- console程序关闭事件
- WSAAsyncSelect模型有问,谢谢!
- 钩子 还是不用钩子
- 请问在ATL中不使用MFC如何调用出CFileDialog对话框啊,不会是要LoadLibrary吧,有谁能给我指点一下啊
- 进程如何被保护住,想退出的时候就让它退出??????????????
- 简单问题:vector<string> and vector3f分别表示什么意思?
- 请问哪有VC的函数库的资料啊?
- com Ptr小问题,完整代码
- 急需帮助,关于串口通讯的的问题。
- 请问怎样通过类型库(.TLB文件)获取组件接口信息
- 关于ocx控件嵌套的问题,两个控件运行时都没有窗口,其中一个要调用另一个控件,怎么解决?
- 在视图画出坐标系的问题!
1。用vc6建立一个activex控件test,在默认选项情况下只加了个“不可见”选项-》finish
2。view-》classwizard-》add class-》from a type library-》选择我要调用的另一个ocx控件myocx.tlb
3。在testCtrl头文件中#include "myocx.h"
4。添加method1 返回值为void,无参数
5。在method1函数体内写如下代码:
_DMyocx myocx;
myocx.AboutBox();
编译后用vc自带的控件容器运行method1,无反映不知是为什么。另外,我试过用import形式来调用ocx,但在调用CreateInstance(__uuidof(****))函数时其返回值总是指示“没有注册类别”,我用其他程序调用过那个控件,完全可用。我还是不知为什么。
如果仅仅是简单的控件调用控件,你的做法是可行的。如果你是想在控件中使用对话框,你的方法就不行了。如果你想验证控件是否调用了控件,那你最好不要使用myocx.AboutBox();的方法。可以验证的方法很多啊,比如写文件,传数据什么的都是可以的。
我在stdafx头文件中这样引用dll(一个com组件)
#import "Table2DomainUI.dll" no_namespace named_guids然后在vc的doc文件中
这样使用 ITable2DomainUI * pITable2Doomain = NULL;
其中的ITable2DomainUI是一个组件的实现类,就是clsid所表示的那个类
可是这样程序是不识别ITable2DomainUI的
请问是这样使用的吗?????
(Table2DomainUI.dll已经注册,且在当前程序的目录下)
请问在vc中如何使用仅仅有一个dll的com组件
其中没有tlb或者是olb类型库,
我是这样使用的,可是不对啊
TOP
回复人:sinall() 五级(中级) 信誉:97 2004-10-22 14:41:21 得分:0
置顶文章,结果打不开,这是我保存的(不是我写的)准备及条件:
COM服务器为进程内服务器,DLL名为simpCOM.dll,该组件只有一个接口IFoo,该接口只有一个方法HRESULT SayHello(void)
在SDK中调用
=====================================
一、最简单最常用的一种,用#import导入类型库,利用VC提供的智能指针包装类
演示代码:#import "D:\Temp\vc\simpCOM\Debug\simpCOM.dll" no_namespace
CoInitialize(NULL);IFooPtr spFoo = NULL;
spFoo.CreateInstance(__uuidof(Foo));
spFoo->SayHello();
spFoo.Release();/*晕死了,本来智能指针就是为了让用户不用关心这个的,可是我发现如果不手工调用一下的话,程序退出后会发生内存访问错误,我是在console中做试验的,哪位大侠知道怎么回事请一定指教*/
CoUninitialize();二、引入midl.exe产生的*.h,*_i.c文件,利用CoCreateInstance函数来调用演示代码:
/*在工程中加入*_i.c文件,例如本例的simpCOM_i.c,该文件定义了类和接口的guid值,如果不引入的话,会发生连接错误。*/#include "D:\Temp\vc\simpCOM\simpCOM.h"
CoInitialize(NULL);IFoo* pFoo = NULL;
HRESULT hr = CoCreateInstance(CLSID_Foo, NULL, CLSCTX_ALL, IID_IFoo, (void**)&pFoo);
if (SUCCEEDED(hr) && (pFoo != NULL))
{
pFoo->SayHello();
pFoo->Release();
}CoUninitialize();三、不用CoCreateInstance,直接用CoGetClassObejct得到类厂对象接口,然后用该接口的方法CreateInstance来生成实例。
演示代码:
/*前期准备如二方法所述*/
IClassFactory* pcf = NULL;
HRESULThr = CoGetClassObject(CLSID_Foo, CLSCTX_ALL, NULL, IID_IClassFactory, (void**)&pcf);
if (SUCCEEDED(hr) && (pcf != NULL))
{
IFoo* pFoo = NULL;
hr = pcf->CreateInstance(NULL, IID_IFoo, (void**)&pFoo);
if (SUCCEEDED(hr) && (pFoo != NULL))
{
pFoo->SayHello();
pFoo->Release();
}
pcf->Release();
}四、不用CoCreateInstance or CoGetClassObject,直接从dll中得到DllGetClassObject,接着生成类对象及类实例(本方法适合于你想用某个组件,却不想在注册表中注册该组件)演示代码:
/*前期准备工作如二方法所述,事实上只要得到CLSID和IID的定义及接口的定义就行*/typedef HRESULT (__stdcall * pfnGCO) (REFCLSID, REFIID, void**);
pfnGCO fnGCO = NULL;
HINSTANCE hdllInst = LoadLibrary("D:\\Temp\\vc\\simpCOM\\Debug\\simpCOM.dll");
fnGCO = (pfnGCO)GetProcAddress(hdllInst, "DllGetClassObject");
if (fnGCO != 0)
{
IClassFactory* pcf = NULL;
HRESULT hr=(fnGCO)(CLSID_Foo, IID_IClassFactory, (void**)&pcf);
if (SUCCEEDED(hr) && (pcf != NULL))
{
IFoo* pFoo = NULL;
hr = pcf->CreateInstance(NULL, IID_IFoo, (void**)&pFoo);
if (SUCCEEDED(hr) && (pFoo != NULL))
{
pFoo->SayHello();
pFoo->Release();
}
pcf->Release();
}
}
FreeLibrary(hdllInst);
在MFC中调用
=====================================
在MFC中除了上面的几种方法外,还有一种更方便的方法,就是通过ClassWizard利用类型库生成包装类,不过有个前提就是com组件的接口必须是派生自IDispatch具体方法:
1、按Ctrl+W调出类向导,按Add Class按钮弹出新菜单,选From a type libarary,然后定位到simpCOM.dll,接下来会出来该simpCOM中的所有接口,选择你想生成的接口包装类后,向导会自动生成相应的.cpp和.h文件.
这样你就可以在你的MFC工程中像使用普通类那样使用COM组件了.演示代码:CoInitialize(NULL);IFoo foo;
if (foo.CreateDispatch("simpCOM.Foo") != 0)
{
foo.SayHello();
foo.ReleaseDispatch();
}CoUninitialize();―――――――――――――――――――――――――――――――――――――――
不好意思,不小心发出去了。
_foo,我觉得不一定要调用Release,估计原因是因为spFoo智能指针对象在CoUninitialize()函数以后调用引起的。要是如下面这样调用,应该就没有问题了。#import "D:\Temp\vc\simpCOM\Debug\simpCOM.dll" no_namespace
CoInitialize(NULL);
{
IFooPtr spFoo = NULL;
spFoo.CreateInstance(__uuidof(Foo));
spFoo->SayHello();
}
CoUninitialize();