Microsoft MVP성태의 닷넷 이야기
.NET Framework: 126.3. CAG - 간단한 유형의 모듈 제작 [링크 복사], [링크+제목 복사],
조회: 24853
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
부모글 보이기/감추기
(연관된 글이 3개 있습니다.)

간단한 유형의 모듈 제작


이번 글에서는 간단하게 모듈 추가 절차를 알아볼 텐데, 전체적인 내용은 다음의 글을 정리한 것입니다.

Composite Application Guidance for WPF - June 2008
How to: Create a Module
; https://docs.microsoft.com/en-us/previous-versions/msp-n-p/ff921345(v=pandp.10)




우선, 모듈이란 뭘까요? 위의 링크에서 제공되는 글의 서두에서 그 정의를 찾아볼 수 있는데요.

A module encapsulates a set of related concerns. Modules are independently developed and deployed, and they interact with each other to create the application.



비록 모듈의 정의가 그러하지만, 현실적으로 CAG 프레임워크로 보자면 Unity Framework의 관리하에 놓인 어셈블리라고 보시면 됩니다. 따라서, 모듈로 정의된 어셈블리는 Unity에 의해서 로드되면서 Reflection 등의 과정을 거쳐서 IoC와 같은 헤택을 받게되는 것입니다.

실제로 추가를 해보면서 이해를 해보는 것도 좋겠지요.

"모듈"로 동작되는 어셈블리를 만들기 위해 "[그림 1]"과 같이 "StatusBar"라는 이름으로 프로젝트를 추가합니다.

[그림 1: StatusBar 프로젝트 추가]
impl_cag_app_step_by_step_chapter3_1.png

다음의 프로젝트 참조를 참조합니다.

  • PresentationCore.dll
  • PresentationFramework.dll
  • WindowsBase.dll
  • Microsoft.Practices.Composite.dll
  • Microsoft.Practices.Composite.Presentation.dll

{ModuleName}Module.cs와 같은 이름 규칙에 따라 새로운 Module 타입을 "StatusBarModule.cs"라는 이름으로 추가하고 코드는 다음과 같이 작성해 줍니다.

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.Practices.Composite.Modularity;
using Microsoft.Practices.Composite.Regions;

namespace StatusBar
{
    public class StatusBarModule : IModule
    {
        private readonly IRegionManager regionManager;

        public StatusBarModule(IRegionManager regionManager)
        {
            this.regionManager = regionManager;
        }

        public void Initialize()
        {
            this.regionManager.Regions["StatusRegion"].Add(new DefaultStatusBar());
        }
    }
}

우선, StatusBarModule 생성자를 보시면 IRegionManager 인터페이스가 넘어오는 것을 볼 수 있습니다. 실제 인스턴스 타입은 "Microsoft.Practices.Composite.Presentation.Regions.RegionManager"로 정의된 것인데, 런타임 시에 Unity에 의해서 기 등록된 IRegionManager의 인스턴스가 주입(Injection)되어 넘어옵니다.

즉, 만약 Unity에 의해서 위의 모듈이 로드되지 않고 단순히 "StatusBarModule test = new StatusBarModule();"과 같은 식으로 생성을 했다면 - 다시 말해서 Unity의 "관리"에 놓이지 않는다면 - IRegionManager 등의 값은 당연히 배정되지 않습니다.

그다음으로 Initialize 메서드를 살펴보면,

이와 같이 모듈 내에서는 해당 모듈이 제공하는 View / Service를 등록해 주면 되는데, 위의 코드에서는 Region 영역에 "DefaultStatusBar" 뷰를 하나 등록하고 있습니다.

본론에서 벗어나지 않기 위해 DefaultStatusBar.xaml은 다음과 같이 간단하게 구현하는 것으로 끝내겠습니다.

<UserControl x:Class="StatusBar.DefaultStatusBar"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
    <Grid>
        <Button MinWidth="80" MinHeight="25" Name="button1">Button</Button>
    </Grid>
</UserControl>

이것으로, 간단한 유형의 모듈 하나가 완성되었습니다. 이제 지금까지 새롭게 만들어진 모듈을 CAG로 하여금 로드를 하라고 시켜야 할 텐데요.

"이전의 글"에서 Bootstrapper.GetModuleCatalog 안에 DirectoryModuleCatalog를 사용했기 때문에 이렇게 만들어진 Module의 출력 경로를 "$(SolutionDir)\bin\Debug\Modules"로 설정해 주면 되는데, 이번 경우에는 코드로도 추가하는 방법과 폴더를 지정하는 방법을 모두 사용할 수 있도록 하는 예시를 보여주기 위해 StatusBar 모듈을 직접 참조해서 코드로 추가해 보겠습니다.

===== Bootstrapper.cs =====

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.Practices.Composite.UnityExtensions;
using System.Windows;
using Microsoft.Practices.Composite.Modularity;
using System.IO;
using StatusBar;

namespace DevToolManager
{
    public class Bootstrapper : UnityBootstrapper
    {
        protected override DependencyObject CreateShell()
        {
            Shell shell = Container.Resolve<Shell>();
            shell.Show();
            return shell;
        }

        protected override Microsoft.Practices.Composite.Modularity.IModuleCatalog GetModuleCatalog()
        {
            string modulePath = @".\Modules";
            if (Directory.Exists(modulePath) == false)
            {
                Directory.CreateDirectory(modulePath);
            }

            DirectoryModuleCatalog catalog = new DirectoryModuleCatalog() { ModulePath = modulePath };
            catalog.AddModule(typeof(StatusBarModule));
            return catalog;
        }
    }
}

간단하지요! 단순히 DirectoryModuleCatalog 인스턴스에서 정적 참조한 어셈블리에 정의된 모듈 타입을 AddModule로 전달해 주면 됩니다. 이렇게 해서 실행시키면 버튼 하나가 있는 WPF 응용 프로그램이 실행되는 것을 확인할 수 있습니다.

[그림 2: StatusBar 모듈이 반영된 실행 화면]
impl_cag_app_step_by_step_chapter3_2.png

다운로드: 예제 솔루션



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

[연관 글]






[최초 등록일: ]
[최종 수정일: 7/17/2021]

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

비밀번호

댓글 작성자
 




... 46  47  48  49  50  51  52  53  [54]  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12591정성태4/9/202120885.NET Framework: 1034. C# - byte 배열을 Hex(16진수) 문자열로 고속 변환하는 방법 [2]파일 다운로드1
12590정성태4/9/202117044.NET Framework: 1033. C# - .NET 4.0 이하에서 Console.IsInputRedirected 구현 [1]
12589정성태4/8/202118231.NET Framework: 1032. C# - Environment.OSVersion의 문제점 및 윈도우 운영체제의 버전을 구하는 다양한 방법 [1]
12588정성태4/7/202120013개발 환경 구성: 565. PowerShell - New-SelfSignedCertificate를 사용해 CA 인증서 생성 및 인증서 서명 방법
12587정성태4/6/202121247개발 환경 구성: 564. Windows 10 - ClickOnce 배포처럼 사용할 수 있는 MSIX 설치 파일 [1]
12586정성태4/5/202118136오류 유형: 710. Windows - Restart-Computer / shutdown 명령어 수행 시 Access is denied(E_ACCESSDENIED)
12585정성태4/5/202117134개발 환경 구성: 563. 기본 생성된 kubeconfig 파일의 내용을 새롭게 생성한 인증서로 구성하는 방법
12584정성태4/1/202118290개발 환경 구성: 562. kubeconfig 파일 없이 kubectl 옵션만으로 실행하는 방법
12583정성태3/29/202119156개발 환경 구성: 561. kubectl 수행 시 다른 k8s 클러스터로 접속하는 방법
12582정성태3/29/202118631오류 유형: 709. Visual C++ - 컴파일 에러 error C2059: syntax error: '__stdcall'
12581정성태3/28/202118556.NET Framework: 1031. WinForm/WPF에서 Console 창을 띄워 출력하는 방법 (2) - Output 디버깅 출력을 AllocConsole로 우회 [2]
12580정성태3/28/202116421오류 유형: 708. SQL Server Management Studio - Execution Timeout Expired.
12579정성태3/28/202117039오류 유형: 707. 중첩 가상화(Nested Virtualization) - The virtual machine could not be started because this platform does not support nested virtualization.
12578정성태3/27/202117456개발 환경 구성: 560. Docker Desktop for Windows 기반의 Kubernetes 구성 (2) - WSL 2 인스턴스에 kind가 구성한 k8s 서비스 위치
12577정성태3/26/202119024개발 환경 구성: 559. Docker Desktop for Windows 기반의 Kubernetes 구성 - WSL 2 인스턴스에 kind 도구로 k8s 클러스터 구성
12576정성태3/25/202117098개발 환경 구성: 558. Docker Desktop for Windows에서 DockerDesktopVM 기반의 Kubernetes 구성 (2) - k8s 서비스 위치
12575정성태3/24/202115700개발 환경 구성: 557. Docker Desktop for Windows에서 DockerDesktopVM 기반의 Kubernetes 구성 [1]
12574정성태3/23/202121300.NET Framework: 1030. C# Socket의 Close/Shutdown 동작 (동기 모드)
12573정성태3/22/202118700개발 환경 구성: 556. WSL 인스턴스 초기 설정 명령어 [1]
12572정성태3/22/202117916.NET Framework: 1029. C# - GC 호출로 인한 메모리 압축(Compaction)을 확인하는 방법파일 다운로드1
12571정성태3/21/202115960오류 유형: 706. WSL 2 기반으로 "Enable Kubernetes" 활성화 시 초기화 실패 [1]
12570정성태3/19/202121288개발 환경 구성: 555. openssl - CA로부터 인증받은 새로운 인증서를 생성하는 방법
12569정성태3/18/202121643개발 환경 구성: 554. WSL 인스턴스 export/import 방법 및 단축 아이콘 설정 방법
12568정성태3/18/202114956오류 유형: 705. C# 빌드 - Couldn't process file ... due to its being in the Internet or Restricted zone or having the mark of the web on the file.
12567정성태3/17/202117011개발 환경 구성: 553. Docker Desktop for Windows를 위한 k8s 대시보드 활성화 [1]
12566정성태3/17/202116906개발 환경 구성: 552. Kubernetes - kube-apiserver와 REST API 통신하는 방법 (Docker Desktop for Windows 환경)
... 46  47  48  49  50  51  52  53  [54]  55  56  57  58  59  60  ...