what is the difference? you can always use AxMSHierarchicalFlexGridLib.AxMSHFlexGrid axMSHFlexGrid1 = new AxMSHierarchicalFlexGridLib.AxMSHFlexGrid(); .....
you need to create it through AxHos, see how it is done: HOW TO: Dynamically Add ActiveX Controls that Require Run-Time Licenses in Visual C# .NET http://support.microsoft.com/default.aspx?scid=kb;EN-US;326652
C#积木模块ABC:3.从C#中调用COM组件 (后期连接) www.chinacs.net 2001-5-22 11:59:00 中文C#技术站 3.从C#中调用COM组件 (后期连接) .NET框架是COM的一个自然发展,两者共享许多核心要素,这包括组件的再利用以及语言的中立性。为了向后兼容,COM Interop可以使用现存的COM组件而不要求对原始组件进行修改。当一个 .NET 框架开发人员想将COM代码合并到一个管理应用程序中时,就可以用COM Interop功能引入相关的COM类型。引入之后,这个COM类型就可以使用了。这属于前期连接。但是有时候你需要对象的后期连接,这在.NET中也能实现,使用名称空间映射就可以通过后期连接来调用COM对象。 这里介绍一个应用程序例程,它将调用Excel,并且通过使用后期连接使它可视。 后期连接将使用Reflectionb的Type类,这个Type类有许多方法可以取得COM对象,就象我们已经使用过的 GetTypeFromProgID("Application"),这个方法从系统注册表中得到COM ID,然后使用STATIC类的成员 Activator.CreateInstance()创建这个COM对象的一个新例示。 要想调用COM对象的方法、函数和属性,就必须使用包含正确设置的Type对象的InvokeMethod()方法。这个方法接受一些参数变量,其中最重要的一个是方法类型的ex属性(get或set)。在例子中我们为Excel.Visible使用了set属性,从而使Excel应用程序可视。 我们将尝试在.NET环境中调用Excel应用程序。这是一个后期连接应用程序,因为如果是前期连接的话你就需要使用COM对象的RCW(RunTime Callable Wraper:运行时间的可调用包)来完成下面的命令行程序tblimp所完成的任务: ex. c:\> tblimp /out: 下载COMinDOTNET.zip,这是一个控制台应用程序。下面是调用excel的代码: //Variable Type excel; object[] parameter= new object[1]; object excelObject; try { //Get the excel object excel = Type.GetTypeFromProgID("Excel.Application"); //Create instance of excel excelObject = Activator.CreateInstance(excel); //Set the parameter whic u want to set parameter[0] = true; //Set the Visible property excel.InvokeMember("Visible", BindingFlags.SetProperty, null, excelObject, parameter); } catch(Exception e) { Console.WriteLine("Error Stack {0} ", e.Message) ; } finally { //When this object is destroyed the Excel application will be closed //So Sleep for sometime and see the excel application Thread.Sleep(5000); //Relaese the object //GC.RunFinalizers() }
要通过从数据流读取控件的状态
this.axMSHFlexGrid1.OcxState = ((System.Windows.Forms.AxHost.State)(resources.GetObject("axMSHFlexGrid1.OcxState")));Form1.resx文件中有它状态的定义: <data name="axMSFlexGrid1.OcxState" mimetype="application/x-microsoft.net.object.binary.base64">
<value>
AAEAAAD/////AQAAAAAAAAAMAgAAAFpTeXN0ZW0uV2luZG93cy5Gb3JtcywgVmVyc2lvbj0xLjAuMzMw
MC4wLCBDdWx0dXJlPW5ldXRyYWwsIFB1YmxpY0tleVRva2VuPWI3N2E1YzU2MTkzNGUwODkFAQAAACFT
eXN0ZW0uV2luZG93cy5Gb3Jtcy5BeEhvc3QrU3RhdGUBAAAABERhdGEHAgIAAAAJAwAAAA8DAAAABAEA
AAIBAAAAAQAAAAAkAAAANzJFNjcxMjAtNTk1OS0xMWNmLTkxRjYtQzI4NjNDMzg1RTMwAAAAAMsAAAAh
QzQSCAAAAAQTAACdBgAAQm9vUAAABgCAAAAAAgAAAAIAAAABAAAAAQAAAAAAAAAFAACACAAAgA8AAIAS
AACADQAAgA4AAICAgIAAwMDAAAAAAAAAAAAAAQAAAAEAAAAAAAAAAQAAAAAAAAAAAAAAAQABAAAAAQAC
AAMAAAAAAAAAAAABAAEAAAABAAQAAAAAAAAAA1LjC5GPzhGd4wCqAEu4UQGGAACQAZBfAQAEy87M5QRS
4wuRj84RneMAqgBLuFFsdAAAAAAAAAs=
</value>
推荐你先隐藏它, 需要时把它属性设成 .Visiabled = true;
HOW TO: Dynamically Add ActiveX Controls that Require Run-Time Licenses in Visual C# .NET
http://support.microsoft.com/default.aspx?scid=kb;EN-US;326652
www.chinacs.net 2001-5-22 11:59:00 中文C#技术站 3.从C#中调用COM组件 (后期连接) .NET框架是COM的一个自然发展,两者共享许多核心要素,这包括组件的再利用以及语言的中立性。为了向后兼容,COM Interop可以使用现存的COM组件而不要求对原始组件进行修改。当一个 .NET 框架开发人员想将COM代码合并到一个管理应用程序中时,就可以用COM Interop功能引入相关的COM类型。引入之后,这个COM类型就可以使用了。这属于前期连接。但是有时候你需要对象的后期连接,这在.NET中也能实现,使用名称空间映射就可以通过后期连接来调用COM对象。
这里介绍一个应用程序例程,它将调用Excel,并且通过使用后期连接使它可视。
后期连接将使用Reflectionb的Type类,这个Type类有许多方法可以取得COM对象,就象我们已经使用过的 GetTypeFromProgID("Application"),这个方法从系统注册表中得到COM ID,然后使用STATIC类的成员 Activator.CreateInstance()创建这个COM对象的一个新例示。
要想调用COM对象的方法、函数和属性,就必须使用包含正确设置的Type对象的InvokeMethod()方法。这个方法接受一些参数变量,其中最重要的一个是方法类型的ex属性(get或set)。在例子中我们为Excel.Visible使用了set属性,从而使Excel应用程序可视。
我们将尝试在.NET环境中调用Excel应用程序。这是一个后期连接应用程序,因为如果是前期连接的话你就需要使用COM对象的RCW(RunTime Callable Wraper:运行时间的可调用包)来完成下面的命令行程序tblimp所完成的任务:
ex. c:\> tblimp /out:
下载COMinDOTNET.zip,这是一个控制台应用程序。下面是调用excel的代码:
//Variable Type excel; object[] parameter= new object[1]; object excelObject; try { //Get the excel object excel = Type.GetTypeFromProgID("Excel.Application"); //Create instance of excel excelObject = Activator.CreateInstance(excel); //Set the parameter whic u want to set parameter[0] = true; //Set the Visible property excel.InvokeMember("Visible", BindingFlags.SetProperty, null, excelObject, parameter); } catch(Exception e) { Console.WriteLine("Error Stack {0} ", e.Message) ; } finally { //When this object is destroyed the Excel application will be closed //So Sleep for sometime and see the excel application Thread.Sleep(5000); //Relaese the object //GC.RunFinalizers() }
activex控件也一样。我在用TextBox textBox = new TextBox();
textBox.Top =100;
textBox.Left100;
textBox.Text="文本标签";
this.Controls.Add(textBox);