WPF MaterialDesign 颜色选择器自定义模板颜色

首先得确保程序UI使用的是MaterialDesign。

本版本为5.0以上版本,低版本个别类名会有出入,按提示修改即可:

XMAL页面:

<UserControl x:Class="**********************"
             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="********************************"
             xmlns:materialDesign="http://materialdesigninxaml.net/winfx/xaml/themes"
             xmlns:materialDesignColors="clr-namespace:MaterialDesignColors;assembly=MaterialDesignColors"
             mc:Ignorable="d" 
             xmlns:converters="这里引用自己转换器的地址"
             d:DesignHeight="450" d:DesignWidth="800">
    <UserControl.Resources>
        <ResourceDictionary>
            <ResourceDictionary.MergedDictionaries>
                <ResourceDictionary Source="pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.TextBlock.xaml" />
                <ResourceDictionary Source="pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.ToggleButton.xaml" />
                <ResourceDictionary Source="pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.Button.xaml" />
            </ResourceDictionary.MergedDictionaries>
            <converters:ColorToBrushConverter x:Key="ColorToBrushConverter" />
        </ResourceDictionary>
    </UserControl.Resources>
                <materialDesign:Card Margin="5" materialDesign:ElevationAssist.Elevation="Dp4" BorderThickness="3" BorderBrush="White">
                    <!-- Color picker section -->
                    <DockPanel Margin="16">
                        <Grid DockPanel.Dock="Left">
                            <Grid>
                                <Grid.ColumnDefinitions>
                                    <ColumnDefinition Width="160" />
                                    <ColumnDefinition />
                                </Grid.ColumnDefinitions>
                                <Grid.RowDefinitions>
                                    <RowDefinition Height="auto"/>
                                    <RowDefinition/>
                                </Grid.RowDefinitions>

                                <StackPanel Orientation="Horizontal" Margin="5">
                                    <TextBlock Text="浅色"/>
                                    <ToggleButton Style="{DynamicResource MaterialDesignSwitchToggleButton}"
                                     IsChecked="{Binding IsDarkTheme}" ToolTip="点击切换主题">
                                        <materialDesign:PackIcon
Kind="Pin"
RenderTransformOrigin=".5,.5">
                                            <materialDesign:PackIcon.RenderTransform>
                                                <RotateTransform
    Angle="45" />
                                            </materialDesign:PackIcon.RenderTransform>
                                        </materialDesign:PackIcon>
                                        <materialDesign:ToggleButtonAssist.OnContent>
                                            <materialDesign:PackIcon
  Kind="Pin" />
                                        </materialDesign:ToggleButtonAssist.OnContent>
                                    </ToggleButton>
                                    <TextBlock Text="深色"/>
                                </StackPanel>
                                <!--左侧颜色查看-->
                                <DockPanel Grid.Row="1">
                                    <TextBox Margin="2,0,10,2"
                   materialDesign:HintAssist.Hint="Color HEX value"
                   DockPanel.Dock="Top"
                   Style="{StaticResource MaterialDesignFilledTextBox}"
                   Text="{Binding Color, ElementName=ColorPicker, UpdateSourceTrigger=PropertyChanged}" />
                                    <Rectangle Margin="2,0,10,2" Fill="{Binding Color, ElementName=ColorPicker, Converter={StaticResource ColorToBrushConverter}}" />
                                </DockPanel>
                                <!--颜色选择器-->
                                <materialDesign:ColorPicker x:Name="ColorPicker"
                                    Grid.Column="1"
                                            Grid.RowSpan="2"
                                    Color="{Binding SelectedColor}" />
                            </Grid>
                        </Grid>
                    </DockPanel>
                </materialDesign:Card>
</UserControl>

后台cs代码:

public partial class Setting : UserControl, INotifyPropertyChanged
 {
     public event PropertyChangedEventHandler PropertyChanged;
     public void OnPropertyChanged([CallerMemberName] string propertyname = "")
     {
         PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyname));
     }
     public Setting()
     {
        InitializeComponent();
        ThemeInit();
     }
    #region 修改主题与颜色
  /// <summary>
  /// 初始化获取当前模板,在构造方法使用该方法
  /// </summary>
  private void ThemeInit()
  {
      //获取当前主题
      Theme theme = _paletteHelper.GetTheme();
      var the = theme.GetBaseTheme();
      if (the == BaseTheme.Dark)
      {
          _isDarkTheme = true;
      }
      SelectedColor = theme.PrimaryDark.Color;
  }

  private bool _isDarkTheme;
  /// <summary>
  /// 是否黑色模板
  /// </summary>
  public bool IsDarkTheme
  {
      get => _isDarkTheme;
      set
      {
          _isDarkTheme = value;
          OnPropertyChanged();
          ApplyBase(_isDarkTheme);
      }
  }
  private readonly PaletteHelper _paletteHelper = new PaletteHelper();
  private Color? _selectedColor;
  /// <summary>
  /// 颜色选择器的当前颜色
  /// </summary>
  public Color? SelectedColor
  {
      get => _selectedColor;
      set
      {
          if (_selectedColor != value)
          {
              _selectedColor = value;
              OnPropertyChanged();
              if (value is Color color)
              {
                  ChangeHue(color);
              }
          }
      }
  }
  /// <summary>
  /// 修改主题
  /// </summary>
  /// <param name="isDark"></param>
  private void ApplyBase(bool isDark)
  {
      Theme theme = _paletteHelper.GetTheme();
      theme.SetBaseTheme(isDark ? BaseTheme.Dark : BaseTheme.Light);
      _paletteHelper.SetTheme(theme);
  }
  /// <summary>
  /// 修改主题颜色
  /// </summary>
  /// <param name="obj"></param>
  private void ChangeHue(object obj)
  {
      var hue = (Color)obj;
      SelectedColor = hue;
      //修改主要背景色
      ChangePrimaryColor(_paletteHelper, hue);
      //修改次要背景色
      ChangeSecondaryColor(_paletteHelper, hue);
  }
  /// <summary>
  /// 修改主要前景色
  /// </summary>
  /// <param name="color"></param>
  private void SetPrimaryForegroundToSingleColor(Color color)
  {
      Theme theme = _paletteHelper.GetTheme();
      theme.PrimaryLight = new ColorPair(theme.PrimaryLight.Color, color);
      theme.PrimaryMid = new ColorPair(theme.PrimaryMid.Color, color);
      theme.PrimaryDark = new ColorPair(theme.PrimaryDark.Color, color);
      _paletteHelper.SetTheme(theme);
  }
  /// <summary>
  /// 修改次要前景色
  /// </summary>
  /// <param name="color"></param>
  private void SetSecondaryForegroundToSingleColor(Color color)
  {
      Theme theme = _paletteHelper.GetTheme();
      theme.SecondaryLight = new ColorPair(theme.SecondaryLight.Color, color);
      theme.SecondaryMid = new ColorPair(theme.SecondaryMid.Color, color);
      theme.SecondaryDark = new ColorPair(theme.SecondaryDark.Color, color);
      _paletteHelper.SetTheme(theme);
  }
  /// <summary>
  /// 修改主要背景色
  /// </summary>
  /// <param name="paletteHelper"></param>
  /// <param name="color"></param>
  public void ChangePrimaryColor(PaletteHelper paletteHelper, Color color)
  {
      Theme theme = paletteHelper.GetTheme();
      theme.PrimaryLight = new ColorPair(color.Lighten());
      theme.PrimaryMid = new ColorPair(color);
      theme.PrimaryDark = new ColorPair(color.Darken());
      paletteHelper.SetTheme(theme);
  }
  /// <summary>
  /// 修改次要背景色
  /// </summary>
  /// <param name="paletteHelper"></param>
  /// <param name="color"></param>
  public void ChangeSecondaryColor(PaletteHelper paletteHelper, Color color)
  {
      Theme theme = paletteHelper.GetTheme();
      theme.SecondaryLight = new ColorPair(color.Lighten());//该颜色的亮色
      theme.SecondaryMid = new ColorPair(color);
      theme.SecondaryDark = new ColorPair(color.Darken());//该颜色的暗色
      paletteHelper.SetTheme(theme);
  }
  #endregion
}

颜色转换器:

[ValueConversion(typeof(Color), typeof(Brush))]
public class ColorToBrushConverter : IValueConverter
{
    public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
    {
        if (value is Color color)
        {
            return new SolidColorBrush(color);
        }
        return Binding.DoNothing;
    }

    public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
    {
        if (value is SolidColorBrush brush)
        {
            return brush.Color;
        }
        return default(Color);
    }
}

本次App.xaml引用如下(这是5.0以上版本的引用方法):

<Application x:Class="***.App"
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             xmlns:local="clr-namespace:****"
             xmlns:materialDesign="http://materialdesigninxaml.net/winfx/xaml/themes"
             StartupUri="MainWindow.xaml">
    <Application.Resources>
        <ResourceDictionary>
            <ResourceDictionary.MergedDictionaries>
                <materialDesign:BundledTheme BaseTheme="Dark"
                                     ColorAdjustment="{materialDesign:ColorAdjustment}"
                                     PrimaryColor="Blue"
                                     SecondaryColor="Lime" />
                <ResourceDictionary Source="pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesign3.Defaults.xaml" />
            </ResourceDictionary.MergedDictionaries>
        </ResourceDictionary>
    </Application.Resources>
</Application>

最后注意一点:若想要控件颜色随选择变化,不能给控件设置固定颜色,并且得使用属性Mode="PrimaryDark"或者materialDesign:ColorZoneAssist.Mode。这两个属性有三个可变化的值皆是Primary***。控件能使用哪个用哪个。也可根据该UI的Demo查看详情,若需要按钮式的参考WPF 学习:如何照着MaterialDesign的Demo学习_materialdesigndemo-CSDN博客

好记性不如烂笔头.........................................................................................................

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
WPF MaterialDesign演示程序是一款基于Windows Presentation Foundation(WPF)框架开发的演示程序。MaterialDesign是一种现代化的设计风格,以扁平化、简洁化和有层次感的界面设计为特点。这个演示程序提供了丰富的MaterialDesign控件和效果,帮助开发人员更好地理解和应用这种设计风格。 要下载WPF MaterialDesign演示程序,可以按照以下步骤进行: 1. 打开你常用的浏览程序,如Google Chrome、火狐浏览等。 2. 在浏览地址栏中输入“WPF MaterialDesign演示程序下载”关键词进行搜索。 3. 选择一个可信赖的官方网站或者开发者网站,找到相关的下载页面。 4. 在下载页面中,可能会提供不同版本的WPF MaterialDesign演示程序。选择适合你的操作系统和开发环境的版本。 5. 点击下载按钮并等待下载完成。这个过程可能需要一定的时间,取决于你的下载速度。 6. 下载完成后,找到下载的安装文件,双击运行安装程序。 7. 按照安装程序的引导进行安装,选择安装路径和其他设置参数。 8. 等待安装完成后,就可以打开WPF MaterialDesign演示程序进行使用了。 需要注意的是,下载和安装WPF MaterialDesign演示程序之前,建议确保你的电脑满足相应的系统和硬件要求,以及没有安全软件的阻止。 总结起来,下载WPF MaterialDesign演示程序只需要在浏览中搜索并选择可信赖的下载来源,然后按照相应的步骤进行下载和安装即可。这个演示程序将为你提供一个实践和学习MaterialDesign设计风格的平台。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小白

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值