31章:ピクチャ ビューアーの作成

    作成2013.04.23

     ここでは、Windowsフォームアプリケーション用サンプルコードをWPFアプリケーション用コードに変換します。フォームアプリケーションからWPFアプリケーションへの変化が最近の主流のようです。

  1. 参照元情報
    「ピクチャ ビューアーの作成」にジャンプする
    「WPF - Windows フォーム用のコントロールを使う」にジャンプする
     作成方法の詳細は上記を参照願います。


  2. フォームアプリケーションからWPFアプリケーションへの変更
     若干の変更でフォームアプリケーションからWPFアプリケーションへの変更ができます。
     完成ファイルは以下からダウンロードできます。
     ダウンロード後は解凍してから使用してください。
      [WPFピクチャ ビューアーの作成]をダウンロードする。
     解凍すると「31WpfAPictureViewer」フォルダーがあります。
    注(1)「31WpfAPictureViewer」フォルダーの「WpfAPictureViewer.sln」ファイルをダブルクリックすると「Express 2012 for Windows Desktop」が起動します。
    注(2)メニューの「ウインド」_「ウインドレイアウトのリセット」で標準に戻ります。
    注(3)「ソリューションエクスプローラ」ウインドウ内の「MainWindow.xaml」をダブルクリックすると「デザイン」と「XAML」が表示されます。
    注(4)メニューの「表示」_「コード」を選択するとコードが表示されます。
    注(5)「WpfAPictureViewer.sln」の動作確認は「デバッグ」_「デバッグ開始」で実行します。デバッグ機能を用いて動作確認を行います。


  3. WpfAPictureViewer.slnの実行
    (1)「Express 2012 for Windows Desktop」のデバッグ機能を使用します。
    (2)「デバッグ」_「デバッグ開始」を選択します。
    (3)MainWindow画面が表示されます。
    (2)「Show a picture」ボタンを押します。
    (3)OpenFileDialogが表示されますので、画像ファイルを選択し開きます。
    (4)選択した画像が表示されます。
    (5)最大化ボタンを押すとウインドウは画面いっぱいに広がります。
    (6)Strech(CheckBox)のチェックをはずすと縦横比が変化します。
    (7)チェックをいれた状態でSet thebackground colorボタンを押すとColorDiaalogが表示されます。
    (8)色を選択しOKボタンを押すと背景色が変わります。
    (9)Clear the pictureボタンを押すと背景色のみになります。
    (10)Closeボタンをおすとプログラムは終了します。


  4. プロジェクトの構成
    (1)UserControl1.vbの構成
    ・OpenFileDialog1とColorDialog1とPicturBox1を配置します。

    (2)XAMLコードの構成
    ・UserControl1とCheckBoxとButtonを配置します。

    注:OpenFileDialog1とColorDialog1とPicturBox1がフォームアプリケーション用のツールとなります。


  5. MainWindow.xamlの全コード
    <Window x:Class="MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:wf="clr-namespace:System.Windows.Forms;assembly=System.Windows.Forms"
        xmlns:self="clr-namespace:WpfAPictureViewer"
        Title="MainWindow" Height="350" Width="525">
        <Grid>
    
            <Grid.RowDefinitions>
                <RowDefinition Height="*" />
                <RowDefinition Height="30" />
            </Grid.RowDefinitions>
            <WindowsFormsHost x:Name="wfHost"  Grid.Row="0">
                <self:UserControl1 x:Name="myControl"  />
            </WindowsFormsHost>
            <StackPanel Grid.Row="1"  Name="StackPanel1"  Orientation="Horizontal">
                <CheckBox Content="Stretch" Height="16" Width="100" Name="CheckBox1"  IsChecked="True" />
                <Button Content="Show a picture" Height="23" Name="Button1" />
                <Button Content="Clear the picture" Height="23" Name="Button2" />
                <Button Content="Set the background color" Height="23" Name="Button3"  />
                <Button Content="Close" Height="23" Name="Button4"  />
            </StackPanel>
        </Grid>
    </Window>
    


  6. MainWindow.xamlコードの解説
    (1)<Window>階層1:クラス:以下の記載が特別です。
     xmlns:wf="clr-namespace:System.Windows.Forms;assembly=System.Windows.Forms"
     上記の記載はMaskedTextBoxクラスを使用するための記載です。MaskedTextBoxクラスは名前空間が System.Windows.Formsであり具体的にはsystem.windows.forms.dll 内にあると思われます。
    xmlns:self="clr-namespace:WpfAPictureViewer"
     上記の記載はWpfAPictureViewerソリューションを使用するための記載です。
    (2) <WindowsFormsHost x:Name="wfHost" Grid.Row="0">
    <self:UserControl1 x:Name="myControl" />
    </WindowsFormsHost>
     上記の記載でUserControl1の使用条件を設定します。名前は"myControl" となります。
    (3)<StackPanel Grid.Row="1" Name="StackPanel1" Orientation="Horizontal">
    <CheckBox Content="Stretch" Height="16" Width="100" Name="CheckBox1" IsChecked="True" />
    <Button Content="Show a picture" Height="23" Name="Button1" />
    <Button Content="Clear the picture" Height="23" Name="Button2" />
    <Button Content="Set the background color" Height="23" Name="Button3" />
    <Button Content="Close" Height="23" Name="Button4" />
    </StackPanel>
     上記の記載でCheckBoxとButtonを配置します。


  7. MainWindow.xaml.csの全コード
    using System.Windows;
    
    namespace WpfAPictureViewer
    {
        public partial class MainWindow : Window
        {
            public MainWindow()
            {InitializeComponent(); }
    
            private void Button1_Click(object sender, RoutedEventArgs e)
            {
                if (myControl.OpenFileDialog1.ShowDialog() == System.Windows.Forms.DialogResult.OK)
                {myControl.PictureBox1.Load(myControl.OpenFileDialog1.FileName);}
            }
    
            private void Button2_Click(object sender, RoutedEventArgs e)
            {myControl.PictureBox1.Image = null;}
    
            private void Button3_Click(object sender, RoutedEventArgs e)
            {
                if (myControl.ColorDialog1.ShowDialog() == System.Windows.Forms.DialogResult.OK)
                { myControl.PictureBox1.BackColor = myControl.ColorDialog1.Color;}
            }
    
            private void Button4_Click(object sender, RoutedEventArgs e)
            { Close();}
    
            private void CheckBox1_Checked(object sender, RoutedEventArgs e)
            { myControl.PictureBox1.SizeMode = System.Windows.Forms.PictureBoxSizeMode.Zoom;}
    
            private void CheckBox1_Unchecked(object sender, RoutedEventArgs e)
            { myControl.PictureBox1.SizeMode = System.Windows.Forms.PictureBoxSizeMode.StretchImage;}
        }
    }
    


  8. MainWindow.xaml.csコードの解説
    (1)private void Button1_Click(object sender, RoutedEventArgs e)
    {
    if (myControl.OpenFileDialog1.ShowDialog() == System.Windows.Forms.DialogResult.OK)
    {myControl.PictureBox1.Load(myControl.OpenFileDialog1.FileName);}
    }
     上記の記載でOpenFileDialog1で選択した画像ファイルをPictureBox1に表示します。
    (2) private void Button2_Click(object sender, RoutedEventArgs e)
    {myControl.PictureBox1.Image = null;}
     上記の記載でPictureBox1の画像を消去します。
    (3)private void Button3_Click(object sender, RoutedEventArgs e)
    {
    if (myControl.ColorDialog1.ShowDialog() == System.Windows.Forms.DialogResult.OK)
    { myControl.PictureBox1.BackColor = myControl.ColorDialog1.Color;}
    }
     上記の記載でColorDialog1で選択した色を背景色に設定します。
    (4)private void Button4_Click(object sender, RoutedEventArgs e)
    { Close();}
     上記の記載でプログラムを終了します。
    (5)private void CheckBox1_Checked(object sender, RoutedEventArgs e)
    { myControl.PictureBox1.SizeMode = System.Windows.Forms.PictureBoxSizeMode.Zoom;}
     上記の記載でPictureBox1をZoomモードに設定します。
    (6)private void CheckBox1_Unchecked(object sender, RoutedEventArgs e)
    { myControl.PictureBox1.SizeMode = System.Windows.Forms.PictureBoxSizeMode.StretchImage;}
     上記の記載でPictureBox1をStretchImageモードに設定します。


  9. Public Class UserControl1クラスのコード
     Public Class UserControl1クラスのコードの記載はありません。

    感想:
    (1)UserControlを使用することにより、簡単にWPFアプリケーションに変換できます。







32章:WPF迷路の作成に行く。

トップページに戻る。