C#プログラミング

【C#】Styleを値に応じて変化させるDataTrigger【WPF】

スタイルを値に応じて変化させる方法記事のアイキャッチ画像 C#

C#のGUIを値に応じて変化させる方法をサンプルコードで紹介します。ソフトの状態を文字のみで表現していると場所をとったり、分かりづらかったりします。色などを動的に変化させることで、見た目や操作性を格段に良くすることができます。今回は、DataTriggerを用いてGUIを自動で変化させる方法を簡単なサンプルコード付きで紹介します。

スポンサーリンク

Styleに関する基本情報

まずStyleやGUIパーツ(コントロール)の見た目を変更したことない方は、まずこちらの記事を見てみてください。

GUIパーツ(コントロール)の外観を変更したことがない方はまず以下記事を確認ください。
TextBlockの配置や色を変えています。

スタイルを一括で設定する方法は以下記事で紹介しています。

本記事はこれらの続編になります。

スポンサーリンク

動的にStyleを変えるDataTrigger

動的にコントロールのスタイルを変化させるには、Style.TriggersStyleの中に記載します。

プログラム内の変数と連動したい場合は、Style.Triggersの中にDataTriggerを記載します。
そこに連動させたい変数をバインドし、Setterタグに設定を記載します。

スポンサーリンク

値に応じてstyleを変化させるサンプルコード

ボタンを押すとON/OFFの文字変化とその色が変わるサンプルを作成しました。
このような使い方は実用上よくあると思います。

サンプルソフトの動作の様子

コードはMVVM形式になっています。MVVMに関しては以下記事で紹介しています。

View

まずはXAMLです。TextBlockを対象(TargetType)にしています。
<Style.Triggers/>の外に記載した内容は、通常のStyleとして反映されるので、Triggerによる変更要素が反映されない場合は、優先されます。

<Window.Resources>
    <Style TargetType="TextBlock">
        <!--デフォルトの設定-->
        <Setter Property="Text" Value="OFF" />
        <Setter Property="Foreground" Value="Blue" />
        <!--値に応じて変化する要素-->
        <Style.Triggers>
            <DataTrigger Binding="{Binding style_flg}" Value="true">
                <Setter Property="Text" Value="ON"/>
                <Setter Property="Foreground" Value="Red" />
            </DataTrigger>
        </Style.Triggers>
    </Style>
</Window.Resources>
    
<Grid>
    <StackPanel Orientation="Vertical" >
        <Label Content="★出力ウィンド - - - - -" />
            
        <!--テスト用TextBlock(Triggerで変化させない不変な設定はこちらに記載)-->
        <TextBlock HorizontalAlignment="Center" Margin="10" FontSize="50"/>

        <!--操作用ボタン-->
        <Button Content="Style切り替えボタン" Margin="30" Command="{Binding Button1_Pushed}" />

    </StackPanel>
</Grid>

コードビハインドはいつものやつです。工夫なし。

using Style.ViewModels;
using System.Windows;

namespace Style.Views
{
    public partial class MainWindow : Window
    {
        MainViewModel vm = new MainViewModel();
        
        public MainWindow()
        {
            InitializeComponent();

            this.DataContext = vm;
        }
    }
}

ViewModel

ボタンを押すとフラグ(style_flg)のtrue/falseが反転します。

using Style.Common;
using System;
using System.ComponentModel;
using System.Windows.Input;

namespace Style.ViewModels
{
    internal class MainViewModel : INotifyPropertyChanged
    {
        //コマンド
        public ICommand Button1_Pushed { get; set; }

        public MainViewModel()
        {
            //コマンド
            Button1_Pushed = new RelayCommand(Button1_Command);
        }

        //コマンドの処理内容
        private void Button1_Command()
        {
            //style_flgの[true/false]切り替え
            if (style_flg == true)
                style_flg = false;
            else
                style_flg = true;
        }

        //スタイル変更フラグ
        private bool _style_flg = false;
        public bool style_flg
        {
            get { return _style_flg; }
            set
            {
                _style_flg = value;
                NotifyPropertyChanged("style_flg");
            }
        }

        //変数の更新通知用
        public event PropertyChangedEventHandler PropertyChanged;
        private void NotifyPropertyChanged(String info)
        {
            if (PropertyChanged != null)
            {
                PropertyChanged(this, new PropertyChangedEventArgs(info));
            }
        }
    }
}

Modelはないです。

スポンサーリンク

さいごに

以下はC#のGUI関連記事などです。

コメント

タイトルとURLをコピーしました