Button 컨트롤 형식에 대한 UI 자동화 지원

참고 항목

이 설명서는 System.Windows.Automation 네임스페이스에 정의된 관리되는 UI 자동화 클래스를 사용하려는 .NET Framework 개발자를 위한 것입니다. UI 자동화에 대한 최신 정보는 Windows 자동화 API: UI 자동화를 참조하세요.

이 항목에서는 Button 컨트롤 형식에 대한 UI 자동화 지원 정보를 제공합니다. UI 자동화에서 컨트롤 형식은 ControlTypeProperty 속성을 사용하기 위해 컨트롤이 충족해야 하는 조건 집합입니다. 조건에는 UI 자동화 트리 구조, UI 자동화 속성 값, 컨트롤 패턴 및 UI 자동화 이벤트에 대한 특정 지침이 포함됩니다.

단추는 사용자가 작업을 수행하기 위해 조작하는 대화 상자의 확인취소 단추와 같은 개체입니다. 단추 컨트롤은 사용자가 완료하려는 단일 명령에 매핑되기 때문에 간단하게 노출할 수 있는 컨트롤입니다.

다음 섹션에서는 Button 컨트롤 형식에 필요한 UI 자동화 트리 구조, 속성, 컨트롤 패턴, 이벤트를 정의합니다. UI 자동화 요구 사항은 WPF(Windows Presentation Foundation), Win32 또는 Windows Forms 등 모든 단추 컨트롤에 적용됩니다.

필요한 UI 자동화 트리 구조

다음 표는 단추 컨트롤과 관련된 UI 자동화 트리의 컨트롤 뷰 및 콘텐츠 뷰를 보여주고 각 뷰에 포함될 수 있는 내용에 대해 설명합니다. UI 자동화 트리에 대한 자세한 내용은 UI 자동화 트리 개요를 참조하세요.

컨트롤 뷰 콘텐츠 뷰
단추

- Image(0개 이상)
- Text(0개 이상)
단추

필요한 UI 자동화 속성

다음 표에서는 값 또는 정의가 Button 컨트롤 형식을 구현하는 컨트롤(예: 단추 컨트롤)과 특별히 관련된 UI 자동화 속성을 나열하여 보여 줍니다. UI 자동화 속성에 대한 자세한 내용은 클라이언트용 UI 자동화 속성을 참조하세요.

UI 자동화 속성 주의
AcceleratorKeyProperty 메모를 참조하세요. 일반적으로 최종 사용자가 단추 컨트롤이 나타내는 작업을 키보드에서 신속하게 수행하도록 하려면 단추 컨트롤이 액셀러레이터 키를 지원해야 합니다.
AutomationIdProperty 메모를 참조하세요. 이 속성의 값은 애플리케이션의 모든 컨트롤에서 고유해야 합니다.
BoundingRectangleProperty 메모를 참조하세요. 전체 컨트롤이 포함된 가장 바깥쪽 사각형입니다.
ClickablePointProperty 메모를 참조하세요. 경계 사각형이 없는 경우 지원됩니다. 경계 사각형 내의 일부 지점이 클릭 가능하지 않으며 특수화된 적중 테스트를 수행하는 경우 클릭 가능한 지점을 재정의하고 제공하세요.
ControlTypeProperty 단추 이 값은 모든 UI 프레임워크에 대해 동일합니다.
HelpTextProperty 메모를 참조하세요. 도움말 텍스트는 단추 활성화의 최종 결과를 나타낼 수 있습니다. 이는 일반적으로 도구 설명을 통해 제공되는 정보 형식과 동일합니다.
IsContentElementProperty True 단추 컨트롤이 항상 콘텐츠여야 합니다.
IsControlElementProperty True 단추 컨트롤이 항상 컨트롤이어야 합니다.
IsKeyboardFocusableProperty 메모를 참조하세요. 컨트롤이 키보드 포커스를 받을 수 있으면 해당 컨트롤은 이 속성을 지원해야 합니다.
LabeledByProperty Null 단추 컨트롤은 콘텐츠에 의해 자체적으로 레이블이 지정됩니다.
LocalizedControlTypeProperty "button" Button 컨트롤 형식에 해당하는 지역화된 문자열입니다.
NameProperty 메모를 참조하세요. 단추 컨트롤의 이름은 레이블을 지정하는 데 사용되는 텍스트입니다. 단추의 레이블을 지정하기 위해 이미지를 사용할 때마다 단추의 Name 속성에 대해 대체 텍스트를 제공해야 합니다.

필요한 UI 자동화 컨트롤 패턴

다음 표에서는 모든 단추 컨트롤에서 지원되는 데 필요한 UI 자동화 컨트롤 패턴을 나열하여 보여 줍니다. 컨트롤 패턴에 대한 자세한 내용은 UI Automation Control Patterns Overview를 참조하세요.

컨트롤 패턴 지원 주의
IInvokeProvider 메모를 참조하세요. 모든 단추는 Invoke 컨트롤 패턴 또는 Toggle 컨트롤 패턴을 지원해야 합니다. Invoke는 사용자의 요청 시 해당 단추가 명령을 수행할 때 지원됩니다. 이 명령은 잘라내기, 복사, 붙여넣기 또는 삭제 등과 같은 단일 작업에 매핑됩니다.
IToggleProvider 메모를 참조하세요. 모든 단추는 Invoke 컨트롤 패턴 또는 Toggle 컨트롤 패턴을 지원해야 합니다. Toggle은 단추가 최대 3가지 상태로 순환될 수 있는 경우에 지원됩니다. 일반적으로 이 상태는 특정 기능의 설정/해제 스위치로 표시됩니다.
IExpandCollapseProvider 메모를 참조하세요. 단추가 분할 단추의 자식으로 호스트되는 경우, 자식 단추는 Invoke 또는 Toggle 패턴 대신 ExpandCollapse 패턴을 지원할 수 있습니다. ExpandCollapse 패턴은 해당 단추 요소와 연결된 메뉴 또는 하위 구조를 열거나 닫는 데 사용할 수 있습니다.

필요한 UI 자동화 이벤트

다음 표에서는 모든 단추 컨트롤에서 지원되는 데 필요한 UI 자동화 이벤트를 나열하여 보여 줍니다. 이벤트에 대한 자세한 내용은 UI Automation Events Overview를 참조하세요.

UI 자동화 이벤트 지원 주의
AutomationFocusChangedEvent Required None
BoundingRectangleProperty 속성 변경 이벤트. Required None
IsOffscreenProperty 속성 변경 이벤트. Required None
IsEnabledProperty 속성 변경 이벤트. Required None
NameProperty 속성 변경 이벤트. Required None
StructureChangedEvent Required None
InvokedEvent 개체 컨트롤이 Invoke 컨트롤 패턴을 지원하는 경우 이 이벤트를 지원해야 합니다.
ToggleStateProperty 속성 변경 이벤트. 개체 컨트롤이 Toggle 컨트롤 패턴을 지원하는 경우 이 이벤트를 지원해야 합니다.

참고 항목