MenuBaseStyle.xaml 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. <ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  2. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  3. xmlns:hc="clr-namespace:HandyControl.Controls">
  4. <Style x:Key="MenuItemBaseStyle" TargetType="MenuItem">
  5. <Setter Property="Padding" Value="{Binding Path=(hc:MenuAttach.ItemPadding),RelativeSource={RelativeSource AncestorType=MenuBase}}"/>
  6. <Setter Property="OverridesDefaultStyle" Value="True" />
  7. <Setter Property="Background" Value="Transparent"/>
  8. <Setter Property="BorderThickness" Value="0"/>
  9. <Setter Property="hc:ScrollViewer.PanningMode" Value="Both"/>
  10. <Setter Property="Stylus.IsFlicksEnabled" Value="False"/>
  11. <Setter Property="Foreground" Value="{DynamicResource PrimaryTextBrush}"/>
  12. <Setter Property="Margin" Value="0,0,0,2" />
  13. <Setter Property="hc:BorderElement.CornerRadius" Value="{StaticResource DefaultCornerRadius}" />
  14. <Setter Property="Template">
  15. <Setter.Value>
  16. <ControlTemplate TargetType="MenuItem">
  17. <Border x:Name="Bd" CornerRadius="{Binding Path=(hc:BorderElement.CornerRadius),RelativeSource={RelativeSource TemplatedParent}}" MinWidth="240" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{TemplateBinding Background}" SnapsToDevicePixels="True">
  18. <Grid x:Name="Grid" Margin="{TemplateBinding Padding}">
  19. <Grid.ColumnDefinitions>
  20. <ColumnDefinition Width="26"/>
  21. <ColumnDefinition Width="*"/>
  22. <ColumnDefinition Width="30"/>
  23. <ColumnDefinition SharedSizeGroup="MenuItemIGTColumnGroup" Width="Auto"/>
  24. <ColumnDefinition Width="20"/>
  25. </Grid.ColumnDefinitions>
  26. <ContentPresenter Margin="0,0,10,0" x:Name="Icon" ContentSource="Icon" HorizontalAlignment="Right" Height="16" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" VerticalAlignment="Center" Width="16"/>
  27. <Border Margin="0,0,10,0" IsHitTestVisible="False" Grid.Column="0" x:Name="GlyphPanel" CornerRadius="2" Background="{DynamicResource PrimaryBrush}" ClipToBounds="False" HorizontalAlignment="Right" Height="16" Visibility="Hidden" VerticalAlignment="Center" Width="16">
  28. <Path UseLayoutRounding="True" Width="12" Height="12" Data="{StaticResource CheckedGeometry}" StrokeThickness="2" Stretch="Uniform" Stroke="{DynamicResource TextIconBrush}"/>
  29. </Border>
  30. <ContentPresenter Grid.Column="1" x:Name="ContentPresenter" ContentStringFormat="{TemplateBinding HeaderStringFormat}" ContentTemplate="{TemplateBinding HeaderTemplate}" ContentSource="Header" Margin="0,3" RecognizesAccessKey="True" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}"/>
  31. <TextBlock x:Name="InputGestureText" Margin="0,0,10,0" Grid.Column="3" VerticalAlignment="Center" HorizontalAlignment="Left" Text="{TemplateBinding InputGestureText}"/>
  32. </Grid>
  33. </Border>
  34. <ControlTemplate.Triggers>
  35. <Trigger Property="IsChecked" Value="True">
  36. <Setter Property="Visibility" TargetName="GlyphPanel" Value="Visible"/>
  37. </Trigger>
  38. <Trigger Property="Icon" Value="{x:Null}">
  39. <Setter Property="Visibility" TargetName="Icon" Value="Collapsed"/>
  40. </Trigger>
  41. </ControlTemplate.Triggers>
  42. </ControlTemplate>
  43. </Setter.Value>
  44. </Setter>
  45. <Style.Triggers>
  46. <Trigger Property="Role" Value="TopLevelHeader">
  47. <Setter Property="Margin" Value="0"/>
  48. <Setter Property="Template">
  49. <Setter.Value>
  50. <ControlTemplate TargetType="MenuItem">
  51. <Border MinWidth="44" x:Name="templateRoot" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="1,1,1,0" Background="{TemplateBinding Background}" SnapsToDevicePixels="True">
  52. <Grid VerticalAlignment="Center" Margin="{TemplateBinding Padding}">
  53. <Grid.ColumnDefinitions>
  54. <ColumnDefinition Width="Auto"/>
  55. <ColumnDefinition Width="Auto"/>
  56. </Grid.ColumnDefinitions>
  57. <ContentPresenter Margin="0,0,10,0" x:Name="Icon" ContentSource="Icon" HorizontalAlignment="Right" Height="16" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" VerticalAlignment="Center" Width="16"/>
  58. <Border Margin="0,0,10,0" Grid.Column="0" x:Name="GlyphPanel" CornerRadius="2" Background="{DynamicResource PrimaryBrush}" ClipToBounds="False" HorizontalAlignment="Right" Height="16" Visibility="Collapsed" VerticalAlignment="Center" Width="16">
  59. <Path UseLayoutRounding="True" Width="12" Height="12" Data="{StaticResource CheckedGeometry}" StrokeThickness="2" Stretch="Uniform" Stroke="{DynamicResource TextIconBrush}"/>
  60. </Border>
  61. <ContentPresenter x:Name="menuHeaderContainer" ContentTemplate="{TemplateBinding HeaderTemplate}" Grid.Column="1" ContentStringFormat="{TemplateBinding HeaderStringFormat}" ContentSource="Header" RecognizesAccessKey="True" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}"/>
  62. <Popup Grid.Column="0" x:Name="PART_Popup" PlacementTarget="{Binding ElementName=templateRoot}" AllowsTransparency="True" Focusable="False" IsOpen="{Binding IsSubmenuOpen, RelativeSource={RelativeSource TemplatedParent}}" Placement="Bottom">
  63. <hc:SimplePanel Effect="{StaticResource EffectShadow2}" Margin="8,0,8,8">
  64. <Border CornerRadius="{Binding Path=(hc:BorderElement.CornerRadius),RelativeSource={RelativeSource TemplatedParent},Converter={StaticResource CornerRadiusSplitConverter},ConverterParameter='0,0,1,1'}" x:Name="SubMenuBorder" BorderThickness="1" BorderBrush="{DynamicResource BorderBrush}" Background="{DynamicResource RegionBrush}">
  65. <ScrollViewer Style="{StaticResource ScrollViewerUpDown}" Margin="2,2,2,0">
  66. <ItemsPresenter x:Name="ItemsPresenter" KeyboardNavigation.DirectionalNavigation="Cycle" Grid.IsSharedSizeScope="True" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" KeyboardNavigation.TabNavigation="Cycle"/>
  67. </ScrollViewer>
  68. </Border>
  69. <Border hc:MenuTopLineAttach.Popup="{Binding ElementName=PART_Popup}" Height="1" Background="{DynamicResource RegionBrush}" VerticalAlignment="Top" BorderThickness="1,0" BorderBrush="{DynamicResource BorderBrush}" HorizontalAlignment="Left"/>
  70. </hc:SimplePanel>
  71. </Popup>
  72. </Grid>
  73. </Border>
  74. <ControlTemplate.Triggers>
  75. <Trigger Property="Icon" Value="{x:Null}">
  76. <Setter Property="Visibility" TargetName="Icon" Value="Collapsed"/>
  77. </Trigger>
  78. <Trigger Property="IsChecked" Value="True">
  79. <Setter Property="Visibility" TargetName="GlyphPanel" Value="Visible"/>
  80. <Setter Property="Visibility" TargetName="Icon" Value="Collapsed"/>
  81. </Trigger>
  82. <Trigger Property="IsHighlighted" Value="True">
  83. <Setter Property="Background" TargetName="templateRoot" Value="{DynamicResource SecondaryRegionBrush}"/>
  84. <Setter Property="TextElement.Foreground" TargetName="menuHeaderContainer" Value="{DynamicResource PrimaryTextBrush}"/>
  85. </Trigger>
  86. <Trigger Property="IsSubmenuOpen" Value="True">
  87. <Setter Property="BorderBrush" TargetName="templateRoot" Value="{DynamicResource BorderBrush}"/>
  88. <Setter Property="Background" TargetName="templateRoot" Value="{DynamicResource RegionBrush}"/>
  89. <Setter Property="TextElement.Foreground" TargetName="menuHeaderContainer" Value="{DynamicResource PrimaryTextBrush}"/>
  90. </Trigger>
  91. </ControlTemplate.Triggers>
  92. </ControlTemplate>
  93. </Setter.Value>
  94. </Setter>
  95. </Trigger>
  96. <Trigger Property="Role" Value="TopLevelItem">
  97. <Setter Property="Margin" Value="0"/>
  98. <Setter Property="Template">
  99. <Setter.Value>
  100. <ControlTemplate TargetType="MenuItem">
  101. <Border x:Name="templateRoot" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="1,1,1,0" Background="{TemplateBinding Background}" SnapsToDevicePixels="True">
  102. <Grid Margin="{TemplateBinding Padding}">
  103. <Grid.ColumnDefinitions>
  104. <ColumnDefinition Width="Auto"/>
  105. <ColumnDefinition/>
  106. </Grid.ColumnDefinitions>
  107. <ContentPresenter Margin="0,0,10,0" x:Name="Icon" HorizontalAlignment="Left" ContentSource="Icon" Height="16" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" VerticalAlignment="Center" Width="16"/>
  108. <Border Margin="0,0,10,0" IsHitTestVisible="False" Grid.Column="0" x:Name="GlyphPanel" CornerRadius="2" Background="{DynamicResource PrimaryBrush}" ClipToBounds="False" HorizontalAlignment="Right" Height="16" Visibility="Collapsed" VerticalAlignment="Center" Width="16">
  109. <Path UseLayoutRounding="True" Width="12" Height="12" Data="{StaticResource CheckedGeometry}" StrokeThickness="2" Stretch="Uniform" Stroke="{DynamicResource TextIconBrush}"/>
  110. </Border>
  111. <ContentPresenter x:Name="menuHeaderContainer" ContentTemplate="{TemplateBinding HeaderTemplate}" Grid.Column="1" ContentStringFormat="{TemplateBinding HeaderStringFormat}" ContentSource="Header" HorizontalAlignment="Left" RecognizesAccessKey="True" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" VerticalAlignment="Center"/>
  112. </Grid>
  113. </Border>
  114. <ControlTemplate.Triggers>
  115. <Trigger Property="Icon" Value="{x:Null}">
  116. <Setter Property="Visibility" TargetName="Icon" Value="Collapsed"/>
  117. </Trigger>
  118. <Trigger Property="IsChecked" Value="True">
  119. <Setter Property="Visibility" TargetName="GlyphPanel" Value="Visible"/>
  120. <Setter Property="Visibility" TargetName="Icon" Value="Collapsed"/>
  121. </Trigger>
  122. <Trigger Property="IsHighlighted" Value="True">
  123. <Setter Property="Background" TargetName="templateRoot" Value="{DynamicResource SecondaryRegionBrush}"/>
  124. <Setter Property="TextElement.Foreground" TargetName="menuHeaderContainer" Value="{DynamicResource PrimaryTextBrush}"/>
  125. </Trigger>
  126. <Trigger Property="IsSubmenuOpen" Value="True">
  127. <Setter Property="Background" TargetName="templateRoot" Value="White"/>
  128. <Setter Property="TextElement.Foreground" TargetName="menuHeaderContainer" Value="{DynamicResource PrimaryTextBrush}"/>
  129. </Trigger>
  130. <MultiTrigger>
  131. <MultiTrigger.Conditions>
  132. <Condition Property="IsHighlighted" Value="True"/>
  133. <Condition Property="IsEnabled" Value="False"/>
  134. </MultiTrigger.Conditions>
  135. <Setter Property="Background" TargetName="templateRoot" Value="#0A000000"/>
  136. <Setter Property="BorderBrush" TargetName="templateRoot" Value="#21000000"/>
  137. </MultiTrigger>
  138. </ControlTemplate.Triggers>
  139. </ControlTemplate>
  140. </Setter.Value>
  141. </Setter>
  142. </Trigger>
  143. <Trigger Property="Role" Value="SubmenuHeader">
  144. <Setter Property="DockPanel.Dock" Value="Top"/>
  145. <Setter Property="Foreground" Value="{DynamicResource PrimaryTextBrush}"/>
  146. <Setter Property="Template">
  147. <Setter.Value>
  148. <ControlTemplate TargetType="MenuItem">
  149. <Border x:Name="Bd" CornerRadius="{Binding Path=(hc:BorderElement.CornerRadius),RelativeSource={RelativeSource TemplatedParent}}" MinWidth="240" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{TemplateBinding Background}" SnapsToDevicePixels="True">
  150. <Grid x:Name="Grid" Margin="{TemplateBinding Padding}">
  151. <Grid.ColumnDefinitions>
  152. <ColumnDefinition Width="26"/>
  153. <ColumnDefinition Width="*"/>
  154. <ColumnDefinition Width="30"/>
  155. <ColumnDefinition SharedSizeGroup="MenuItemIGTColumnGroup" Width="Auto"/>
  156. <ColumnDefinition Width="20"/>
  157. </Grid.ColumnDefinitions>
  158. <ContentPresenter Margin="0,0,10,0" x:Name="Icon" ContentSource="Icon" HorizontalAlignment="Right" Height="16" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" VerticalAlignment="Center" Width="16"/>
  159. <Border Margin="0,0,10,0" IsHitTestVisible="False" Grid.Column="0" x:Name="GlyphPanel" CornerRadius="2" Background="{DynamicResource PrimaryBrush}" ClipToBounds="False" HorizontalAlignment="Right" Height="16" Visibility="Hidden" VerticalAlignment="Center" Width="16">
  160. <Path UseLayoutRounding="True" Width="12" Height="12" Data="{StaticResource CheckedGeometry}" StrokeThickness="2" Stretch="Uniform" Stroke="{DynamicResource TextIconBrush}"/>
  161. </Border>
  162. <ContentPresenter TextElement.Foreground="{TemplateBinding Foreground}" Margin="0,3" x:Name="ContentPresenter" ContentStringFormat="{TemplateBinding HeaderStringFormat}" ContentTemplate="{TemplateBinding HeaderTemplate}" Grid.Column="1" ContentSource="Header" RecognizesAccessKey="True" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}"/>
  163. <Path x:Name="Path" Grid.Column="4" Width="10" Height="10" HorizontalAlignment="Left" Data="{StaticResource RightGeometry}" Stretch="Uniform" Fill="{TemplateBinding Foreground}" VerticalAlignment="Center"/>
  164. <Popup Grid.Column="1" x:Name="PART_Popup" AllowsTransparency="True" Focusable="False" IsOpen="{Binding IsSubmenuOpen, RelativeSource={RelativeSource TemplatedParent}}" Placement="Right" VerticalOffset="{Binding Path=(hc:MenuAttach.PopupVerticalOffset),RelativeSource={RelativeSource AncestorType=MenuBase}}" HorizontalOffset="{Binding Path=(hc:MenuAttach.PopupHorizontalOffset),RelativeSource={RelativeSource AncestorType=MenuBase}}">
  165. <Border Effect="{StaticResource EffectShadow2}" Margin="8" CornerRadius="{Binding Path=(hc:BorderElement.CornerRadius),RelativeSource={RelativeSource TemplatedParent}}" x:Name="SubMenuBorder" BorderThickness="1" BorderBrush="{DynamicResource BorderBrush}" Background="{DynamicResource RegionBrush}">
  166. <ScrollViewer Style="{StaticResource ScrollViewerUpDown}" Margin="2,2,2,0">
  167. <ItemsPresenter x:Name="ItemsPresenter" KeyboardNavigation.DirectionalNavigation="Cycle" Grid.IsSharedSizeScope="True" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" KeyboardNavigation.TabNavigation="Cycle"/>
  168. </ScrollViewer>
  169. </Border>
  170. </Popup>
  171. </Grid>
  172. </Border>
  173. <ControlTemplate.Triggers>
  174. <Trigger Property="IsChecked" Value="True">
  175. <Setter Property="Visibility" TargetName="GlyphPanel" Value="Visible"/>
  176. </Trigger>
  177. </ControlTemplate.Triggers>
  178. </ControlTemplate>
  179. </Setter.Value>
  180. </Setter>
  181. </Trigger>
  182. <Trigger Property="IsHighlighted" Value="True">
  183. <Setter Property="Background" Value="{DynamicResource SecondaryRegionBrush}"/>
  184. </Trigger>
  185. <Trigger Property="IsEnabled" Value="False">
  186. <Setter Property="Opacity" Value=".4"/>
  187. </Trigger>
  188. </Style.Triggers>
  189. </Style>
  190. <Style x:Key="MenuBaseStyle" TargetType="Menu">
  191. <Setter Property="hc:MenuAttach.ItemPadding" Value="{StaticResource DefaultControlPadding}" />
  192. <Setter Property="hc:MenuAttach.PopupVerticalOffset" Value="-9" />
  193. <Setter Property="hc:MenuAttach.PopupHorizontalOffset" Value="10" />
  194. <Setter Property="OverridesDefaultStyle" Value="True" />
  195. <Setter Property="Background" Value="{DynamicResource RegionBrush}"/>
  196. <Setter Property="Foreground" Value="{DynamicResource PrimaryTextBrush}"/>
  197. <Setter Property="VerticalContentAlignment" Value="Center"/>
  198. <Setter Property="hc:BorderElement.CornerRadius" Value="{StaticResource DefaultCornerRadius}" />
  199. <Setter Property="Template">
  200. <Setter.Value>
  201. <ControlTemplate TargetType="Menu">
  202. <Border BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{TemplateBinding Background}" Padding="{TemplateBinding Padding}" SnapsToDevicePixels="true">
  203. <ItemsPresenter SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}"/>
  204. </Border>
  205. </ControlTemplate>
  206. </Setter.Value>
  207. </Setter>
  208. </Style>
  209. </ResourceDictionary>