다음을 통해 공유


C# 및 WinUI 3/Windows 앱 SDK 사용하여 Hello World 앱 빌드

이 방법에서는 Visual Studio 2022 및 WinUI 3 / Windows 앱 SDK를 사용하여 시작할 때 "Hello world!"를 표시하는 Windows 데스크톱 앱을 빌드합니다.

빌드 중인 'Hello world' 앱입니다.

이 방법은 초보자를 대상으로 하며, Windows 데스크톱 개발에 익숙하다는 가정을 전제로 하지 않습니다.

필수 조건

이 자습서에서는 Visual Studio를 사용하고 WinUI 3 빈 앱 템플릿을 기반으로 빌드합니다. 설정하려면 WinUI 시작의 지침을 따릅니다. Visual Studio를 설치하고, WinUI로 앱을 개발할 수 있도록 구성하고, Hello World 프로젝트를 만들고, 최신 버전의 WinUI가 있는지 확인합니다.

이 작업을 마쳤으면 여기로 돌아와 Hello World 프로젝트에 대해 자세히 알아보고 업데이트하세요.

빈 앱 프로젝트 검토

Visual Studio의 WinUI 프로젝트 템플릿에는 앱을 빌드하고 실행하는 데 필요한 모든 것이 포함되어 있습니다. 빈 앱 템플릿은 디버그 모드에서 실행할 때 다음과 같은 대화형 버튼이 있는 창을 만듭니다.

템플릿 기반 프로젝트 빌드 실행

Click Me 버튼을 클릭하면 이벤트 바인딩 데모를 볼 수 있습니다.

'Click Me' 버튼

이 경우 버튼 컨트롤의 Click 이벤트는 myButton_Click 이벤트 핸들러(MainWindow.xaml.cs에 위치)에 바인딩됩니다.

기본 창의 코드 숨김 파일에 있는 'Click Me' 버튼의 이벤트 처리기

MainWindow.xaml.cs에는 기본 창의 비즈니스 논리 관련 내용이 코드 숨김 파일 형태로 포함되어 있지만, 프레젠테이션 관련 내용은 MainWindow.xaml에 있습니다.

기본 창의 마크업 파일에 있는 'Click Me' 버튼의 XML 마크업

이렇게 비즈니스 논리프레젠테이션 문제를 분리하면 일관된 애플리케이션 개발 패턴을 통해 애플리케이션의 UI에 데이터와 이벤트를 바인딩할 수 있습니다.

프로젝트의 파일 구조

코드를 변경하기 전에 프로젝트의 파일 구조를 검토해 보겠습니다.

프로젝트의 파일 구조는 아래와 같습니다.

파일 구조 개요

이 표에서는 위에서 시작하여 아래로 내려가며 작업하는 파일에 대해 설명합니다.

항목 설명
Solution 'Hello World' 이는 솔루션 파일로, 프로젝트의 논리적 컨테이너입니다. 프로젝트는 앱인 경우가 많지만, 클래스 라이브러리를 지원할 수도 있습니다.
Hello World 이는 앱 파일의 논리적 컨테이너인 프로젝트 파일입니다.
Dependencies 앱은 프레임워크(예: .NETWindows SDK) 그리고 패키지(예: Windows App SDK 앱 SDK)에 따라 좌우됩니다. 앱에 더 정교한 기능과 타사 라이브러리를 도입하면 여기에 추가 종속성이 나타납니다.
Properties 규칙에 따라 WinUI 3 프로젝트는 이 폴더에 게시 프로필 및 실행 구성 파일을 배치합니다.
PublishProfiles 게시 프로필은 광범위한 플랫폼에서 앱의 게시 구성을 지정합니다.
launchSettings.json 이 파일로 시작 프로필, 즉 dotnet run을(를) 통해 앱을 시작할 때 사용 가능한 프로필을 구성할 수 있습니다.
Assets 이 폴더에는 앱의 로고, 이미지 및 기타 미디어 자산이 포함되어 있습니다.
app.manifest 이 앱 매니페스트 파일에는 사용자의 장치에 앱 설치 시 Windows에서 앱을 표시하는 방식과 관련한 구성이 포함됩니다.
App.xaml 이 표시 파일은 앱이 의존하는 공유되고 전역적으로 액세스 가능한 리소스를 지정합니다.
App.xaml.cs 이 코드 숨김 파일은 앱의 비즈니스 논리에 대한 진입점을 나타냅니다. 이는 MainWindow의 인스턴스를 만들고 활성화하는 역할을 합니다.
MainWindow.xaml 이 표시 파일에는 앱의 기본 창에 대한 프레젠테이션 문제가 포함됩니다.
MainWindow.xaml.cs 이 코드 숨김 파일에는 앱의 기본 창과 관련된 비즈니스 논리 문제가 포함됩니다.
Package.appxmanifest 패키지 매니페스트 파일을 통해 Windows 스토어에 게시자 정보, 로고, 프로세서 아키텍처 및 앱이 표시되는 방식을 결정하는 기타 세부 정보를 구성할 수 있습니다.

"Hello world!" 표시

MainWindow.xaml(으)로 이동하여 "Click me" 단추 대신 "Hello world!"를 표시합니다. StackPanel 컨트롤의 XAML 표시가 나타나야 합니다.

<StackPanel Orientation="Horizontal" HorizontalAlignment="Center" VerticalAlignment="Center">
   <Button x:Name="myButton" Click="myButton_Click">Click Me</Button>
</StackPanel>

Windows 앱을 빌드하는 동안 API 참조 문서를 자주 참고해야 합니다. StackPanel의 참조 문서에서 StackPanel 컨트롤의 상세 내용과 사용자 지정 방법을 확인할 수 있습니다.

빨간색 텍스트로 StackPanel 컨트롤을 업데이트해 Hello world!을(를) 표시해 보겠습니다.

<StackPanel Orientation="Horizontal" HorizontalAlignment="Center" VerticalAlignment="Center">
    <TextBlock x:Name="myText" Text="Hello world!" Foreground="Red"/>
</StackPanel>

지금 앱을 실행하려고 하면 Visual Studio에서 The name 'myButton' does not exist in the current context 등의 오류가 발생합니다. 이는 새 컨트롤로 프레젠테이션 계층을 업데이트했지만, 코드 숨김 파일에서 이전 컨트롤의 비즈니스 논리를 업데이트하지 않았기 때문입니다.

MainWindow.xaml.cs(으)로 이동하여 myButton_Click 이벤트 처리기를 삭제합니다. 대화형 Click me 단추를 정적 Hello world! 텍스트로 대체했기 때문에 이것이 가능합니다. 이제 기본 창의 비즈니스 논리는 다음과 같습니다.

public sealed partial class MainWindow : Window
{
    public MainWindow()
    {
        this.InitializeComponent();
    }

    // ↓ you can delete this ↓
    //private void myButton_Click(object sender, RoutedEventArgs e)
    //{
    //    myButton.Content = "Clicked";
    //}
}

앱을 다시 시작하면 빨간색 Hello world!이(가) 표시됩니다.

빨간색 'Hello world!'

앱의 제목 표시줄 업데이트

this.Title = "Hello world!";MainWindow.xaml.cs 코드 숨김 파일에 추가합니다.

public MainWindow()
{
    this.InitializeComponent();
    this.Title = "Hello world!"; // <- this is new
}

앱을 다시 시작하면 본문과 제목 표시줄 모두에 Hello world!(이)가 표시됩니다.

빌드 중인 'Hello, world!' 앱입니다.

축하합니다! 첫 번째 Windows 앱 SDK/WinUI 3 앱을 빌드했습니다.

요약

이 방법에서 달성한 내용은 다음과 같습니다.

  1. Visual Studio의 프로젝트 템플릿으로 시작했습니다.
  2. 컨트롤의Click 처리기가 발생했습니다.
  3. 프레젠테이션 문제비즈니스 논리를 분리하는 규칙, 즉 긴밀하게 결합된 XAML 표시 파일C# 코드 숨김 파일을 사용하는 데 익숙해졌을 것입니다.
  4. 기본 WinUI 3 프로젝트 파일 구조를 검토했습니다.
  5. 새로운 TextBlock 컨트롤(StackPanel 내)을 지원하기 위해 프레젠테이션 계층(XAML 표시)와 비즈니스 논리(코드 숨김)을 모두 수정했습니다.
  6. You reviewed 참조 문서를 검토하여 StackPanel 컨트롤의 속성을 더 깊이 이해했습니다.
  7. 기본 창의 제목 표시줄을 업데이트했습니다.

전체 코드 파일

<!-- MainWindow.xaml -->
<Window
    x:Class="Hello_World.MainWindow"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="using:Hello_World"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d">

    <StackPanel Orientation="Horizontal" HorizontalAlignment="Center" VerticalAlignment="Center">
        <TextBlock x:Name="myText" Text="Hello world!" Foreground="Red"/>
    </StackPanel>
</Window>
// MainWindow.xaml.cs
using Microsoft.UI.Xaml;
using Microsoft.UI.Xaml.Controls;
using Microsoft.UI.Xaml.Controls.Primitives;
using Microsoft.UI.Xaml.Data;
using Microsoft.UI.Xaml.Input;
using Microsoft.UI.Xaml.Media;
using Microsoft.UI.Xaml.Navigation;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Runtime.InteropServices.WindowsRuntime;
using Windows.Foundation;
using Windows.Foundation.Collections;

namespace Hello_World
{
    public sealed partial class MainWindow : Window
    {
        public MainWindow()
        {
            this.InitializeComponent();
            this.Title = "Hello world!";
        }
    }
}
<!-- App.xaml -->
<Application
    x:Class="Hello_World.App"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="using:Hello_World">
    <Application.Resources>
        <ResourceDictionary>
            <ResourceDictionary.MergedDictionaries>
                <XamlControlsResources xmlns="using:Microsoft.UI.Xaml.Controls" />
                <!-- Other merged dictionaries here -->
            </ResourceDictionary.MergedDictionaries>
            <!-- Other app resources here -->
        </ResourceDictionary>
    </Application.Resources>
</Application>
// App.xaml.cs
using Microsoft.UI.Xaml;
using Microsoft.UI.Xaml.Controls;
using Microsoft.UI.Xaml.Controls.Primitives;
using Microsoft.UI.Xaml.Data;
using Microsoft.UI.Xaml.Input;
using Microsoft.UI.Xaml.Media;
using Microsoft.UI.Xaml.Navigation;
using Microsoft.UI.Xaml.Shapes;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Runtime.InteropServices.WindowsRuntime;
using Windows.ApplicationModel;
using Windows.ApplicationModel.Activation;
using Windows.Foundation;
using Windows.Foundation.Collections;

namespace Hello_World
{
    public partial class App : Application
    {
        public App()
        {
            this.InitializeComponent();
        }

        protected override void OnLaunched(Microsoft.UI.Xaml.LaunchActivatedEventArgs args)
        {
            m_window = new MainWindow();
            m_window.Activate();
        }

        private Window m_window;
    }
}

FAQ

질문: "패키지된"이란 무슨 의미인가요?

최종 사용자에게 각종 애플리케이션 패키지 형식으로 Windows 앱을 배달할 수 있습니다. WinUI 및 Windows 앱 SDK를 사용할 때, MSIX를 이용하여 패키지된 앱은 최종 사용자에게 편리한 설치 및 업데이트를 제공할 수 있는 방식으로 앱을 번들로 묶습니다. 배포 아키텍처 및 프레임워크 종속 앱을 방문하여 자세히 알아보세요.

Q: VS Code를 사용하여 WinUI 앱을 빌드할 수 있나요?

기술적으로 가능하지만 Visual Studio 2022를 사용하여 WinUI 및 Windows 앱 SDK를 사용하여 데스크톱 앱을 빌드하는 것이 좋습니다. Windows 개발자 FAQ에서 자세한 정보를 확인하세요.

Q: C++를 사용하여 WinUI 앱을 빌드할 수 있나요?

예! 자세한 내용은 C++/WinRT 소개를 참조하세요.