InvokeHelper

InvokeHelper目录 基本信息 其他信息 编辑本段基本信息   当在项目中插入ActiveX控件ClassWizard生成的CWnd的派生类C++类中,可以看到其成员函数的代码中都有对InvokeHelper函数的调用,InvokeHelper函数的第一个参数都和对应的属性或方法在ActiveX控件中的分发(dispatch)ID(标识ActiveX控件的方法或属性的)相对应。通过查看ActiveX控件hlp文件可以发现,ActiveX控件的方法在生存的C++类中都有同名的成员函数与之对应,ActiveX控件的属性都有一组Get和Set函数对其操作,其中ActiveX控件的方法和属性操作与生成的C++类成员函数相关联都是通过InvokeHelper函数的调用来完成的,InvokeHelper函数的第一个参数是由Component Gallery(控件提供者)提供的。因为经过这样的处理,所以我们如果要调用ActiveX控件的方法或对其属性进行取和设置操作,只需调用生成的C++类对应的成员函数便可。 编辑本段其他信息   下面对InvokeHelper单独说明:   CWnd::InvokeHelper   void InvokeHelper( DISPID dwDispID, WORD wFlags, VARTYPE vtRet, void* pvRet, const BYTE* pbParamInfo, ... );   说明:   Call this member function to invoke the OLE control method or property specified by dwDispID, in the context specified by wFlags.   其中参数:   dwDispID:   //Identifies the method or property to be invoked. This value is usually supplied by Component Gallery.   wFlags:可以为下面些值,指明调用InvokeHelper的目的。   //[ DISPATCH_METHOD ] The member is invoked as a method. If a property has the same name, both this and the DISPATCH_PROPERTYGET flag may be set.   [ DISPATCH_PROPERTYGET ] The member is retrieved as a property or data member.   [ DISPATCH_PROPERTYPUT ] The member is changed as a property or data member.   [ DISPATCH_PROPERTYPUTREF ] The member is changed by a reference assignment, rather than a value assignment. This flag is valid only when the property accepts a reference to an object.   vtRet:   //Specifies the type of the return value.   VT_EMPTY void   VT_I2 short   VT_I4 long   VT_R4 float   VT_R8 double   VT_CY CY   VT_DATE DATE   VT_BSTR BSTR   VT_DISPATCH LPDISPATCH   VT_ERROR SCODE   VT_BOOL BOOL   VT_VARIANT VARIANT   VT_UNKNOWN LPUNKNOWN   pvRet:   //Address of the variable that will that will receive the property value or return value. It must match the type specified by vtRet.   pbParamInfo:一般都设置为NULL   //Pointer to a null-terminated string of bytes specifying the types of the parameters following pbParamInfo.   specifies the types of the parameters passed to the method or property.   ...:   //Variable List of parameters, of types specified in pbParamInfo.   InvokeHelper()函数的用法   1、播放文件的函数:   void CActiveMovie3::Run()   {   InvokeHelper(0x60020001, DISPATCH_METHOD, VT_EMPTY, NULL, NULL);   }   2、暂停播放的函数: void CActiveMovie3::Pause()   {   InvokeHelper(0x60020002, DISPATCH_METHOD, VT_EMPTY, NULL, NULL);   }   4、停止播放的函数: void CActiveMovie3::Stop()   {   InvokeHelper(0x60020003, DISPATCH_METHOD, VT_EMPTY, NULL, NULL);   }   5、获得文件的函数: CString CActiveMovie3::GetFileName()   {   CString result;   InvokeHelper(0xb, DISPATCH_PROPERTYGET, VT_BSTR, (void*)&result, NULL);   return result;   }   6、设置文件的函数: void CActiveMovie3::SetFileName(LPCTSTR lpszNewValue)   {   static BYTE parms[] = VTS_BSTR;   InvokeHelper(0xb, DISPATCH_PROPERTYPUT, VT_EMPTY, NULL, parms,   lpszNewValue);   }   7、获得播放位置的函数: double CActiveMovie3::GetCurrentPosition()   {   double result;   InvokeHelper(0xd, DISPATCH_PROPERTYGET, VT_R8, (void*)&result, NULL);   return result;   }   8、设置播放位置的函数: void CActiveMovie3::SetCurrentPosition(double newValue)   {   static BYTE parms[] = VTS_R8;   InvokeHelper(0xd, DISPATCH_PROPERTYPUT, VT_EMPTY, NULL, parms, newValue);   }   9、获得音量的函数: long CActiveMovie3::GetVolume()   {   long result;   InvokeHelper(0x13, DISPATCH_PROPERTYGET, VT_I4, (void*)&result, NULL);   return result;   }   10、设置音量的函数: void CActiveMovie3::SetVolume(long nNewValue)   {   static BYTE parms[] = VTS_I4;   InvokeHelper(0x13, DISPATCH_PROPERTYPUT, VT_EMPTY, NULL, parms, nNewValue);   }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在VS2019中,我们可以使用MFC来操作Excel文件。MFC(Microsoft Foundation Class)是一个Microsoft Windows的C++类库,它提供了开发Windows应用程序的框架和工具。 要操作Excel文件,我们需要添加以下头文件: #include <afxdb.h> #include <afxdao.h> 然后,我们可以使用CDaoDatabase类来连接Excel文件: CDaoDatabase db; CString strConnect = _T("Excel 12.0;HDR=Yes;IMEX=1;DATABASE=C:\\Path\\To\\Your\\ExcelFile.xlsx"); db.Open(strConnect); 接下来,我们可以使用SQL查询来执行各种操作。例如,我们可以使用CDaoRecordset类来获取数据: CDaoRecordset rs(&db); rs.Open(_T("SELECT * FROM [Sheet1$]")); 然后,我们可以使用rs.GetFieldValue方法来获取特定单元格的值: CString strValue; rs.GetFieldValue(_T("ColumnName"), strValue); 或者,我们可以使用rs.GetFieldValueAsDouble或rs.GetFieldValueAsInt等方法来获取数值类型的数据。 如果我们想要更新或插入数据,我们可以使用rs.Edit和rs.Update方法: rs.Edit(); rs.SetFieldValue(_T("ColumnName"), strValue); rs.Update(); 当我们完成操作后,记得关闭数据库连接: db.Close(); 需要注意的是,MFC操作Excel文件的功能相对较为有限,对于复杂的操作可能不够灵活。此外,操作Excel文件可能需要安装相应的驱动程序或Excel软件本身。 总之,使用VS2019中的MFC可以方便地操作Excel文件,但需要注意其功能的限制和对相关依赖的处理。 ### 回答2: VS2019 MFC是一种用于创建Windows桌面应用程序的开发工具。它提供了许多功能强大的库和类,使开发人员能够轻松地操作Excel文件。 在VS2019 MFC中操作Excel文件的第一步是添加MFC应用程序项目,并设置项目属性以包括“Microsoft Office Excel”组件。然后,您可以使用类库中的一些类和函数来处理Excel文件。 首先,您需要使用CExcelApplication类的实例来打开Excel应用程序。然后,使用CExcelWorkbook类的实例打开特定的Excel文件。您还可以使用CExcelWorksheet类的实例选择要操作的工作表。 接下来,您可以使用类中的一些函数来读取或写入Excel文件中的数据。例如,使用CExcelWorksheet类的GetCell函数可以获取单元格的内容,使用SetCell函数可以设置单元格的值。 此外,您还可以使用MFC类库中提供的其他功能来处理Excel文件,例如合并单元格、设置格式、创建图表等。 在处理完Excel文件后,您需要记得关闭工作簿和应用程序,以释放资源并确保文件已保存。 总而言之,通过使用VS2019 MFC可以很方便地操作Excel文件。无论是读取还是写入数据,设置格式还是创建图表,这个开发工具提供了一整套强大的类和函数,使开发人员能够轻松地处理Excel文件。 ### 回答3: 在VS2019中,带有MFC(Microsoft Foundation Class)的应用程序可以通过使用Microsoft Office提供的COM接口来操作Excel。 首先,我们需要在MFC应用程序中导入Excel相关的头文件,如afxdao.h和afxisapi.h。 接下来,我们可以使用COleVariant类来表示任何类型的数据,因为Excel单元格中的数据类型可以是字符串、整数、浮点数等。 要操作Excel,我们需要创建一个Excel应用程序对象,可以使用COleDispatchDriver类来处理和管理COM对象的生命周期。我们可以通过以下代码创建一个Excel应用程序对象: ```cpp COleDispatchDriver excelApp; if (!excelApp.CreateDispatch("Excel.Application")) { // 创建失败的处理代码 return; } ``` 接下来,我们可以使用excelApp对象打开或新建一个工作簿,并操作其中的工作表。例如,要打开一个名为"MyBook.xlsx"的工作簿,我们可以使用以下代码: ```cpp COleDispatchDriver workbooks; workbooks = excelApp.GetIDispatch(); workbooks.InvokeHelper(L"Open", DISPATCH_METHOD, NULL, L"MyBook.xlsx"); ``` 然后,我们可以使用COleDispatchDriver类中的InvokeHelper方法来调用Excel的各种功能。例如,要读取A1单元格的值,可以使用以下代码: ```cpp COleDispatchDriver activeSheet; activeSheet = workbooks.InvokeHelper(L"ActiveSheet", DISPATCH_PROPERTYGET); COleDispatchDriver cell; cell.CreateDispatch("Excel.Range", activeSheet.InvokeHelper(L"Range", DISPATCH_PROPERTYGET, L"A1")); COleVariant value; cell.InvokeHelper(L"Value", DISPATCH_PROPERTYGET, value.GetAddress(), 0); ``` 同样,我们也可以使用InvokeHelper方法来修改单元格的值。例如,要将"Hello World"写入B2单元格,可以使用以下代码: ```cpp cell = workbooks.InvokeHelper(L"ActiveSheet", DISPATCH_PROPERTYGET).InvokeHelper(L"Range", DISPATCH_PROPERTYGET, L"B2"); cell.InvokeHelper(L"Value", DISPATCH_PROPERTYPUT, NULL, L"Hello World"); ``` 最后,当我们完成Excel操作后,我们需要释放和关闭Excel应用程序。我们可以使用以下代码进行释放和关闭: ```cpp if (workbooks != NULL) { workbooks.InvokeHelper(L"Close", DISPATCH_METHOD); workbooks.ReleaseDispatch(); } excelApp.InvokeHelper(L"Quit", DISPATCH_METHOD); excelApp.ReleaseDispatch(); ``` 这是使用VS2019中的MFC操作Excel的基本步骤。我们可以根据需要调用更多的Excel功能来完成更复杂的操作,例如合并单元格、设置样式和格式等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值