Avalonia UI - スタイル定義

提供:MochiuWiki : SUSE, EC, PCB
2024年12月30日 (月) 06:28時点におけるWiki (トーク | 投稿記録)による版 (ページの作成:「== 概要 == コントロールのスタイルおよびテンプレートを別ファイルとして定義して再利用する<u>"スタイルの外部化"</u>を行う。<br> <br> スタイルの外部化を行うことにより、以下に示すようなメリットがある。<br> * 開発効率の向上 *: デザイナーと開発者の分業が容易になり、並行作業が可能になる。 *: コンポーネントの部品化による再利用性の向上…」)
(差分) ← 古い版 | 最新版 (差分) | 新しい版 → (差分)
ナビゲーションに移動 検索に移動

概要

コントロールのスタイルおよびテンプレートを別ファイルとして定義して再利用する"スタイルの外部化"を行う。

スタイルの外部化を行うことにより、以下に示すようなメリットがある。

  • 開発効率の向上
    デザイナーと開発者の分業が容易になり、並行作業が可能になる。
    コンポーネントの部品化による再利用性の向上する。
    デザインシステムの一貫性を保ちやすい。
  • コード管理の最適化
    関心の分離 (Separation of Concerns) 原則に従った明確な責任分担が可能となる。
    整理された階層的なファイル構造により、メンテナンス性が向上する。
    スタイル定義の集中管理による変更の追跡が容易になる。
  • 再利用性の最大化
    コードの重複を防ぎ、DRY原則を実現
    複数の画面での同一スタイルの再利用が容易になる。
    アプリケーション全体での一貫したデザインの実現できる。
    コンポーネントライブラリとしての活用が可能になる。
  • テーマ対応の柔軟性
    ダークモード/ライトモードの切り替えが容易になる。
    複数のテーマやブランディングへの対応が可能になる。
    カラーパレットやデザイントークンの一元管理できる。
  • 保守性の向上
    スタイルの変更が1箇所で完結し、影響範囲を制御可能になる。
    デザインの修正や更新が効率的になる。
    品質管理とテストが容易になる。


[プロジェクトのトップディレクトリ]
 ├── Styles/
 │   ├── ButtonStyles.axaml     # ボタンスタイル
 │   ├── TextBoxStyles.axaml    # テキストボックススタイル
 │   ├── Colors.axaml           # カラーテーマ
 │   └── Dimensions.axaml       # サイズ定義
 ├── Controls/
 │   └── CustomButton.axaml     # カスタムコントロール
 └── Views/
     └── MainWindow.axaml       # メインウインドウ


このような構造化により、大規模なプロジェクトでも効率的な開発とメンテナンスが可能となり、チーム開発での生産性が向上する。
また、デザインシステムの構築と進化にも柔軟に対応できる。


リソースディクショナリとして定義

 <!-- /Styles/ButtonStyles.axaml -->
 <ResourceDictionary xmlns="https://github.com/avaloniaui"
                     xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
    <Style Selector="Button.modern">
       <Setter Property="Background" Value="#2196F3"/>
       <Setter Property="Foreground" Value="White"/>
       <Setter Property="CornerRadius" Value="4"/>
       <Setter Property="Padding" Value="16,8"/>
       <Setter Property="BorderThickness" Value="0"/>
       <Setter Property="HorizontalContentAlignment" Value="Center"/>
       <Setter Property="VerticalContentAlignment" Value="Center"/>
 
       <Setter Property="Transitions">
          <Transitions>
             <TransformOperationsTransition Property="RenderTransform" Duration="0.2" Easing="CubicEaseOut"/>
             <BrushTransition Property="Background" Duration="0.2" Easing="CubicEaseOut"/>
          </Transitions>
       </Setter>
 
       <Style Selector="^:pointerover">
          <Setter Property="Background" Value="#1976D2"/>
          <Setter Property="RenderTransform" Value="scale(1.02)"/>
       </Style>
 
       <Style Selector="^:pressed">
          <Setter Property="RenderTransform" Value="scale(0.98)"/>
       </Style>
    </Style>
 </ResourceDictionary>



App.axamlでスタイル定義を読み込む

 <Application xmlns="https://github.com/avaloniaui"
              xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
    <Application.Styles>
       <FluentTheme />
 
       <!-- スタイルの読み込み -->
       <StyleInclude Source="/Styles/ButtonStyles.axaml"/>
    </Application.Styles>
 </Application>



スタイル定義の使用

例えば、MainWindow.axamlファイルでカスタムスタイル定義 (以下の例ではボタン) を使用する。

 <Button Classes="modern"
         Name="BtnStart" 
         Width="200" 
         Height="50"
         Click="btnStart_Click">
    Start
 </Button>


属性名 説明 備考
Classes="<スタイルクラス名>"
Classes="<スタイルクラス名 1> <スタイルクラス名 2>"
スタイルクラスの指定 ResourceDictionaryで定義されたスタイルクラス名を適用する。
複数のクラスを空白区切りで指定可能 (例: Classes="modern primary")
Name="<コントロールの識別子>" コントロールの一意な識別子 コードビハインドからコントロールを参照する場合は定義する。
XAMLとコードの橋渡しとなる重要な属性である。
Width="<数値>"
Width="Auto"
ボタンの幅をピクセル単位で指定する。 固定値での指定、あるいは、他の単位 (Width="Auto") や相対値も使用できる。
Height="<数値>"
Height="Auto"
ボタンの高さをピクセル単位で指定する。 固定値での指定、あるいは、他の単位 (Width="Auto") や相対値も使用できる。
Click="<イベントハンドラメソッド名>" コントロールのイベントハンドラメソッド名を指定する。 例えば、ボタンの場合は、クリックイベントハンドラメソッド名を指定する。
ただし、コードビハインド (.cs) ファイルに定義が必要となる。
コンテンツ名 (キャプション名) コントロールに表示されるテキストを指定する。 開始タグと終了タグの間に配置する。
他のコントロールや画像等も配置可能である。


その他、指定可能なプロパティを下表に示す。

プロパティ名 説明 備考
IsEnabled ボタンの有効 / 無効状態 true / falseで指定する。
falseの場合、ボタンは押下不可でグレーアウト表示される。
Background 背景色 Color型での指定が可能である。

ブラシ (SolidColorBrush等) での指定も可能。
また、透明度 (Alpha) の指定も可能。
Foreground 文字色 Backgroundと同様、Color型やブラシでの指定が可能である。
ボタン内のテキストやアイコンの色に適用する。
Padding 内部の余白 4辺個別に指定が可能である。(左,上,右,下)
一括指定も可能 (例 : Padding="10")

単位はピクセルであることに注意する。
Margin 外部の余白 Paddingと同様に4辺個別に指定が可能である。
コントロール間の間隔を調整する場合に使用する。

単位はピクセルであることに注意する。
HorizontalAlignment 水平方向の配置 親コンテナ内での配置位置を指定する。
Left, Center, Right, Stretchから選択可能である。
VerticalAlignment 垂直方向の配置 親コンテナ内での配置位置を指定する。
Top, Center, Bottom, Stretchから選択可能である。