다음을 통해 공유


사용자 지정 작업 창

작업 창은 일반적으로 Microsoft Office 응용 프로그램에서 다른 창의 한 쪽에 도킹되는 사용자 인터페이스 패널입니다.사용자 지정 작업 창을 통해 작업 창을 직접 만들 수 있고 사용자에게 솔루션의 기능에 액세스하는 친숙한 인터페이스를 제공할 수 있습니다.예를 들어 인터페이스에 문서를 수정하거나 데이터 소스의 데이터를 표시하는 코드를 실행하는 컨트롤을 포함할 수 있습니다.

적용 대상: 이 항목의 정보는 Outlook 2013 및 Outlook 2010의 응용 프로그램 수준 프로젝트에 적용됩니다. 자세한 내용은 Office 응용 프로그램 및 프로젝트 형식에 따라 사용 가능한 기능을 참조하십시오.

[!참고]

사용자 지정 작업 창(Task Pane)은 작업 창(Actions Pane)과 다릅니다.작업 창(Actions Pane)은 Microsoft Office Word 및 Microsoft Office Excel용 문서 수준 사용자 지정의 일부입니다.자세한 내용은 작업 창 개요을 참조하십시오.

사용자 지정 작업 창의 장점

사용자 지정 작업 창을 사용하면 직접 개발한 기능을 친숙한 사용자 인터페이스에 통합할 수 있습니다.Visual Studio 도구를 사용하여 사용자 지정 작업 창을 빠르게 만들 수 있습니다.

Aa942864.collapse_all(ko-kr,VS.110).gif친숙한 사용자 인터페이스

Microsoft Office System의 응용 프로그램 사용자는 Word의 스타일 및 서식 작업 창 등의 작업 창에 이미 익숙합니다.사용자 지정 작업 창은 Microsoft Office System의 다른 작업 창과 같은 방식으로 작동합니다.사용자는 사용자 지정 작업 창을 응용 프로그램 창에 여러 방향으로 도킹하거나 창에서 임의의 위치로 끌어 놓을 수 있습니다.여러 사용자 지정 작업 창을 동시에 표시하는 추가 기능을 만들 수 있으며 사용자는 각 작업 창을 개별적으로 제어할 수 있습니다.

Aa942864.collapse_all(ko-kr,VS.110).gifWindows Forms 지원

Visual Studio의 Office 개발 도구를 사용하여 만드는 사용자 지정 작업 창의 사용자 인터페이스는 Windows Forms 컨트롤을 기반으로 합니다.익숙한 Windows Forms 디자이너를 사용하여 사용자 지정 작업 창의 사용자 인터페이스를 디자인할 수 있습니다.Windows Forms의 데이터 바인딩 지원 기능을 사용하여 작업 창의 컨트롤에 데이터 소스를 바인딩할 수도 있습니다.

사용자 지정 작업 창 만들기

기본적인 사용자 지정 작업 창을 만드는 과정은 두 단계로 진행됩니다.

  1. Windows Forms 컨트롤을 UserControl 개체에 추가하여 사용자 지정 작업 창의 사용자 인터페이스를 만듭니다.

  2. 추가 기능의 CustomTaskPaneCollection 개체에 사용자 정의 컨트롤을 전달하여 사용자 지정 작업 창을 인스턴스화합니다.이 컬렉션은 작업 창의 모양을 수정하거나 사용자 이벤트에 응답하는 데 사용할 수 있는 새 CustomTaskPane 개체를 반환합니다.

자세한 내용은 방법: 응용 프로그램에 사용자 지정 작업 창 추가을 참조하십시오.

Aa942864.collapse_all(ko-kr,VS.110).gif사용자 인터페이스 만들기

Visual Studio의 Office 개발 도구를 사용하여 만드는 모든 사용자 지정 작업 창에는 UserControl 개체가 포함되어 있습니다.이 사용자 정의 컨트롤은 사용자 지정 작업 창의 사용자 인터페이스를 제공합니다.사용자 정의 컨트롤은 디자인 타임에 만들거나 런타임에 만들 수 있습니다.디자인 타임에 사용자 정의 컨트롤을 만드는 경우 Windows Forms 디자이너를 사용하여 작업 창의 사용자 인터페이스를 구성할 수 있습니다.

Aa942864.collapse_all(ko-kr,VS.110).gif사용자 지정 작업 창 인스턴스화

사용자 지정 작업 창의 사용자 인터페이스가 포함된 사용자 정의 컨트롤을 만든 후에는 CustomTaskPane을 인스턴스화해야 합니다.이렇게 하려면 Add 메서드 중 하나를 호출하여 추가 기능의 CustomTaskPaneCollection에 사용자 정의 컨트롤을 전달합니다.이 컬렉션은 ThisAddIn 클래스의 CustomTaskPanes 필드로 노출됩니다.다음 코드 예제는 ThisAddIn 클래스에서 실행되도록 만들어졌습니다.

myUserControl1 = New MyUserControl
myCustomTaskPane = Me.CustomTaskPanes.Add(myUserControl1, "My Task Pane")
myCustomTaskPane.Visible = True
myUserControl1 = new MyUserControl();
myCustomTaskPane = this.CustomTaskPanes.Add(myUserControl1, "My Task Pane");
myCustomTaskPane.Visible = true;

Add 메서드에서는 새 CustomTaskPane 개체를 반환합니다.이 개체를 사용하여 작업 창의 모양을 수정하거나 사용자 이벤트에 응답할 수 있습니다.

Aa942864.collapse_all(ko-kr,VS.110).gif여러 창의 작업 창 제어

사용자 지정 작업 창은 사용자에게 문서 또는 항목의 뷰를 제공하는 문서 프레임 창에 연결됩니다.작업 창은 연결된 창이 표시되는 경우에만 나타납니다.

사용자 지정 작업 창이 표시되는 창을 결정하려면 작업 창을 만들 때 적절한 Add 메서드 오버로드를 사용합니다.

일부 Office 응용 프로그램에는 둘 이상의 창이 열려 있을 때 작업 창을 만들거나 표시할 시기에 대한 명시적 지침이 필요합니다.그러므로 응용 프로그램에서 작업 창이 적절한 문서나 항목과 함께 나타나도록 코드에서 사용자 지정 작업 창을 인스턴스화할 위치를 고려해야 합니다.자세한 내용은 응용 프로그램 창의 사용자 지정 작업 창 관리.

작업 창에서 응용 프로그램 액세스

사용자 정의 컨트롤에서 응용 프로그램을 자동화하려면 코드에서 Globals.ThisAddIn.Application을 사용하여 개체 모델에 직접 액세스합니다.정적 Globals 클래스는 ThisAddIn 개체에 대한 액세스를 제공합니다.이 개체의 Application 필드는 응용 프로그램의 개체 모델에 대한 진입점입니다.

ThisAddIn 개체의 Application 필드에 대한 자세한 내용은 응용 프로그램 수준 추가 기능 프로그래밍을 참조하십시오.사용자 지정 작업 창에서 응용 프로그램을 자동화하는 방법을 보여 주는 연습을 보려면 연습: 사용자 지정 작업 창을 사용하여 응용 프로그램 자동화를 참조하십시오.Globals 클래스에 대한 자세한 내용은 Office 프로젝트의 개체에 전역 액세스를 참조하십시오.

작업 창의 사용자 인터페이스 관리

작업 창을 만든 후 CustomTaskPane 개체의 속성 및 이벤트를 사용하여 작업 창의 사용자 인터페이스를 제어하고 사용자가 작업 창을 변경할 때 응답할 수 있습니다.

Aa942864.collapse_all(ko-kr,VS.110).gif사용자 지정 작업 창 표시

작업 창은 기본적으로 표시되지 않습니다.작업 창을 표시하려면 Visible 속성을 true로 설정해야 합니다.

작업 창의 모퉁이에 있는 닫기 단추(X)를 클릭하여 언제든지 작업 창을 닫을 수 있습니다.그러나 사용자 지정 작업 창을 다시 열 수 있는 기본적인 방법은 없습니다.사용자 지정 작업 창을 닫은 사용자는 이를 표시할 수 있는 방법이 제공되지 않는 한 사용자 지정 작업 창을 다시 표시할 수 없습니다.

추가 기능에서 사용자 지정 작업 창을 만들 때는 사용자가 클릭하여 사용자 지정 작업 창을 표시하거나 숨길 수 있는 단추 등의 UI 요소를 함께 만들어야 합니다.리본 메뉴를 사용자 지정할 수 있는 Microsoft Office 응용 프로그램에서 사용자 지정 작업 창을 만드는 경우 사용자 지정 작업 창을 표시하거나 숨기는 단추가 포함된 컨트롤 그룹을 리본 메뉴에 추가할 수 있습니다.이 작업을 수행하는 방법을 보여 주는 연습은 연습: 사용자 지정 작업 창과 리본 단추 동기화를 참조하십시오.

리본 메뉴를 사용자 지정할 수 없는 Microsoft Office 응용 프로그램에서 사용자 지정 작업 창을 만드는 경우에는 사용자 지정 작업 창을 표시하거나 숨기는 CommandBarButton을 추가할 수 있습니다.

Aa942864.collapse_all(ko-kr,VS.110).gif작업 창의 모양 수정

CustomTaskPane 개체의 속성을 사용하여 사용자 지정 작업 창의 크기와 위치를 제어할 수 있습니다.사용자 지정 작업 창에 포함된 UserControl 개체의 속성을 사용하여 사용자 지정 작업 창의 모양을 다양하게 변경할 수 있습니다.예를 들어 사용자 정의 컨트롤의 BackgroundImage 속성을 사용하여 사용자 지정 작업 창의 배경 이미지를 지정할 수 있습니다.

다음 표에서는 CustomTaskPane 속성을 통해 사용자 지정 작업 창에 대해 변경할 수 있는 항목을 보여 줍니다.

Task

속성

작업 창의 크기 변경

Height

Width

작업 창의 위치 변경

DockPosition

작업 창을 숨기거나 표시

Visible

사용자가 작업 창의 위치를 변경할 수 없도록 고정

DockPositionRestrict

Aa942864.collapse_all(ko-kr,VS.110).gif사용자 지정 작업 창 이벤트 프로그래밍

추가 기능에서 사용자 지정 작업 창이 수정되는 경우에 응답해야 할 수 있습니다.예를 들어 사용자가 창의 방향을 세로에서 가로로 변경하는 경우 컨트롤의 위치를 조정할 수 있습니다.

다음 표에서는 사용자 지정 작업 창이 변경되는 경우에 응답하기 위해 처리할 수 있는 이벤트를 보여 줍니다.

Task

Event

작업 창의 위치가 변경될 때 응답

DockPositionChanged

작업 창이 숨겨지거나 표시될 때 응답

VisibleChanged

작업 창에서 사용하는 리소스 정리

사용자 지정 작업 창을 만든 후에도 추가 기능이 실행되는 동안에는 CustomTaskPane 개체가 메모리에 유지됩니다.이 개체는 사용자가 작업 창의 모퉁이에 있는 닫기 단추(X)를 클릭한 후에도 메모리에 유지됩니다.

추가 기능이 실행 중일 때 작업 창에 사용된 리소스를 정리하려면 Remove 또는 RemoveAt 메서드를 사용합니다.이 메서드는 지정된 CustomTaskPane 개체를 CustomTaskPanes 컬렉션에서 제거하고 개체의 Dispose 메서드를 호출합니다.

Microsoft Visual Studio Tools for Office Runtime에서는 추가 기능이 언로드될 때 사용자 지정 작업 창에서 사용된 리소스를 자동으로 정리합니다.프로젝트의 ThisAddIn_Shutdown 이벤트 처리기에서 Remove 또는 RemoveAt 메서드를 호출하지 마십시오.Microsoft Visual Studio Tools for Office Runtime에서는 ThisAddIn_Shutdown이 호출되기 전에 CustomTaskPane 개체에서 사용된 리소스를 정리하기 때문에 이러한 메서드는 ObjectDisposedException을 throw합니다.ThisAddIn_Shutdown에 대한 자세한 내용은 Office 프로젝트의 이벤트를 참조하십시오.

여러 응용 프로그램 창의 사용자 지정 작업 창 관리

응용 프로그램에서 여러 개의 창을 사용하는 사용자 지정 작업 창을 만들어 문서 및 다른 항목을 표시하는 경우 사용자가 예상하는 작업 창이 표시되도록 추가 단계를 수행해야 합니다.

모든 응용 프로그램의 사용자 지정 작업 창은 사용자에게 문서 또는 항목의 보기를 표시하는 문서 프레임 창과 연결됩니다.작업 창은 연결된 창이 표시되는 경우에만 나타납니다.그러나 모든 응용 프로그램에서 동일한 방식으로 문서 프레임 창을 사용하는 것은 아닙니다.

다음 응용 프로그램 그룹에는 각각 다른 개발 요구 사항이 있습니다.

  • Outlook

  • 단어, InfoPath, PowerPoint

비디오에 링크 관련 비디오 데모를 보려면 How Do I: Manage Task Panes in Word Add-ins?를 참조하십시오.

Outlook

Outlook용 사용자 지정 작업 창을 만들면 사용자 지정 작업 창이 특정 탐색기 창이나 검사기 창에 연결됩니다.탐색기는 폴더의 내용이 표시되는 창이고, 검사기는 전자 메일 메시지 또는 작업과 같은 항목이 표시되는 창입니다.

여러 탐색기 창이나 검사기 창에 사용자 지정 작업 창을 표시하려면 탐색기 또는 검사기 창이 열릴 때 사용자 지정 작업 창의 새 인스턴스를 만들어야 합니다.이렇게 하려면 탐색기 또는 검사기 창이 만들어질 때 발생하는 이벤트를 처리하고 이벤트 처리기에 작업 창을 만듭니다.표시되는 창에 따라 작업 창을 숨기거나 표시하도록 탐색기 및 검사기 이벤트를 처리할 수도 있습니다.

작업 창을 특정 탐색기 또는 검사기에 연결하려면 CustomTaskPaneCollection.Add(UserControl, String, Object) 메서드를 사용하여 작업 창을 만든 다음 Explorer 또는 Inspector 개체를 window 매개 변수에 전달합니다.사용자 지정 작업 창을 만드는 방법에 대한 자세한 내용은 사용자 지정 작업 창를 참조하십시오.

열리는 모든 전자 메일 메시지에 대한 작업 창을 만드는 방법을 보여 주는 연습은 연습: Outlook에서 전자 메일 메시지와 함께 사용자 지정 작업 창 표시를 참조하십시오.

Aa942864.collapse_all(ko-kr,VS.110).gifOutlook 이벤트

탐색기 창의 상태를 모니터링하려면 다음과 같은 탐색기 관련 이벤트를 처리합니다.

검사기 창의 상태를 모니터링하려면 다음과 같은 검사기 관련 이벤트를 처리합니다.

Aa942864.collapse_all(ko-kr,VS.110).gifOutlook에서 사용자 지정 작업 창의 여러 인스턴스 방지

Outlook 창에 사용자 지정 작업 창의 인스턴스가 여러 개 표시되지 않게 하려면 각 창이 닫힐 때 ThisAddIn 클래스의 CustomTaskPanes 컬렉션에서 사용자 지정 작업 창을 명시적으로 제거합니다.창을 닫을 때 발생하는 ExplorerEvents_10_Event.Close 또는 InspectorEvents_10_Event.Close 등의 이벤트에서 Remove 메서드를 호출합니다.

사용자 지정 작업 창을 명시적으로 제거하지 않으면 Outlook 창에 사용자 지정 작업 창의 인스턴스가 여러 개 표시될 수 있습니다.Outlook에서는 기존 창이 재활용되기도 하며, 이러한 경우 이전에 연결된 사용자 지정 작업 창에 대한 참조가 유지됩니다.

단어, InfoPath, PowerPoint

단어, InfoPath, PowerPoint 각 문서 다른 문서 프레임 창에 표시합니다.이러한 응용 프로그램의 사용자 지정 작업 창을 만들면 해당 사용자 지정 작업 창은 특정 문서에만 연결됩니다.사용자가 다른 문서를 열면 해당 사용자 지정 작업 창은 이전 문서가 다시 표시될 때까지 숨겨집니다.

여러 문서에서 사용자 지정 작업 창을 표시하려면 사용자가 새 문서를 만들거나 기존 문서를 열 때 사용자 지정 작업 창의 새 인스턴스를 만듭니다.이렇게 하려면 문서가 만들어지거나 열릴 때 발생하는 이벤트를 처리하고 이벤트 처리기에 작업 창을 만듭니다.표시되는 문서에 따라 작업 창을 숨기거나 표시하도록 문서 이벤트를 처리할 수도 있습니다.

작업 창을 특정 문서 창에 연결 하려면 사용은 CustomTaskPaneCollection.Add(UserControl, String, Object) 작업창을 만들고 전달 하는 메서드는 Microsoft.Office.Interop.Word.Window (Word의 경우)에 대 한 Microsoft.Office.Interop.InfoPath.WindowObject (InfoPath)에 대 한 또는 Microsoft.Office.Interop.PowerPoint.DocumentWindow (PowerPoint)에 대 한 하는 window 매개 변수.

Aa942864.collapse_all(ko-kr,VS.110).gifWord 이벤트

Word에서 문서 창의 상태를 모니터링하려면 다음 이벤트를 처리합니다.

Aa942864.collapse_all(ko-kr,VS.110).gifInfoPath 이벤트

InfoPath에서 문서 창의 상태를 모니터링하려면 다음 이벤트를 처리합니다.

Aa942864.collapse_all(ko-kr,VS.110).gifPowerPoint 이벤트

Powerpoint에서 문서 창의 상태를 모니터링 하려면 다음 이벤트를 처리 합니다.

참고 항목

작업

방법: 응용 프로그램에 사용자 지정 작업 창 추가

연습: 사용자 지정 작업 창을 사용하여 응용 프로그램 자동화

연습: 사용자 지정 작업 창과 리본 단추 동기화

연습: Outlook에서 전자 메일 메시지와 함께 사용자 지정 작업 창 표시