共用方式為


IDataModelManager4::CreateDataModelObject 方法 (dbgmodel.h)

CreateDataModelObject 方法是簡單的協助程式包裝函式,用來建立屬於數據模型的物件,也就是要附加為其他物件的父模型的物件。 所有這類對象都必須透過 IDataModelConcept支援數據模型概念。 此方法會建立沒有明確內容的新空白綜合物件,並將 inpassed IDataModelConcept 新增為新建立之對象的數據模型概念實作。 這同樣可以透過呼叫 CreateSyntheticObject 和 SetConcept 來完成。

語法

HRESULT CreateDataModelObject(
  IDataModelConcept *dataModel,
  IModelObject      **object
);

參數

dataModel

IDataModelConcept 的實作,這會自動新增至新建立的對象作為數據模型概念的實作。

object

新建立的合成物件(具有數據模型概念集)將會在這裡傳回。

傳回值

此方法會傳回 HRESULT。

言論

範例程式代碼

ComPtr<IDataModelManager4> spManager; /* get the data model manager */

// We need some IDataModelConcept implementation.  Provide a 
// minimal one for example purposes.
class MyDataModel :
    public Microsoft::WRL::RuntimeClass<
        Microsoft::WRL::RuntimeClassFlags<
            Microsoft::WRL::RuntimeClassType::ClassicCom
            >,
        IDataModelConcept
        >
{
public:

    IFACEMETHOD(InitializeObject)(
        _In_ IModelObject * /*pContextObject*/, 
        _In_opt_ IDebugHostTypeSignature * /*pMatchingSignature*/, 
        _In_opt_ IDebugHostSymbolEnumerator * /*pWildcardMatches*/
        )
    {
        return S_OK;
    }

    IFACEMETHOD(GetName)(_Out_ BSTR *pModelName)
    {
        *pModelName = nullptr;
        return E_NOTIMPL;
    }
};

ComPtr<MyDataModel> spMyModel = Microsoft::WRL::Make<MyDataModel>();
if (spMyModel != nullptr)
{
    ComPtr<IModelObject> spDataModelObject;
    if (SUCCEEDED(spManager->CreateDataModelObject(spMyModel.Get(),
                                                   &spDataModelObject)))
    {
        // spDataModelObject is now a data model object and can be attached
        // as a parent to any other object via AddParentModel().
    }
}

要求

要求 價值
標頭 dbgmodel.h

另請參閱

IDataModelManager4 介面