DrawingAttributes.AddPropertyData(Guid, Object) メソッド

定義

DrawingAttributes オブジェクトにカスタム プロパティを追加します。

public:
 void AddPropertyData(Guid propertyDataId, System::Object ^ propertyData);
public void AddPropertyData(Guid propertyDataId, object propertyData);
member this.AddPropertyData : Guid * obj -> unit
Public Sub AddPropertyData (propertyDataId As Guid, propertyData As Object)

パラメーター

propertyDataId
Guid

カスタム プロパティに関連付ける Guid

propertyData
Object

カスタム プロパティの値を指定します。 propertyData は、 CharByteInt16UInt16Int32UInt32Int64UInt64SingleDoubleDateTimeBooleanStringDecimal 、またはこれらのデータ型の配列である必要があります。ただし、 String型の配列にすることはできません。

例外

propertyDatanullです。

propertyDataId は空の Guidです。

-又は-

propertyData は、 Parameters セクションに記載されている許可されているデータ型の 1 つではありません。

次の例では、 DrawingAttributes オブジェクトからカスタム プロパティを追加および取得する方法を示します。 この例では、 DrawingAttributes オブジェクトがペンか蛍光ペンかを示すプロパティを追加します。 ChangeColors_Click イベント ハンドラーのコードは、InkCanvas オブジェクト (DrawingAttributes) を使用するinkDAのストロークの新しい色をレンダリングします。 この例では、InkCanvasという名前のinkCanvas1があり、DrawingAttributes という名前の 2 つのinkDA オブジェクトとhighlighterDAがあることを前提としています。

Guid purposeGuid = new Guid("12345678-9012-3456-7890-123456789012");
string penValue = "pen";
string highlighterValue = "highlighter";

// Add a property to each DrawingAttributes object to 
// specify its use.
private void AssignDrawingAttributesInstrument()
{
    inkDA.AddPropertyData(purposeGuid, penValue);
    highlighterDA.AddPropertyData(purposeGuid, highlighterValue);
}

// Change the color of the ink that on the InkCanvas that used the pen.
void ChangeColors_Click(Object sender, RoutedEventArgs e)
{
    foreach (Stroke s in inkCanvas1.Strokes)
    {
        if (s.DrawingAttributes.ContainsPropertyData(purposeGuid))
        {
            object data = s.DrawingAttributes.GetPropertyData(purposeGuid);

            if ((data is string) && ((string)data == penValue))
            {
                s.DrawingAttributes.Color = Colors.Black;
            }
        }
    }
}
Private purposeGuid As New Guid("12345678-9012-3456-7890-123456789012")
Private penValue As String = "pen"
Private highlighterValue As String = "highlighter"

' Add a property to each DrawingAttributes object to 
' specify its use.
Private Sub AssignDrawingAttributesInstrument()

    inkDA.AddPropertyData(purposeGuid, penValue)
    highlighterDA.AddPropertyData(purposeGuid, highlighterValue)

End Sub

' Change the color of the ink that on the InkCanvas that used the pen.
Private Sub ChangeColors_Click(ByVal sender As [Object], _
        ByVal e As RoutedEventArgs)

    Dim s As Stroke

    For Each s In inkCanvas1.Strokes
        If s.DrawingAttributes.ContainsPropertyData(purposeGuid) Then

            Dim data As Object = s.DrawingAttributes.GetPropertyData(purposeGuid)

            If TypeOf data Is String AndAlso CStr(data) = penValue Then
                s.DrawingAttributes.Color = Colors.Black
            End If

        End If
    Next s

End Sub

注釈

AddPropertyData メソッドを使用すると、DrawingAttributes オブジェクトにカスタム プロパティを追加できます。 これは、独自のストロークをレンダリングし、追加情報を提供する場合に便利です。

適用対象