Microsoft MVP성태의 닷넷 이야기
.NET Framework: 101. WPF - ActiveX 컨트롤 호스팅하는 방법 [링크 복사], [링크+제목 복사],
조회: 32982
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

WPF에서 ActiveX 컨트롤 호스팅하는 방법


사실, 이 내용은 이미 다음의 자료에 공개되어 있습니다.

Windows Presentation Foundation
Walkthrough: Hosting an ActiveX Control in Windows Presentation Foundation
; https://learn.microsoft.com/en-us/dotnet/framework/wpf/advanced/walkthrough-hosting-an-activex-control-in-wpf

여기서는, 정리 차원에서 내용을 써보겠습니다.




처음, WPF 디자이너에서 ActiveX를 넣어보려고 했던 분들은 아시겠지만 "도구 상자"에 아무리 "ActiveX" 컨트롤을 선택해서 추가해 봐도 정작 WPF 디자이너 화면이 활성화되면 "도구 상자"에 등록된 ActiveX 항목들이 보이지 않게 됩니다. 그래서, 디자이너에서 직접 추가할 수는 없게 되어 있습니다.

사실, WPF에서는 일반적인 상황에서 Window 내에 또 다른 Window를 가질 수 없습니다. 단지, 이에 대한 예외로 WindowsFormsHost 클래스를 두고 있고, ActiveX 개체는 바로 이 WindowsFormsHost 내에서 활성화되어야 합니다. 이런 제약 사항으로 인해 디자이너에서 바로 추가하는 것은 안되지만, 코드를 통해서는 추가가 가능하도록 되어 있습니다.

위의 자료에 공개되어 있는 예제에서처럼, 미디어 플레이어를 호스트하고 싶다면 다음과 같은 코드를 작성해 주면 됩니다.

private void WindowLoaded(object sender, RoutedEventArgs e) 
{
    System.Windows.Forms.Integration.WindowsFormsHost host =
        new System.Windows.Forms.Integration.WindowsFormsHost();

    AxWMPLib.AxWindowsMediaPlayer axWmp = new AxWMPLib.AxWindowsMediaPlayer();
    host.Child = axWmp;

    this.grid1.Children.Add(host);
}

다른 코드들은 모두 가능하지만, AxWMPLib.AxWindowsMediaPlayer 코드는 현재 가용하지가 않습니다. 그럴 수밖에 없는 것이 MediaPlayer 관련한 interop 어셈블리들이 참조되지 않았기 때문입니다.

예전, Windows Forms 시절에는 디자이너 화면에서 ActiveX 컨트롤을 그려 넣으면 자동으로 interop 어셈블리들이 참조 추가되었던 반면, WPF에서는 디자이너에서 지원이 되지 않기 때문에 이를 위한 약간의 부가작업을 해줘야 합니다.

이를 위해, Microsoft에서 제시하는 방법은 별도로 Windows Forms 응용 프로그램 프로젝트를 하나 생성하고, 윈폼 디자이너 화면에서 원하는 ActiveX 컨트롤을 그려 넣으라는 것입니다. 그렇게 되면, (위의 예제를 따르는 경우) 다음과 같은 interop DLL들이 생성이 되는데,

  • AxInterop.WMPLib.dll
  • Interop.WMPLib.dll

이렇게 생성된 DLL을 WPF 프로젝트에 가져다 참조를 해서 사용하면 되는 것입니다. (물론, 위의 DLL을 생산하기 위해 만들었던 Windows Forms 프로젝트는 더 이상 필요하지 않습니다. 그 외에도, aximp.exe를 이용하는 것도 한 방법일 수 있겠죠!)




어찌 보면, 마이크로소프트가 이런 부분을 우회적으로 해결할 수도 있지 않았을까 하는 생각을 해봅니다. WPF 디자이너 화면에서 ActiveX를 가져다 놓으면 WindowsFormsHost를 자동으로 생성해서 그 안에 ActiveX 개체를 호스팅해주는 식으로만 처리해 준다면... ^^ 좋았을 것입니다. 실제로, 이미 WindowsFormsHost 역시 다음과 같이 디자이너에서 추가하는 것이 가능합니다.

howto_host_activex_in_wpf_1.PNG

그나마, 이 상태에서는 코드가 다음과 같이 좀 더 간결하게 됩니다.

private void Window_Loaded(object sender, RoutedEventArgs e)
{
    AxWMPLib.AxWindowsMediaPlayer axWmp = new AxWMPLib.AxWindowsMediaPlayer();
    windowsFormsHost1.Child = axWmp;
}




[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 8/9/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2013-10-30 02시35분
정성태
2021-06-11 01시39분
[나그네] 증권사 Active x 를 WPF 닷넷 5버전에서 사용하려고 4시간 삽질했는데

아래 내용으로 해결하였습니다. 감사합니다.

==============================================================
이렇게 생성된 DLL을 WPF 프로젝트에 가져다 참조를 해서 사용하면 되는 것입니다. (물론, 위의 DLL을 생산하기 위해 만들었던 Windows Forms 프로젝트는 더 이상 필요하지 않습니다. 그 외에도, aximp.exe를 이용하는 것도 한 방법일 수 있겠죠!)
[guest]

... 61  62  63  64  65  66  67  68  69  70  71  72  73  [74]  75  ...
NoWriterDateCnt.TitleFile(s)
12086정성태12/20/201921093디버깅 기술: 144. windbg - Marshal.FreeHGlobal에서 발생한 덤프 분석 사례
12085정성태12/20/201919051오류 유형: 586. iisreset - The data is invalid. (2147942413, 8007000d) 오류 발생 - 두 번째 이야기 [1]
12084정성태12/19/201919470디버깅 기술: 143. windbg/sos - Hashtable의 buckets 배열 내용을 모두 덤프하는 방법 (do_hashtable.py) [1]
12083정성태12/17/201922411Linux: 27. linux - lldb를 이용한 .NET Core 응용 프로그램의 메모리 덤프 분석 방법 [2]
12082정성태12/17/201920620오류 유형: 585. lsof: WARNING: can't stat() fuse.gvfsd-fuse file system
12081정성태12/16/201922514개발 환경 구성: 465. 로컬 PC에서 개발 중인 ASP.NET Core 웹 응용 프로그램을 다른 PC에서도 접근하는 방법 [5]
12080정성태12/16/201919676.NET Framework: 870. C# - 프로세스의 모든 핸들을 열람
12079정성태12/13/201921592오류 유형: 584. 원격 데스크톱(rdp) 환경에서 다중 또는 고용량 파일 복사 시 "Unspecified error" 오류 발생
12078정성태12/13/201921421Linux: 26. .NET Core 응용 프로그램을 위한 메모리 덤프 방법 [3]
12077정성태12/13/201920454Linux: 25. 자주 실행할 명령어 또는 초기 환경을 "~/.bashrc" 파일에 등록
12076정성태12/12/201918996디버깅 기술: 142. Linux - lldb 환경에서 sos 확장 명령어를 이용한 닷넷 프로세스 디버깅 - 배포 방법에 따른 차이
12075정성태12/11/201919795디버깅 기술: 141. Linux - lldb 환경에서 sos 확장 명령어를 이용한 닷넷 프로세스 디버깅
12074정성태12/10/201919496디버깅 기술: 140. windbg/Visual Studio - 값이 변경된 경우를 위한 정지점(BP) 설정(Data Breakpoint)
12073정성태12/10/201920973Linux: 24. Linux/C# - 실행 파일이 아닌 스크립트 형식의 명령어를 Process.Start로 실행하는 방법
12072정성태12/9/201917728오류 유형: 583. iisreset 수행 시 "No such interface supported" 오류
12071정성태12/9/201921283오류 유형: 582. 리눅스 디스크 공간 부족 및 safemode 부팅 방법
12070정성태12/9/201923204오류 유형: 581. resize2fs: Bad magic number in super-block while trying to open /dev/.../root
12069정성태12/2/201919653디버깅 기술: 139. windbg - x64 덤프 분석 시 메서드의 인자 또는 로컬 변수의 값을 확인하는 방법
12068정성태11/28/201928296디버깅 기술: 138. windbg와 Win32 API로 알아보는 Windows Heap 정보 분석 [3]파일 다운로드2
12067정성태11/27/201919711디버깅 기술: 137. 실제 사례를 통해 Debug Diagnostics 도구가 생성한 닷넷 웹 응용 프로그램의 성능 장애 보고서 설명 [1]파일 다운로드1
12066정성태11/27/201919341디버깅 기술: 136. windbg - C# PInvoke 호출 시 마샬링을 담당하는 함수 분석 - OracleCommand.ExecuteReader에서 OpsSql.Prepare2 PInvoke 호출 분석
12065정성태11/25/201917650디버깅 기술: 135. windbg - C# PInvoke 호출 시 마샬링을 담당하는 함수 분석파일 다운로드1
12064정성태11/25/201920629오류 유형: 580. HTTP Error 500.0/500.33 - ANCM In-Process Handler Load Failure
12063정성태11/21/201919580디버깅 기술: 134. windbg - RtlReportCriticalFailure로부터 parameters 정보 찾는 방법
12062정성태11/21/201918969디버깅 기술: 133. windbg - CoTaskMemFree/FreeCoTaskMem에서 발생한 덤프 분석 사례 - 두 번째 이야기
12061정성태11/20/201919430Windows: 167. CoTaskMemAlloc/CoTaskMemFree과 윈도우 Heap의 관계
... 61  62  63  64  65  66  67  68  69  70  71  72  73  [74]  75  ...