ThemeControl.xaml 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242
  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"
  26. Style="{StaticResource MyRadioBtnStyle}" Click="BGStyle_Changed" Content="图 片"
  27. IsChecked="{Binding BGStyle, Mode=TwoWay, Converter={StaticResource BGStyleConvert}, ConverterParameter=1}"/>
  28. <RadioButton Margin="10,0,0,0"
  29. Style="{StaticResource MyRadioBtnStyle}" 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="修改" Style="{StaticResource MyBtnStyle}" Click="BGButton_Click"/>
  50. <Button Content="默认" Style="{StaticResource MyBtnStyle}" Click="DefaultButton_Click"/>
  51. </hc:UniformSpacingPanel>
  52. <hc:UniformSpacingPanel Spacing="10" Margin="20,10,0,0" Grid.ColumnSpan="4">
  53. <CheckBox Style="{StaticResource MyCheckBoxStyle}" x:Name="IconIsAdmin" Content="毛玻璃效果" Click="BGStyle_Changed" IsChecked="{Binding BlurEffect}"/>
  54. </hc:UniformSpacingPanel>
  55. </StackPanel>
  56. </hc:TransitioningContentControl>
  57. </UniformGrid>
  58. <UniformGrid x:Name="GradientBGConf">
  59. <hc:TransitioningContentControl TransitionMode="Fade"
  60. Height="130">
  61. <StackPanel>
  62. <hc:UniformSpacingPanel Spacing="10" Margin="0,10,0,0" Grid.ColumnSpan="4">
  63. <TextBlock Text="纯色背景" VerticalAlignment="Center"/>
  64. </hc:UniformSpacingPanel>
  65. <hc:UniformSpacingPanel Spacing="10" Margin="20,0,0,0" Grid.ColumnSpan="4">
  66. <TextBlock Text="色彩1:" VerticalAlignment="Center" Margin="0,5,0,0"/>
  67. <TextBlock Text="{Binding GradientBGParam.Color1, NotifyOnTargetUpdated=True}"
  68. TargetUpdated="Color_TargetUpdated"
  69. Width="65"
  70. Margin="0,5,0,0"
  71. VerticalAlignment="Center"
  72. />
  73. <Button Style="{StaticResource MyBtnStyle}"
  74. Content="设置"
  75. Tag="Color1"
  76. Click="ColorButton_Click"/>
  77. </hc:UniformSpacingPanel>
  78. <hc:UniformSpacingPanel Spacing="10" Margin="20,5,0,0" Grid.ColumnSpan="4">
  79. <TextBlock Text="色彩2:" VerticalAlignment="Center" Margin="0,5,0,0"/>
  80. <TextBlock Text="{Binding GradientBGParam.Color2, NotifyOnTargetUpdated=True}"
  81. TargetUpdated="Color_TargetUpdated"
  82. Width="65"
  83. Margin="0,5,0,0"
  84. VerticalAlignment="Center"
  85. />
  86. <Button Style="{StaticResource MyBtnStyle}"
  87. Content="设置" Tag="Color2"
  88. Click="ColorButton_Click"
  89. />
  90. </hc:UniformSpacingPanel>
  91. <Button Content="系统预设"
  92. Style="{StaticResource MyBtnStyle}"
  93. Margin="0,5,0,0"
  94. hc:Poptip.HitMode="None"
  95. hc:Poptip.IsOpen="{Binding IsMouseOver, RelativeSource={RelativeSource Self}}"
  96. hc:Poptip.Content="{Binding GradientBGParam.Name, Converter={StaticResource StringAppendConvert}, ConverterParameter=当前设置: \{\}}"
  97. hc:Poptip.Placement="Top"
  98. Click="SysBG_Click"
  99. />
  100. </StackPanel>
  101. </hc:TransitioningContentControl>
  102. </UniformGrid>
  103. <hc:Divider LineStrokeDashArray="3,3" Margin="0,0,0,0" Height="20" LineStroke="Black" Grid.ColumnSpan="1"/>
  104. <hc:UniformSpacingPanel Spacing="10" Margin="5,-10,0,0" Grid.ColumnSpan="4">
  105. <CheckBox Style="{StaticResource MyCheckBoxStyle}" Content="置于顶层" IsChecked="{Binding AlwaysTopmost}"/>
  106. </hc:UniformSpacingPanel>
  107. <hc:UniformSpacingPanel Spacing="10" Margin="5,10,0,0" Grid.ColumnSpan="4">
  108. <CheckBox Style="{StaticResource MyCheckBoxStyle}" Content="主窗口动画" IsChecked="{Binding AppAnimation}" Click="Animation_Checked"/>
  109. </hc:UniformSpacingPanel>
  110. <hc:UniformSpacingPanel Spacing="10" Margin="5,10,0,0" Grid.ColumnSpan="4">
  111. <CheckBox Style="{StaticResource MyCheckBoxStyle}" Content="列表展开动画" IsChecked="{Binding ItemSpradeAnimation}"/>
  112. </hc:UniformSpacingPanel>
  113. <hc:UniformSpacingPanel Spacing="10" Margin="5,10,0,0" Grid.ColumnSpan="4">
  114. <CheckBox Style="{StaticResource MyCheckBoxStyle}" x:Name="BarIcon" Content="显示托盘图标" IsChecked="{Binding ShowBarIcon}"/>
  115. </hc:UniformSpacingPanel>
  116. <hc:UniformSpacingPanel Spacing="10" Margin="5,10,0,0" Grid.ColumnSpan="4">
  117. <CheckBox Style="{StaticResource MyCheckBoxStyle}" Content="显示主面板Logo" IsChecked="{Binding TitleLogoVisible, Mode=TwoWay, Converter={StaticResource Visibility2BooleanConverter}}"/>
  118. </hc:UniformSpacingPanel>
  119. <StackPanel Margin="0,15,0,0">
  120. <hc:UniformSpacingPanel Spacing="10" Grid.ColumnSpan="4">
  121. <TextBlock Text="卡片不透明度" VerticalAlignment="Center"/>
  122. </hc:UniformSpacingPanel>
  123. <hc:UniformSpacingPanel Spacing="10" Margin="10,5,0,0" Grid.ColumnSpan="4">
  124. <hc:PreviewSlider Value="{Binding CardOpacity}"
  125. Maximum="100"
  126. Width="350"
  127. >
  128. <hc:PreviewSlider.PreviewContent>
  129. <Label Style="{StaticResource LabelPrimary}" Content="{Binding Path=(hc:PreviewSlider.PreviewPosition),RelativeSource={RelativeSource Self}}" ContentStringFormat="#0"/>
  130. </hc:PreviewSlider.PreviewContent>
  131. </hc:PreviewSlider>
  132. </hc:UniformSpacingPanel>
  133. <hc:UniformSpacingPanel Spacing="10" Margin="0,10,0,0" Grid.ColumnSpan="4">
  134. <TextBlock Text="背景不透明度" VerticalAlignment="Center"/>
  135. </hc:UniformSpacingPanel>
  136. <hc:UniformSpacingPanel Spacing="10" Margin="10,5,0,0" Grid.ColumnSpan="4">
  137. <hc:PreviewSlider Value="{Binding BgOpacity}"
  138. ValueChanged="BGOpacity_ValueChanged"
  139. Maximum="100"
  140. Width="350"
  141. >
  142. <hc:PreviewSlider.PreviewContent>
  143. <Label Style="{StaticResource LabelPrimary}" Content="{Binding Path=(hc:PreviewSlider.PreviewPosition),RelativeSource={RelativeSource Self}}" ContentStringFormat="#0"/>
  144. </hc:PreviewSlider.PreviewContent>
  145. </hc:PreviewSlider>
  146. </hc:UniformSpacingPanel>
  147. <!--<hc:UniformSpacingPanel Spacing="10" Margin="0,10,0,0" Grid.ColumnSpan="4">
  148. <TextBlock Text="主面板不透明度" VerticalAlignment="Center"/>
  149. </hc:UniformSpacingPanel>
  150. <hc:UniformSpacingPanel Spacing="10" Margin="10,5,0,0" Grid.ColumnSpan="4">
  151. <hc:PreviewSlider Value="{Binding PannelOpacity}"
  152. Minimum="50"
  153. Maximum="100"
  154. Width="350"
  155. >
  156. <hc:PreviewSlider.PreviewContent>
  157. <Label Style="{StaticResource LabelPrimary}" Content="{Binding Path=(hc:PreviewSlider.PreviewPosition),RelativeSource={RelativeSource Self}}" ContentStringFormat="#0"/>
  158. </hc:PreviewSlider.PreviewContent>
  159. </hc:PreviewSlider>
  160. </hc:UniformSpacingPanel>-->
  161. <hc:UniformSpacingPanel Spacing="10" Margin="0,10,0,0" Grid.ColumnSpan="4">
  162. <TextBlock Text="主面板圆角大小" VerticalAlignment="Center"/>
  163. </hc:UniformSpacingPanel>
  164. <hc:UniformSpacingPanel Spacing="10" Margin="10,5,0,0" Grid.ColumnSpan="4">
  165. <hc:PreviewSlider Value="{Binding PannelCornerRadius}"
  166. Maximum="25"
  167. Width="350"
  168. >
  169. <hc:PreviewSlider.PreviewContent>
  170. <Label Style="{StaticResource LabelPrimary}" Content="{Binding Path=(hc:PreviewSlider.PreviewPosition),RelativeSource={RelativeSource Self}}" ContentStringFormat="#0"/>
  171. </hc:PreviewSlider.PreviewContent>
  172. </hc:PreviewSlider>
  173. </hc:UniformSpacingPanel>
  174. <hc:UniformSpacingPanel Spacing="10" Margin="0,10,0,0" Grid.ColumnSpan="4">
  175. <TextBlock Text="图标大小" VerticalAlignment="Center"/>
  176. </hc:UniformSpacingPanel>
  177. <hc:UniformSpacingPanel Spacing="10" Margin="10,5,0,0" Grid.ColumnSpan="4"
  178. Background="#00FFFFFF"
  179. PreviewMouseLeftButtonDown="PreviewSlider_MouseLeftButtonUp"
  180. >
  181. <hc:PreviewSlider Value="{Binding ImageWidth, Mode=TwoWay}"
  182. Minimum="40"
  183. Maximum="60"
  184. Width="350"
  185. >
  186. <hc:PreviewSlider.PreviewContent>
  187. <Label Style="{StaticResource LabelPrimary}" Content="{Binding Path=(hc:PreviewSlider.PreviewPosition),RelativeSource={RelativeSource Self}}" ContentStringFormat="#0"/>
  188. </hc:PreviewSlider.PreviewContent>
  189. </hc:PreviewSlider>
  190. </hc:UniformSpacingPanel>
  191. </StackPanel>
  192. <hc:Divider LineStrokeDashArray="3,3" LineStroke="Black" Grid.ColumnSpan="4"/>
  193. <hc:UniformSpacingPanel Spacing="10" Grid.ColumnSpan="4">
  194. <TextBlock VerticalAlignment="Center" Text="图标字体颜色:" />
  195. <TextBlock VerticalAlignment="Center" Text="{Binding TextColor}" Foreground="{Binding TextColor}" Width="100"/>
  196. <Button Style="{StaticResource MyBtnStyle}" Content="选择" Margin="0,-10,0,0" Tag="Text" Click="ColorButton_Click"/>
  197. </hc:UniformSpacingPanel>
  198. </StackPanel>
  199. </Grid>
  200. <!--<StackPanel x:Name="ColorPanel" Panel.ZIndex="1"
  201. Visibility="Collapsed"
  202. Height="500"
  203. Width="450"
  204. VerticalAlignment="Center">
  205. <StackPanel.Background>
  206. <SolidColorBrush Color="AliceBlue" Opacity="0.01"/>
  207. </StackPanel.Background>-->
  208. <!--<hc:ColorPicker Name="MyColorPicker"
  209. Canceled="MyColorPicker_Canceled"
  210. Confirmed="MyColorPicker_Confirmed"
  211. SelectedColorChanged="MyColorPicker_SelectedColorChanged"/>-->
  212. <!--</StackPanel>-->
  213. </Grid>
  214. </UserControl>