我正在尝试使用IFileSystemImage2接口使用Imapi2创建具有多个启动记录的ISO。
为此,我应该能够使用put_BootImageOptionsArray
传递SAFEARRAY*
VT_DISPATCH
类型的IBootOptions
,即每个启动选项配置的IBootOptions
类型的COM指针。作为一个简短的演示,我有以下代码(在这种情况下我只创建了一个SAFEARRAYBOUND bounds[1];
bounds[0].cElements = 1;
bounds[1].lLbound = 0;
IBootOptions* BootOptionsArrayData = NULL;
SAFEARRAY* Array = SafeArrayCreateEx(VT_DISPATCH,
1,
bounds,
(void*) &IID_IBootOptions);
hr = SafeArrayAccessData(Array,
reinterpret_cast<void**>(&BootOptionsArrayData));
BootOptionsArrayData = BootOptions; // BootOptions = IBootOptions*
hr = SafeArrayUnaccessData(Array);
hr = IsoImage->put_BootImageOptionsArray(Array);
):
put_BootImageOptionsArray
但是,每次拨打E_NOINTERFACE
时,我都会返回hr = CoCreateInstance(CLSID_MsftFileSystemImage,
NULL,
CLSCTX_ALL,
__uuidof(IFileSystemImage2),
(void**) &IsoImage);
。
正在按照您的期望创建IsoImage:
IFileSystemImage2
使用IFileSystemImage
来自CoCreateInstance
的任何继承功能都可以。同样,我可以IFileSystemImage
代替CMsftFileSystemImage::put_BootOptionsArray
,并且可以正常使用此界面。
我已经在WinDbg中附加了我的进程并在{{1}}中设置了一个断点,但是,这个函数(底层实现)根本就没有被调用。
因此,我的问题很简单:实现似乎存在,但我似乎无法调用它。有没有人有使用这一特定功能的经验,如果是这样,你是如何让它工作的?
答案 0 :(得分:2)
SAFEARRAY的documentation stipulates必须是包含IDispatch接口指针的VARIANT数组,所以你可以这样做(我使用的智能指针更容易......):
CComPtr<IFileSystemImage2> image;
CComPtr<IBootOptions> options;
image.CoCreateInstance(CLSID_MsftFileSystemImage);
options.CoCreateInstance(CLSID_BootOptions);
// set various options here...
options->put_Manufacturer(CComBSTR(L"joe"));
// create a SAFEARRAY of VARIANT
CComSafeArray<VARIANT> a(1);
// create a VARIANT of type VT_UNKNONW (or VT_DISPATCH)
CComVariant v(options);
// put it in the array
a.SetAt(0, v);
HRESULT hr = pImage->put_BootImageOptionsArray(a.m_psa);