Microsoft MVP성태의 닷넷 이야기
.NET Framework: 126.3. CAG - 간단한 유형의 모듈 제작 [링크 복사], [링크+제목 복사]
조회: 19328
글쓴 사람
정성태 (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

비밀번호

댓글 작성자
 




[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13606정성태4/24/2024105닷넷: 2247. C# - tensorflow 연동 (MNIST 예제)파일 다운로드1
13605정성태4/23/2024340닷넷: 2246. C# - Python.NET을 이용한 파이썬 소스코드 연동파일 다운로드1
13604정성태4/22/2024372오류 유형: 901. Visual Studio - Unable to set the next statement. Set next statement cannot be used in '[Exception]' call stack frames.
13603정성태4/21/2024675닷넷: 2245. C# - IronPython을 이용한 파이썬 소스코드 연동파일 다운로드1
13602정성태4/20/2024801닷넷: 2244. C# - PCM 오디오 데이터를 연속(Streaming) 재생 (Windows Multimedia)파일 다운로드1
13601정성태4/19/2024847닷넷: 2243. C# - PCM 사운드 재생(NAudio)파일 다운로드1
13600정성태4/18/2024862닷넷: 2242. C# - 관리 스레드와 비관리 스레드
13599정성태4/17/2024867닷넷: 2241. C# - WAV 파일의 PCM 사운드 재생(Windows Multimedia)파일 다운로드1
13598정성태4/16/2024889닷넷: 2240. C# - WAV 파일 포맷 + LIST 헤더파일 다운로드2
13597정성태4/15/2024873닷넷: 2239. C# - WAV 파일의 PCM 데이터 생성 및 출력파일 다운로드1
13596정성태4/14/20241061닷넷: 2238. C# - WAV 기본 파일 포맷파일 다운로드1
13595정성태4/13/20241051닷넷: 2237. C# - Audio 장치 열기 (Windows Multimedia, NAudio)파일 다운로드1
13594정성태4/12/20241069닷넷: 2236. C# - Audio 장치 열람 (Windows Multimedia, NAudio)파일 다운로드1
13593정성태4/8/20241082닷넷: 2235. MSBuild - AccelerateBuildsInVisualStudio 옵션
13592정성태4/2/20241219C/C++: 165. CLion으로 만든 Rust Win32 DLL을 C#과 연동
13591정성태4/2/20241198닷넷: 2234. C# - WPF 응용 프로그램에 Blazor App 통합파일 다운로드1
13590정성태3/31/20241079Linux: 70. Python - uwsgi 응용 프로그램이 k8s 환경에서 OOM 발생하는 문제
13589정성태3/29/20241152닷넷: 2233. C# - 프로세스 CPU 사용량을 나타내는 성능 카운터와 Win32 API파일 다운로드1
13588정성태3/28/20241267닷넷: 2232. C# - Unity + 닷넷 App(WinForms/WPF) 간의 Named Pipe 통신 [2]파일 다운로드1
13587정성태3/27/20241170오류 유형: 900. Windows Update 오류 - 8024402C, 80070643
13586정성태3/27/20241334Windows: 263. Windows - 복구 파티션(Recovery Partition) 용량을 늘리는 방법
13585정성태3/26/20241115Windows: 262. PerformanceCounter의 InstanceName에 pid를 추가한 "Process V2"
13584정성태3/26/20241065개발 환경 구성: 708. Unity3D - C# Windows Forms / WPF Application에 통합하는 방법파일 다운로드1
13583정성태3/25/20241303Windows: 261. CPU Utilization이 100% 넘는 경우를 성능 카운터로 확인하는 방법
13582정성태3/19/20241561Windows: 260. CPU 사용률을 나타내는 2가지 수치 - 사용량(Usage)과 활용률(Utilization)파일 다운로드1
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...