다음을 통해 공유


WindowInteropHelper 클래스

정의

WPF(Windows Presentation Foundation) 및 Win32 코드 사이의 상호 운용을 지원합니다.

public ref class WindowInteropHelper sealed
public sealed class WindowInteropHelper
type WindowInteropHelper = class
Public NotInheritable Class WindowInteropHelper
상속
WindowInteropHelper

설명

이 클래스의 멤버를 사용하면 호출자가 Win32 HWND 및 WPF Window의 부모 HWND에 대한 내부 액세스를 가질 수 있습니다. 적절한 보안 검사는 해당 멤버에 의해 수행됩니다.

HWND를 기반으로 하는 보다 구체적인 개체가 필요할 때마다 이 클래스를 사용합니다.

예제 시나리오는 Win32 애플리케이션에서 WPF 대화 상자를 호스트해야 하는 경우입니다. 대화 상자의 WindowInteropHelper WPF 창 개체를 사용하여 초기화합니다. 그런 다음, 속성에서 Handle WPF 창의 핸들(HWND)을 가져오고 속성을 사용하여 WPF 창의 소유자를 Owner 지정할 수 있습니다. 다음 코드 예제에서는 Win32 애플리케이션에서 WPF 대화 상자를 호스팅할 때 사용하는 WindowInteropHelper 방법을 보여 있습니다.

WindowInteropHelper wih = new WindowInteropHelper(myDialog);
wih.Owner = ownerHwnd;
myDialog.ShowDialog();
Dim wih As New WindowInteropHelper(myDialog)
wih.Owner = ownerHwnd
myDialog.ShowDialog()

이 클래스에서 지원하는 또 다른 시나리오는 WPF Window 개체에서 개체를 가져오는 HwndSource 것입니다. 메서드 HwndSource 를 통해 Win32 메시지를 직접 처리할 AddHook 수 있습니다. WPF에서 동등하거나 처리하지 않는 메시지를 사용 HwndSource AddHook 하거나 대신 Window 처리할 수 있습니다. 원본을 사용하여 WindowInteropHelper 만든 다음 HWND에서 .로 가져오기를 호출 Handle WindowInteropHelper 합니다HwndSource.Window

생성자

WindowInteropHelper(Window)

지정된 WPF(Windows Presentation Foundation) 창에 대한 클래스의 WindowInteropHelper 새 인스턴스를 초기화합니다.

속성

Handle

이를 WindowInteropHelper만드는 데 사용되는 WPF(Windows Presentation Foundation) 창의 창 핸들을 가져옵니다.

Owner

WPF(Windows Presentation Foundation) 소유자 창의 핸들을 가져오거나 설정합니다.

메서드

EnsureHandle()

HWND가 아직 만들어지지 않은 경우 창의 HWND를 만듭니다.

Equals(Object)

지정된 개체가 현재 개체와 같은지 확인합니다.

(다음에서 상속됨 Object)
GetHashCode()

기본 해시 함수로 작동합니다.

(다음에서 상속됨 Object)
GetType()

현재 인스턴스의 Type을 가져옵니다.

(다음에서 상속됨 Object)
MemberwiseClone()

현재 Object의 단순 복사본을 만듭니다.

(다음에서 상속됨 Object)
ToString()

현재 개체를 나타내는 문자열을 반환합니다.

(다음에서 상속됨 Object)

적용 대상

추가 정보