为了说明问题,预先约定:控件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.   

    你要导入没有界面的控件可以从类向导中选择从TypeLib添加类,向导会帮你生成所需要控件的一个封装类
      

  2.   

    firmbird(firmbird):根据你的指点我是这样做的:
    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(****))函数时其返回值总是指示“没有注册类别”,我用其他程序调用过那个控件,完全可用。我还是不知为什么。
      

  3.   

    建议,都不可见的控件做成DLL的COM,这样可以解决你的这些问题
      

  4.   

    你是不是想在ocx中使用对话框的资源?
    如果仅仅是简单的控件调用控件,你的做法是可行的。如果你是想在控件中使用对话框,你的方法就不行了。如果你想验证控件是否调用了控件,那你最好不要使用myocx.AboutBox();的方法。可以验证的方法很多啊,比如写文件,传数据什么的都是可以的。
      

  5.   

    这样是不行的
    我在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(); 
      

  6.   

    另外调用的时候 记得一定要注册你的activex