ThemeControl.xaml 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. <UserControl x:Class="GeekDesk.Control.UserControls.Config.ThemeControl"
  2. xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  3. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  4. xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
  5. xmlns:viewmodel="clr-namespace:GeekDesk.ViewModel"
  6. d:DataContext="{d:DesignInstance Type=viewmodel:AppConfig}"
  7. xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
  8. xmlns:hc="https://handyorg.github.io/handycontrol"
  9. xmlns:cvt="clr-namespace:GeekDesk.Converts"
  10. mc:Ignorable="d"
  11. Background="Transparent"
  12. d:DesignHeight="500" d:DesignWidth="450">
  13. <UserControl.Resources>
  14. <cvt:BGStyleConvert x:Key="BGStyleConvert"/>
  15. <cvt:StringAppendConvert x:Key="StringAppendConvert"/>
  16. <cvt:Visibility2BooleanConverter x:Key="Visibility2BooleanConverter"/>
  17. </UserControl.Resources>
  18. <Grid>
  19. <Grid Background="Transparent">
  20. <StackPanel Margin="20" >
  21. <hc:UniformSpacingPanel Spacing="10" Margin="0,10,0,0" Grid.ColumnSpan="4">
  22. <TextBlock Text="背景风格" VerticalAlignment="Center"/>
  23. </hc:UniformSpacingPanel>
  24. <hc:UniformSpacingPanel Spacing="10" Margin="10,5,0,0" Grid.ColumnSpan="4">
  25. <RadioButton Margin="10,0,0,0" Background="{DynamicResource SecondaryRegionBrush}"
  26. Style="{StaticResource RadioButtonIcon}" Click="BGStyle_Changed" Content="图 片"
  27. IsChecked="{Binding BGStyle, Mode=TwoWay, Converter={StaticResource BGStyleConvert}, ConverterParameter=1}"/>
  28. <RadioButton Margin="10,0,0,0" Background="{DynamicResource SecondaryRegionBrush}"
  29. Style="{StaticResource RadioButtonIcon}" Click="BGStyle_Changed" Content="纯 色"
  30. IsChecked="{Binding BGStyle, Mode=TwoWay, Converter={StaticResource BGStyleConvert}, ConverterParameter=2}"/>
  31. </hc:UniformSpacingPanel>
  32. <UniformGrid x:Name="ImgBGConf">
  33. <hc:TransitioningContentControl TransitionMode="Fade"
  34. Height="130">
  35. <StackPanel>
  36. <hc:UniformSpacingPanel Spacing="10" Margin="0,10,0,0" Grid.ColumnSpan="4">
  37. <TextBlock Text="图片背景" VerticalAlignment="Center"/>
  38. </hc:UniformSpacingPanel>
  39. <hc:UniformSpacingPanel Spacing="10" Margin="20,15,0,0" Grid.ColumnSpan="4">
  40. <TextBlock Text="图片路径:" VerticalAlignment="Center" Margin="0,5,0,0"/>
  41. <TextBlock Text="{Binding BacImgName}" Width="200"
  42. Margin="0,5,0,0"
  43. VerticalAlignment="Center"
  44. hc:Poptip.HitMode="None"
  45. hc:Poptip.IsOpen="{Binding IsMouseOver, RelativeSource={RelativeSource Self}}"
  46. hc:Poptip.Content="{Binding BacImgName}"
  47. hc:Poptip.Placement="TopLeft"
  48. />
  49. <Button Content="修改" Click="BGButton_Click"/>
  50. <Button Content="默认" Click="DefaultButton_Click"/>
  51. </hc:UniformSpacingPanel>
  52. <hc:UniformSpacingPanel Spacing="10" Margin="20,10,0,0" Grid.ColumnSpan="4">
  53. <CheckBox x:Name="IconIsAdmin" Content="毛玻璃效果" Click="BGStyle_Changed" IsChecked="{Binding BlurEffect}">
  54. <CheckBox.Background>
  55. <LinearGradientBrush EndPoint="1,0" StartPoint="0,0">
  56. <GradientStop Color="#FF9EA3A6"/>
  57. </LinearGradientBrush>
  58. </CheckBox.Background>
  59. </CheckBox>
  60. </hc:UniformSpacingPanel>
  61. </StackPanel>
  62. </hc:TransitioningContentControl>
  63. </UniformGrid>
  64. <UniformGrid x:Name="GradientBGConf">
  65. <hc:TransitioningContentControl TransitionMode="Fade"
  66. Height="130">
  67. <StackPanel>
  68. <hc:UniformSpacingPanel Spacing="10" Margin="0,10,0,0" Grid.ColumnSpan="4">
  69. <TextBlock Text="纯色背景" VerticalAlignment="Center"/>
  70. </hc:UniformSpacingPanel>
  71. <hc:UniformSpacingPanel Spacing="10" Margin="20,0,0,0" Grid.ColumnSpan="4">
  72. <TextBlock Text="色彩1:" VerticalAlignment="Center" Margin="0,5,0,0"/>
  73. <TextBlock Text="{Binding GradientBGParam.Color1, NotifyOnTargetUpdated=True}"
  74. TargetUpdated="Color_TargetUpdated"
  75. Width="65"
  76. Margin="0,5,0,0"
  77. VerticalAlignment="Center"
  78. />
  79. <Button Content="设置" Tag="Color1" Click="ColorButton_Click"/>
  80. </hc:UniformSpacingPanel>
  81. <hc:UniformSpacingPanel Spacing="10" Margin="20,5,0,0" Grid.ColumnSpan="4">
  82. <TextBlock Text="色彩2:" VerticalAlignment="Center" Margin="0,5,0,0"/>
  83. <TextBlock Text="{Binding GradientBGParam.Color2, NotifyOnTargetUpdated=True}"
  84. TargetUpdated="Color_TargetUpdated"
  85. Width="65"
  86. Margin="0,5,0,0"
  87. VerticalAlignment="Center"
  88. />
  89. <Button Content="设置" Tag="Color2" Click="ColorButton_Click"/>
  90. </hc:UniformSpacingPanel>
  91. <Button Content="系统预设"
  92. Margin="0,5,0,0"
  93. hc:Poptip.HitMode="None"
  94. hc:Poptip.IsOpen="{Binding IsMouseOver, RelativeSource={RelativeSource Self}}"
  95. hc:Poptip.Content="{Binding GradientBGParam.Name, Converter={StaticResource StringAppendConvert}, ConverterParameter=当前设置: \{\}}"
  96. hc:Poptip.Placement="Top"
  97. Click="SysBG_Click"
  98. />
  99. </StackPanel>
  100. </hc:TransitioningContentControl>
  101. </UniformGrid>
  102. <hc:Divider LineStrokeDashArray="3,3" Margin="0,0,0,0" Height="20" LineStroke="Black" Grid.ColumnSpan="1"/>
  103. <hc:UniformSpacingPanel Spacing="10" Margin="5,-10,0,0" Grid.ColumnSpan="4">
  104. <CheckBox Content="主窗口动画" IsChecked="{Binding AppAnimation}" Click="Animation_Checked">
  105. <CheckBox.Background>
  106. <LinearGradientBrush EndPoint="1,0" StartPoint="0,0">
  107. <GradientStop Color="#FF9EA3A6"/>
  108. </LinearGradientBrush>
  109. </CheckBox.Background>
  110. </CheckBox>
  111. </hc:UniformSpacingPanel>
  112. <hc:UniformSpacingPanel Spacing="10" Margin="5,10,0,0" Grid.ColumnSpan="4">
  113. <CheckBox Content="列表展开动画" IsChecked="{Binding ItemSpradeAnimation}">
  114. <CheckBox.Background>
  115. <LinearGradientBrush EndPoint="1,0" StartPoint="0,0">
  116. <GradientStop Color="#FF9EA3A6"/>
  117. </LinearGradientBrush>
  118. </CheckBox.Background>
  119. </CheckBox>
  120. </hc:UniformSpacingPanel>
  121. <hc:UniformSpacingPanel Spacing="10" Margin="5,10,0,0" Grid.ColumnSpan="4">
  122. <CheckBox x:Name="BarIcon" Content="显示托盘图标" IsChecked="{Binding ShowBarIcon}">
  123. <CheckBox.Background>
  124. <LinearGradientBrush EndPoint="1,0" StartPoint="0,0">
  125. <GradientStop Color="#FF9EA3A6"/>
  126. </LinearGradientBrush>
  127. </CheckBox.Background>
  128. </CheckBox>
  129. </hc:UniformSpacingPanel>
  130. <hc:UniformSpacingPanel Spacing="10" Margin="5,10,0,0" Grid.ColumnSpan="4">
  131. <CheckBox Content="显示主面板Logo" IsChecked="{Binding TitleLogoVisible, Mode=TwoWay, Converter={StaticResource Visibility2BooleanConverter}}">
  132. <CheckBox.Background>
  133. <LinearGradientBrush EndPoint="1,0" StartPoint="0,0">
  134. <GradientStop Color="#FF9EA3A6"/>
  135. </LinearGradientBrush>
  136. </CheckBox.Background>
  137. </CheckBox>
  138. </hc:UniformSpacingPanel>
  139. <StackPanel Margin="0,15,0,0">
  140. <hc:UniformSpacingPanel Spacing="10" Grid.ColumnSpan="4">
  141. <TextBlock Text="卡片不透明度" VerticalAlignment="Center"/>
  142. </hc:UniformSpacingPanel>
  143. <hc:UniformSpacingPanel Spacing="10" Margin="10,5,0,0" Grid.ColumnSpan="4">
  144. <hc:PreviewSlider Value="{Binding CardOpacity}"
  145. Maximum="100"
  146. Width="350"
  147. >
  148. <hc:PreviewSlider.PreviewContent>
  149. <Label Style="{StaticResource LabelPrimary}" Content="{Binding Path=(hc:PreviewSlider.PreviewPosition),RelativeSource={RelativeSource Self}}" ContentStringFormat="#0"/>
  150. </hc:PreviewSlider.PreviewContent>
  151. </hc:PreviewSlider>
  152. </hc:UniformSpacingPanel>
  153. <hc:UniformSpacingPanel Spacing="10" Margin="0,10,0,0" Grid.ColumnSpan="4">
  154. <TextBlock Text="背景不透明度" VerticalAlignment="Center"/>
  155. </hc:UniformSpacingPanel>
  156. <hc:UniformSpacingPanel Spacing="10" Margin="10,5,0,0" Grid.ColumnSpan="4">
  157. <hc:PreviewSlider Value="{Binding BgOpacity}"
  158. ValueChanged="BGOpacity_ValueChanged"
  159. Maximum="100"
  160. Width="350"
  161. >
  162. <hc:PreviewSlider.PreviewContent>
  163. <Label Style="{StaticResource LabelPrimary}" Content="{Binding Path=(hc:PreviewSlider.PreviewPosition),RelativeSource={RelativeSource Self}}" ContentStringFormat="#0"/>
  164. </hc:PreviewSlider.PreviewContent>
  165. </hc:PreviewSlider>
  166. </hc:UniformSpacingPanel>
  167. <!--<hc:UniformSpacingPanel Spacing="10" Margin="0,10,0,0" Grid.ColumnSpan="4">
  168. <TextBlock Text="主面板不透明度" VerticalAlignment="Center"/>
  169. </hc:UniformSpacingPanel>
  170. <hc:UniformSpacingPanel Spacing="10" Margin="10,5,0,0" Grid.ColumnSpan="4">
  171. <hc:PreviewSlider Value="{Binding PannelOpacity}"
  172. Minimum="50"
  173. Maximum="100"
  174. Width="350"
  175. >
  176. <hc:PreviewSlider.PreviewContent>
  177. <Label Style="{StaticResource LabelPrimary}" Content="{Binding Path=(hc:PreviewSlider.PreviewPosition),RelativeSource={RelativeSource Self}}" ContentStringFormat="#0"/>
  178. </hc:PreviewSlider.PreviewContent>
  179. </hc:PreviewSlider>
  180. </hc:UniformSpacingPanel>-->
  181. <hc:UniformSpacingPanel Spacing="10" Margin="0,10,0,0" Grid.ColumnSpan="4">
  182. <TextBlock Text="主面板圆角大小" VerticalAlignment="Center"/>
  183. </hc:UniformSpacingPanel>
  184. <hc:UniformSpacingPanel Spacing="10" Margin="10,5,0,0" Grid.ColumnSpan="4">
  185. <hc:PreviewSlider Value="{Binding PannelCornerRadius}"
  186. Maximum="25"
  187. Width="350"
  188. >
  189. <hc:PreviewSlider.PreviewContent>
  190. <Label Style="{StaticResource LabelPrimary}" Content="{Binding Path=(hc:PreviewSlider.PreviewPosition),RelativeSource={RelativeSource Self}}" ContentStringFormat="#0"/>
  191. </hc:PreviewSlider.PreviewContent>
  192. </hc:PreviewSlider>
  193. </hc:UniformSpacingPanel>
  194. <hc:UniformSpacingPanel Spacing="10" Margin="0,10,0,0" Grid.ColumnSpan="4">
  195. <TextBlock Text="图标大小" VerticalAlignment="Center"/>
  196. </hc:UniformSpacingPanel>
  197. <hc:UniformSpacingPanel Spacing="10" Margin="10,5,0,0" Grid.ColumnSpan="4"
  198. Background="#00FFFFFF"
  199. PreviewMouseLeftButtonDown="PreviewSlider_MouseLeftButtonUp"
  200. >
  201. <hc:PreviewSlider Value="{Binding ImageWidth, Mode=TwoWay}"
  202. Minimum="40"
  203. Maximum="60"
  204. Width="350"
  205. >
  206. <hc:PreviewSlider.PreviewContent>
  207. <Label Style="{StaticResource LabelPrimary}" Content="{Binding Path=(hc:PreviewSlider.PreviewPosition),RelativeSource={RelativeSource Self}}" ContentStringFormat="#0"/>
  208. </hc:PreviewSlider.PreviewContent>
  209. </hc:PreviewSlider>
  210. </hc:UniformSpacingPanel>
  211. </StackPanel>
  212. <hc:Divider LineStrokeDashArray="3,3" LineStroke="Black" Grid.ColumnSpan="4"/>
  213. <hc:UniformSpacingPanel Spacing="10" Grid.ColumnSpan="4">
  214. <TextBlock VerticalAlignment="Center" Text="图标字体颜色:" />
  215. <TextBlock VerticalAlignment="Center" Text="{Binding TextColor}" Foreground="{Binding TextColor}" Width="100"/>
  216. <Button Content="选择" Margin="0,-10,0,0" Tag="Text" Click="ColorButton_Click"/>
  217. </hc:UniformSpacingPanel>
  218. </StackPanel>
  219. </Grid>
  220. <!--<StackPanel x:Name="ColorPanel" Panel.ZIndex="1"
  221. Visibility="Collapsed"
  222. Height="500"
  223. Width="450"
  224. VerticalAlignment="Center">
  225. <StackPanel.Background>
  226. <SolidColorBrush Color="AliceBlue" Opacity="0.01"/>
  227. </StackPanel.Background>-->
  228. <!--<hc:ColorPicker Name="MyColorPicker"
  229. Canceled="MyColorPicker_Canceled"
  230. Confirmed="MyColorPicker_Confirmed"
  231. SelectedColorChanged="MyColorPicker_SelectedColorChanged"/>-->
  232. <!--</StackPanel>-->
  233. </Grid>
  234. </UserControl>