Windows GUI 프로그래밍 시작 6 화면 전환 (2)
■ 소개
이번에는 설치 프로그램에서 자주 사용되는 마법사 형식의 화면을 만듭니다.
data:image/s3,"s3://crabby-images/1b339/1b3398b0a50e024855a794a33a58774f04134b3b" alt=""
[주의]
지금까지 설명한 조작 방법 등은 설명을 생략하거나 간략화하는 경우가 있습니다.
■ 개발 환경
■ 만들어 보자
태그 Window
,,,
data:image/s3,"s3://crabby-images/4967d/4967da988aa891a8d4ad18110e1f82bbb3f6fdcb" alt=""
NavigationWindow
에,,,
data:image/s3,"s3://crabby-images/4d11b/4d11b5909e4ff1747663142c2160075b2c8b8289" alt=""
다시 씁니다.
data:image/s3,"s3://crabby-images/59fe2/59fe2b8176c17889ac5850a9547f056c3816979e" alt=""
코드 비하인드에서 기본 클래스 Window
data:image/s3,"s3://crabby-images/2f2ac/2f2aca6f7502285ffd7cc53102d24f19bcb87209" alt=""
NavigationWindow
로 다시 씁니다.
data:image/s3,"s3://crabby-images/08166/08166f912f9a3b30d1cd626e358e2d6189146055" alt=""
새 항목을 추가하여 페이지(WPF)를 세 개 추가합니다.
이름은 Page1.xaml
, Page2.xaml
, Page3.xaml
입니다.
data:image/s3,"s3://crabby-images/21559/21559dd26af286832e446fc43ee34f823a8f16d5" alt=""
문서 개요에서 NavigationWindow
를 선택하고 속성의 기타 지정에서 Source
속성을 Page1.xaml
로 설정합니다.
data:image/s3,"s3://crabby-images/26a05/26a05220cd0a34bc8f122fbb2420cec9a7624744" alt=""
Page1을 다음과 같이 편집합니다.
data:image/s3,"s3://crabby-images/9ddea/9ddea100d0e37c470eb8c218847adc6ee68c41bf" alt=""
Page1.xaml<Page x:Class="WpfApplication6.Page1"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:local="clr-namespace:WpfApplication6"
mc:Ignorable="d"
d:DesignHeight="300" d:DesignWidth="300"
Title="ページ(1/3)">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="auto"/>
<RowDefinition/>
<RowDefinition Height="auto"/>
</Grid.RowDefinitions>
<TextBlock Text="1ページ目" FontSize="36" Margin="10"/>
<StackPanel Grid.Row="1">
<CheckBox Content="チェック1" Margin="10"/>
<TextBox Text="てきすと" Margin="10"/>
</StackPanel>
<StackPanel Grid.Row="2" Orientation="Horizontal" HorizontalAlignment="Right">
<Button Content="次へ" Width="100" Margin="10" Click="Button_Click"/>
</StackPanel>
</Grid>
</Page>
NavigationService.Navigate 인수에 표시할 페이지를 전달합니다.
Page1.xaml.cs(발췌)private static Page2 page2 = null;
// コンストラクタ
public Page1()
{
InitializeComponent();
}
// 「次へ」ボタンの処理
private void Button_Click(object sender, RoutedEventArgs e)
{
if (page2 == null)
{
// 次に表示するページ(ページ2)を生成、以後使いまわし
page2 = new Page2();
}
// ページ2へ移動
this.NavigationService.Navigate(page2);
}
Page2를 다음과 같이 편집합니다.
data:image/s3,"s3://crabby-images/86bb2/86bb26273d392d3f29b8a4051262fb22917bc426" alt=""
Page2.xaml<Page x:Class="WpfApplication6.Page2"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:local="clr-namespace:WpfApplication6"
mc:Ignorable="d"
d:DesignHeight="300" d:DesignWidth="300"
Title="ページ(2/3)">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="auto"/>
<RowDefinition/>
<RowDefinition Height="auto"/>
</Grid.RowDefinitions>
<TextBlock Text="2ページ目" FontSize="36" Margin="10"/>
<TextBox Grid.Row="1" Text="TextBox"/>
<StackPanel Grid.Row="2" Orientation="Horizontal" HorizontalAlignment="Right">
<Button Content="次へ" Width="100" Margin="10" Click="Button_Click"/>
</StackPanel>
</Grid>
</Page>
Page2.xaml.cs(발췌)private static Page3 page3 = null;
// コンストラクタ
public Page2()
{
InitializeComponent();
}
// 「次へ」ボタンの処理
private void Button_Click(object sender, RoutedEventArgs e)
{
if (page3 == null)
{
// 次に表示するページ(ページ3)を生成、以後使いまわし
page3 = new Page3();
}
// ページ3へ移動
this.NavigationService.Navigate(page3);
}
Page3를 다음과 같이 편집합니다.
data:image/s3,"s3://crabby-images/8d9dc/8d9dcc1ec02763820428d1d4da69d5d52ff36cd1" alt=""
Page3.xaml<Page x:Class="WpfApplication6.Page3"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:local="clr-namespace:WpfApplication6"
mc:Ignorable="d"
d:DesignHeight="300" d:DesignWidth="300"
Title="ページ(3/3)">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="auto"/>
<RowDefinition/>
<RowDefinition Height="auto"/>
</Grid.RowDefinitions>
<TextBlock Text="3ページ目" FontSize="36" Margin="10"/>
<TextBlock Grid.Row="1" Text="あああああ" FontSize="36" Margin="10"/>
<StackPanel Grid.Row="2" Orientation="Horizontal" HorizontalAlignment="Right">
<Button Content="完了" Width="100" Margin="10" Click="Button_Click"/>
</StackPanel>
</Grid>
</Page>
Page3.xaml.cs(발췌)// コンストラクタ
public Page3()
{
InitializeComponent();
}
// 「完了」ボタンの処理
private void Button_Click(object sender, RoutedEventArgs e)
{
// メイン画面を閉じる
App.Current.MainWindow.Close();
}
■ 움직여 보자
data:image/s3,"s3://crabby-images/1cca3/1cca35e995a77748b80577a63513aec757251a10" alt=""
다음 버튼을 눌러 두 번째 페이지로 이동합니다.
data:image/s3,"s3://crabby-images/1a24a/1a24a8543bd7a0d072db09a2130364d986bcb9a3" alt=""
다음 버튼을 눌러 세 번째 페이지로 이동합니다.
data:image/s3,"s3://crabby-images/c01bc/c01bc20d91c57e2f3c2a5b1bfaa16c83bfde7660" alt=""
완료 버튼을 누르면 프로그램이 종료됩니다.
위에 표시된 버튼은 브라우저의 '뒤로', '앞으로' 버튼과 같은 기능입니다.
이를 표시하지 않으려면 NavigationWindow
의 ShowsNavigationUI
속성을 false
로 설정합니다.
세 번째 페이지에서 돌아가기 버튼으로 두 번째 페이지로 돌아왔습니다.
앞으로 버튼이 활성화되었습니다.
data:image/s3,"s3://crabby-images/0bc1e/0bc1e4b0ce6313e7b81e21efff4a96b3ecc652f5" alt=""
앞으로 버튼 드롭다운에서 페이지를 이동할 수 있습니다.
data:image/s3,"s3://crabby-images/32b32/32b322eb3d9937a604b90c97cbbeecf120d150dc" alt=""
오시마
■참고 사이트
<Page x:Class="WpfApplication6.Page1"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:local="clr-namespace:WpfApplication6"
mc:Ignorable="d"
d:DesignHeight="300" d:DesignWidth="300"
Title="ページ(1/3)">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="auto"/>
<RowDefinition/>
<RowDefinition Height="auto"/>
</Grid.RowDefinitions>
<TextBlock Text="1ページ目" FontSize="36" Margin="10"/>
<StackPanel Grid.Row="1">
<CheckBox Content="チェック1" Margin="10"/>
<TextBox Text="てきすと" Margin="10"/>
</StackPanel>
<StackPanel Grid.Row="2" Orientation="Horizontal" HorizontalAlignment="Right">
<Button Content="次へ" Width="100" Margin="10" Click="Button_Click"/>
</StackPanel>
</Grid>
</Page>
private static Page2 page2 = null;
// コンストラクタ
public Page1()
{
InitializeComponent();
}
// 「次へ」ボタンの処理
private void Button_Click(object sender, RoutedEventArgs e)
{
if (page2 == null)
{
// 次に表示するページ(ページ2)を生成、以後使いまわし
page2 = new Page2();
}
// ページ2へ移動
this.NavigationService.Navigate(page2);
}
<Page x:Class="WpfApplication6.Page2"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:local="clr-namespace:WpfApplication6"
mc:Ignorable="d"
d:DesignHeight="300" d:DesignWidth="300"
Title="ページ(2/3)">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="auto"/>
<RowDefinition/>
<RowDefinition Height="auto"/>
</Grid.RowDefinitions>
<TextBlock Text="2ページ目" FontSize="36" Margin="10"/>
<TextBox Grid.Row="1" Text="TextBox"/>
<StackPanel Grid.Row="2" Orientation="Horizontal" HorizontalAlignment="Right">
<Button Content="次へ" Width="100" Margin="10" Click="Button_Click"/>
</StackPanel>
</Grid>
</Page>
private static Page3 page3 = null;
// コンストラクタ
public Page2()
{
InitializeComponent();
}
// 「次へ」ボタンの処理
private void Button_Click(object sender, RoutedEventArgs e)
{
if (page3 == null)
{
// 次に表示するページ(ページ3)を生成、以後使いまわし
page3 = new Page3();
}
// ページ3へ移動
this.NavigationService.Navigate(page3);
}
<Page x:Class="WpfApplication6.Page3"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:local="clr-namespace:WpfApplication6"
mc:Ignorable="d"
d:DesignHeight="300" d:DesignWidth="300"
Title="ページ(3/3)">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="auto"/>
<RowDefinition/>
<RowDefinition Height="auto"/>
</Grid.RowDefinitions>
<TextBlock Text="3ページ目" FontSize="36" Margin="10"/>
<TextBlock Grid.Row="1" Text="あああああ" FontSize="36" Margin="10"/>
<StackPanel Grid.Row="2" Orientation="Horizontal" HorizontalAlignment="Right">
<Button Content="完了" Width="100" Margin="10" Click="Button_Click"/>
</StackPanel>
</Grid>
</Page>
// コンストラクタ
public Page3()
{
InitializeComponent();
}
// 「完了」ボタンの処理
private void Button_Click(object sender, RoutedEventArgs e)
{
// メイン画面を閉じる
App.Current.MainWindow.Close();
}
data:image/s3,"s3://crabby-images/1cca3/1cca35e995a77748b80577a63513aec757251a10" alt=""
다음 버튼을 눌러 두 번째 페이지로 이동합니다.
data:image/s3,"s3://crabby-images/1a24a/1a24a8543bd7a0d072db09a2130364d986bcb9a3" alt=""
다음 버튼을 눌러 세 번째 페이지로 이동합니다.
data:image/s3,"s3://crabby-images/c01bc/c01bc20d91c57e2f3c2a5b1bfaa16c83bfde7660" alt=""
완료 버튼을 누르면 프로그램이 종료됩니다.
위에 표시된 버튼은 브라우저의 '뒤로', '앞으로' 버튼과 같은 기능입니다.
이를 표시하지 않으려면
NavigationWindow
의 ShowsNavigationUI
속성을 false
로 설정합니다.세 번째 페이지에서 돌아가기 버튼으로 두 번째 페이지로 돌아왔습니다.
앞으로 버튼이 활성화되었습니다.
data:image/s3,"s3://crabby-images/0bc1e/0bc1e4b0ce6313e7b81e21efff4a96b3ecc652f5" alt=""
앞으로 버튼 드롭다운에서 페이지를 이동할 수 있습니다.
data:image/s3,"s3://crabby-images/32b32/32b322eb3d9937a604b90c97cbbeecf120d150dc" alt=""
오시마
■참고 사이트
<< 첫 번째 기사 < 이전 기사 다음 기사 >
Reference
이 문제에 관하여(Windows GUI 프로그래밍 시작 6 화면 전환 (2)), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/Kosen-amai/items/9f5e56e8c80b348b127f텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)