IModelPropertyAccessor::GetValue メソッド (dbgmodel.h)
GetValue メソッドは、プロパティ アクセサーのゲッターです。 これは、クライアントが プロパティの基になる値をフェッチする場合に常に呼び出されます。 プロパティ アクセサーを直接取得する呼び出し元は、キー名と正確なインスタンス オブジェクト (このポインター) をプロパティ アクセサーの GetValue メソッドに渡す責任があることに注意してください。
構文
HRESULT GetValue(
PCWSTR key,
IModelObject *contextObject,
IModelObject **value
);
パラメーター
key
値を取得するキーの名前。 プロパティ アクセサーを直接フェッチする呼び出し元は、これを正確に渡す役割を担います。
contextObject
プロパティ アクセサーがフェッチされたコンテキスト オブジェクト (このポインターのインスタンス)。
value
プロパティの基になる値がここで返されます。
戻り値
このメソッドは、成功または失敗を示す HRESULT を返します。
注釈
サンプル コード
// The full implementation class is shown for clarity.
class MyReadOnlyProperty :
public Microsoft::WRL::RuntimeClass<
Microsoft::WRL::RuntimeClassFlags<
Microsoft::WRL::RuntimeClassType::ClassicCom
>,
IModelPropertyAccessor
>
{
public:
IFACEMETHOD(GetValue)(_In_ PCWSTR /*pwszKey*/,
_In_ IModelObject * /*pContextObject*/,
_COM_Errorptr_ IModelObject **ppValue)
{
HRESULT hr = S_OK;
*ppValue = nullptr;
VARIANT vtValue;
vtValue.vt = VT_I4;
vtValue.lVal = m_value;
ComPtr<IModelObject> spValue;
hr = GetManager()->CreateIntrinsicObject(ObjectIntrinsic, &vtValue, &spValue);
if (SUCCEEDED(hr))
{
*ppValue = spValue.Detach();
}
return hr;
}
IFACEMETHOD(SetValue)(_In_ PCWSTR /*pwszKey*/,
_In_ IModelObject * /*pContextObject*/,
_In_ IModelObject * /*pValue*/)
{
// We are a read only property.
return E_NOTIMPL;
}
HRESULT RuntimeClassInitialize(_In_ int value)
{
m_value = value;
return S_OK;
}
private:
int m_value;
};
要件
要件 | 値 |
---|---|
Header | dbgmodel.h |