TextPatternRange.Clone Metodo

Definizione

Recupera un nuovo TextPatternRange oggetto identico all'originale TextPatternRange e eredita tutte le proprietà dell'originale.

public:
 System::Windows::Automation::Text::TextPatternRange ^ Clone();
public System.Windows.Automation.Text.TextPatternRange Clone();
member this.Clone : unit -> System.Windows.Automation.Text.TextPatternRange
Public Function Clone () As TextPatternRange

Valori restituiti

Nuovo intervallo di testo. Non viene mai restituito un riferimento Null (Nothing in Visual Basic).

Esempio

private TextPatternRange CloneSelection(AutomationElement target)
{
    // Specify the control type we're looking for, in this case 'Document'
    PropertyCondition cond = new PropertyCondition(AutomationElement.ControlTypeProperty, ControlType.Document);

    // target --> The root AutomationElement.
    AutomationElement textProvider = target.FindFirst(TreeScope.Descendants, cond);

    TextPattern textpatternPattern = textProvider.GetCurrentPattern(TextPattern.Pattern) as TextPattern;

    if (textpatternPattern == null)
    {
        Console.WriteLine("Root element does not contain a descendant that supports TextPattern.");
        return null;
    }
    TextPatternRange[] currentSelection = textpatternPattern.GetSelection();
    return currentSelection[0].Clone();
}
Private Function CloneSelection(ByVal target As AutomationElement) As TextPatternRange
    ' Specify the control type we're looking for, in this case 'Document'
    Dim cond As PropertyCondition = New PropertyCondition(AutomationElement.ControlTypeProperty, ControlType.Document)

    ' target --> The root AutomationElement.
    Dim textProvider As AutomationElement = target.FindFirst(TreeScope.Descendants, cond)

    Dim textpatternPattern As TextPattern = CType(textProvider.GetCurrentPattern(TextPattern.Pattern), TextPattern)

    If (textpatternPattern Is Nothing) Then
        Console.WriteLine("Root element does not contain a descendant that supports TextPattern.")
        Return Nothing
    End If
    Dim currentSelection As TextPatternRange() = textpatternPattern.GetSelection()
    Return currentSelection.Clone(0)
End Function

Commenti

In alternativa, creare un nuovo DocumentRange oggetto da TextPattern e spostare i due endpoint in modo che corrispondano agli endpoint dell'intervallo di testo originale.

Il nuovo intervallo può essere modificato indipendentemente dall'originale.

Si applica a

Vedi anche