Partilhar via


FindWindow Tag

The <FindWindow> tag consists of a list of child elements that represent a sequence of match operations, all of which need to succeed for the target window to be considered found.

The following code snippet shows how the various <FindWindow> elements are used to find the target window:

# RELAX NG XML grammar for FindWindow
# http://relaxng.org/compact-tutorial-20030326.html
grammar {
   start      = FindWindow
   FindWindow = element FindWindow {
element ControlId { attribute match { xsd:integer }?, text }*
& element Caption { attribute match { xsd:integer }?, text }*
& element CaptionStartsWith { same as Caption }*
& element CaptionEndsWith { same as Caption }*
& element CaptionContains { same as Caption }*
& element Class { attribute match { xsd:integer }?, text }*
& element ClassStartsWith { same as Class }*
& element ClassEndsWith { same as Class }*
& element ClassContains { same as Class }*
& element Find { Caption & Class }*
& element Desktop { empty }*
& element Application { empty }*
& element Owner { empty }*
& element RelaxProcessIdRestriction { empty }*
& element RelaxThreadIdRestriction  { empty }*
}
}

<FindWindow> tag elements

The following table describes the various elements of the <FindWindow> tag:

Element Description

ControlId

Window with ID.

Caption

Window caption text.

CaptionStartsWith

Caption starts with text.

CaptionEndsWith

Caption ends with text.

CaptionContains

Caption contains text.

Class

Window with class name.

ClassStartsWith

Class name stats with text.

ClassEndsWith

Class name ends with text.

ClassContains

Class contains text.

Find

Searches for window as specified via Class or Caption element.

Desktop

Sets the search point to the desktop.

Application

Sets the search point to the applications top-level window.

Owner

Window with specified owner.

RelaxProcessIdRestriction

Includes windows with different process IDs in search. By default, all windows belong to the same process ID.

RelaxThreadIdRestriction

Includes windows with different thread ID in search process. By default all windows belong to the same thread ID.

The following XML shows control definition using the <FindWindow> tag.

<FindWindow>
<Desktop/>
<Caption match="1">Font</Caption>
<Class>#32770</Class>
<Caption>OK</Caption>
</FindWindow>
<FindWindow>
<Application/>
<ControlId>7d</ControlId>
</FindWindow>
<FindWindow>
<Desktop/>
<Class>Notepad</Class>
</FindWindow>

In the preceding XML example, the elements have the following definitions:

  • <Application/> – Sets the context window to the top-level window of the application. By default, the context is initialized to the top-level window before the first child node in <FindWindow/>.

  • <Desktop/> – Sets the context window to the root-level desktop window.

  • <Caption match="1">Font</Caption> – Searches the window hierarchy, starting at the current context window and working down the hierarchy, for the first window with caption text that matches the text provided. If match="2", it searches for the second window with caption text that matches the provided text. If no match attribute is provided, match="1" is the default. The text comparison is a substring match against the caption text. If the provided text can be found as a substring in the subject window's caption, it is considered a match. The successful matching window becomes the new context window. If no match is found, the search fails. By default, only windows that belong to the same ProcessId and ThreadId are considered a match.

  • <Class>#32770</Class> – Searches the window hierarchy, for the first window with class text that matches the provided text. All other behavioral details are identical to <Caption/>.

  • <ControlId>7d</ControlId> – Searches the window hierarchy, for the first window with a control ID that matches the provided value. This must be an exact match. All other behavioral details are identical to <Caption/>.

The following XML searches for the window with the caption OK in the first window with the caption Font and the class ID 32770, starting at the desktop.

<FindWindow>
<Desktop/>
<Caption match="1">Font</Caption>
<Class>#32770</Class>
<Caption>OK</Caption>
</FindWindow> 

The following XML looks for the window with Control ID 7D, starting at the application's top-level window.

<FindWindow>
<Application/>
<ControlId>7d</ControlId>
</FindWindow>

The following XML searches for the (first) window with the class name Notepad, starting at the desktop.

<FindWindow>
<Desktop/>
<Class>Notepad</Class>
</FindWindow> 

See Also

Concepts

WinDDA
Use data driven adapters (DDAs)

Unified Service Desk
Send comments about this topic to Microsoft.
© 2015 Microsoft. All rights reserved.