다음을 통해 공유


IXRDependencyObject::GetAttachedProperty(const WCHAR*, const WCHAR*, IXRDependencyObject**) (Compact 2013)

3/28/2014

This method retrieves the value of the specified attached property.

Use this method when the specified attached property has an IXRDependencyObject object type.

Syntax

virtual HRESULT STDMETHODCALLTYPE GetAttachedProperty(
    __in const WCHAR* pName,
    __in_opt const WCHAR* pNamespace,
    __out IXRDependencyObject** ppDependencyObject
) = 0;

Parameters

  • pName
    [in] Pointer to a string that contains the name of the attached property that you want to retrieve.
  • pNamespace
    [in, optional] Pointer to a string that contains the name of the namespace in which to look. Use this parameter to access an attached property of a custom control. If pNamespace is null, this method looks in the current default namespace.
  • ppDependencyObject
    [out] On return, contains a pointer to a pointer to an IXRDependencyObject derived object that reflects the value of the property that you specified in pName.

Return Value

Returns an HRESULT that indicates success or failure.

Returns XR_E_INVALID_PROPERTY if this method was unable to locate the property requested.

Remarks

Attached properties are a concept that is part of the XAML language. You can set an attached property on objects or XAML elements, even if that property is not conventionally defined in the properties list that belongs to the setting object. For attached properties such as Canvas.Top, the object.property notation does not work because the two periods or "dots" in the syntax create ambiguity. Instead, you set attached properties in XAML for Windows Embedded by using a C++ string that defines the full dotted name of the attached property (for example, L"Canvas.Top"). In the pName parameter, the dot (.) is considered part of the property name/identifier.

You can use this method to retrieve the value of attached properties in XAML for Windows Embedded, such as Canvas.Left. In this case, the attached property name consists of the owner class name for the attached property, a dot, and the attached property name ("ownerType.propertyName").

You can call this method to retrieve the value of an attached property in XAML for Windows Embedded, or to retrieve the value of a custom attached property that you created and registered for a user-defined control.

To use a specific interface pointer type, you can use the helper template version of this method that XAML for Windows Embedded provides. When you supply a derived type, this version automatically supplies a type-safe method that implicitly converts the returned type from a generic interface, so you do not have to explicitly call QueryInterface to convert the generic interface into the required object type.

Example

The following lines of C++ code demonstrate the correct syntax for using this method to retrieve the VisualStateManager.VisualStateGroups property for the inheriting IXRUIElement object:

Important

For readability, the following code example does not contain security checking or error handling. Do not use the following code in a production environment.

IXRVisualStateGroupCollection* pGroups = NULL;
myElement->GetAttachedProperty(L"VisualStateManager.VisualStateGroups", NULL, (IXRDependencyObject**)&pGroups));

.NET Framework Equivalent

System.Windows.DependencyObject.GetValue

Requirements

Header

XamlRuntime.h

sysgen

SYSGEN_XAML_RUNTIME

See Also

Reference

IXRDependencyObject::GetAttachedProperty
IXRDependencyObject