LeftCardControl.xaml 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. <UserControl x:Class="GeekDesk.Control.UserControls.PannelCard.LeftCardControl"
  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:d="http://schemas.microsoft.com/expression/blend/2008"
  6. xmlns:local="clr-namespace:GeekDesk.Control.UserControls.PannelCard"
  7. xmlns:hc="https://handyorg.github.io/handycontrol"
  8. xmlns:cvt="clr-namespace:GeekDesk.Converts"
  9. xmlns:cst="clr-namespace:GeekDesk.Constant"
  10. xmlns:DraggAnimatedPanel="clr-namespace:DraggAnimatedPanel"
  11. mc:Ignorable="d"
  12. d:DesignHeight="450" d:DesignWidth="800"
  13. >
  14. <UserControl.Resources>
  15. <!--左侧栏样式动画-->
  16. <Style x:Key="MenuStyle" TargetType="ListBoxItem" BasedOn="{StaticResource ListBoxItemBaseStyle}">
  17. <Setter Property="FontSize" Value="16"/>
  18. <Setter Property="Margin" Value="0,0,0,1"/>
  19. <Setter Property="Background">
  20. <Setter.Value>
  21. <SolidColorBrush Color="Black" Opacity="0.01"/>
  22. </Setter.Value>
  23. </Setter>
  24. <Setter Property="AllowDrop" Value="True"/>
  25. <EventSetter Event="Drop" Handler="Menu_Drop"/>
  26. <EventSetter Event="PreviewDragEnter" Handler="Menu_PreviewDragEnter"/>
  27. <EventSetter Event="PreviewDragLeave" Handler="Menu_PreviewDragLeave"/>
  28. <EventSetter Event="MouseLeave" Handler="Menu_MouseLeave"/>
  29. <Setter Property="FocusVisualStyle" Value="{x:Null}" />
  30. <EventSetter Event="MouseEnter" Handler="Menu_MouseEnter"/>
  31. <EventSetter Event="PreviewMouseLeftButtonDown" Handler="ListBoxItem_MouseDown"/>
  32. <!--<EventSetter Event="Unselected" Handler="Lbi_Unselected"/>-->
  33. <Style.Triggers>
  34. <MultiTrigger>
  35. <MultiTrigger.Conditions>
  36. <Condition Property="IsMouseOver" Value="False"/>
  37. <Condition Property="IsSelected" Value="False"/>
  38. </MultiTrigger.Conditions>
  39. <MultiTrigger.EnterActions>
  40. <BeginStoryboard>
  41. <Storyboard Timeline.DesiredFrameRate="60">
  42. <DoubleAnimation To="16" Duration="0:0:0.2" Storyboard.TargetProperty="FontSize"/>
  43. </Storyboard>
  44. </BeginStoryboard>
  45. </MultiTrigger.EnterActions>
  46. <MultiTrigger.ExitActions>
  47. <BeginStoryboard>
  48. <Storyboard Timeline.DesiredFrameRate="60">
  49. <DoubleAnimation To="18" Duration="0:0:0.001" Storyboard.TargetProperty="FontSize"/>
  50. </Storyboard>
  51. </BeginStoryboard>
  52. </MultiTrigger.ExitActions>
  53. <MultiTrigger.Setters>
  54. <Setter Property="Background">
  55. <Setter.Value>
  56. <SolidColorBrush Color="Black" Opacity="0.01"/>
  57. </Setter.Value>
  58. </Setter>
  59. <Setter Property="Foreground" Value="Black"/>
  60. </MultiTrigger.Setters>
  61. </MultiTrigger>
  62. <!--移到代码设置-->
  63. <!--<Trigger Property="IsSelected" Value="False">
  64. <Setter Property="Background" Value="Transparent"/>
  65. <Setter Property="Foreground" Value="Black"/>
  66. </Trigger>
  67. <Trigger Property="IsSelected" Value="True">
  68. <Setter Property="Background" Value="#ECECEC"/>
  69. <Setter Property="Foreground" Value="Black"/>
  70. </Trigger>
  71. <Trigger Property="IsMouseOver" Value="False">
  72. <Setter Property="Background" Value="Transparent"/>
  73. <Setter Property="Foreground" Value="Black"/>
  74. </Trigger>-->
  75. <Trigger Property="IsMouseOver" Value="False">
  76. <Setter Property="Background" Value="#00FFFFFF"/>
  77. <Setter Property="Foreground" Value="Black"/>
  78. </Trigger>
  79. </Style.Triggers>
  80. </Style>
  81. <Style x:Key="MyPoptipStyle" TargetType="Border">
  82. <Setter Property="HorizontalAlignment" Value="Center"/>
  83. <Setter Property="VerticalAlignment" Value="Center"/>
  84. <Setter Property="BorderThickness" Value="1"/>
  85. <Setter Property="Background" Value="White"/>
  86. <Setter Property="BorderBrush" Value="{DynamicResource BorderBrush}"/>
  87. <Setter Property="CornerRadius" Value="{StaticResource DefaultCornerRadius}"/>
  88. <Setter Property="Padding" Value="{StaticResource DefaultControlPadding}"/>
  89. <!--<Setter Property="Template">
  90. <Setter.Value>
  91. <ControlTemplate TargetType="hc:Poptip">
  92. <Border BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{TemplateBinding Background}" CornerRadius="{Binding Path=(hc:BorderElement.CornerRadius),RelativeSource={RelativeSource TemplatedParent}}">
  93. <ContentPresenter Margin="{TemplateBinding Padding}" ContentTemplateSelector="{TemplateBinding ContentTemplateSelector}" ContentStringFormat="{TemplateBinding ContentStringFormat}" ContentTemplate="{TemplateBinding ContentTemplate}"/>
  94. </Border>
  95. </ControlTemplate>
  96. </Setter.Value>
  97. </Setter>-->
  98. </Style>
  99. <cvt:MenuWidthConvert x:Key="MenuWidthConvert"/>
  100. <cvt:OpcityConvert x:Key="OpcityConvert"/>
  101. <cvt:StringAppendConvert x:Key="StringAppendConvert"/>
  102. </UserControl.Resources>
  103. <Grid Background="Transparent">
  104. <Popup Name="MyPoptip" FlowDirection="LeftToRight"
  105. PopupAnimation="None" Placement="Mouse" IsOpen="False"
  106. AllowsTransparency="True"
  107. >
  108. <Grid Background="Transparent">
  109. <Border Style="{StaticResource MyPoptipStyle}">
  110. <TextBlock Name="MyPoptipContent" HorizontalAlignment="Center" VerticalAlignment="Center" TextAlignment="Center" Text="Test" FontSize="14"/>
  111. </Border>
  112. </Grid>
  113. </Popup>
  114. <!--左侧栏-->
  115. <hc:Card x:Name="MyCard"
  116. BorderThickness="1"
  117. Effect="{DynamicResource EffectShadow2}"
  118. Margin="5,0,0,5"
  119. MouseDown="MyCard_MouseDown"
  120. >
  121. <hc:Card.Background>
  122. <SolidColorBrush Color="#FFFFFFFF" hc:GeometryEffect.GeometryEffect="20" Opacity="{Binding AppConfig.CardOpacity, Mode=TwoWay, Converter={StaticResource OpcityConvert}}">
  123. </SolidColorBrush>
  124. </hc:Card.Background>
  125. <hc:Card.BorderBrush>
  126. <SolidColorBrush Color="#FFFFFFFF" Opacity="0"/>
  127. </hc:Card.BorderBrush>
  128. <hc:Card.ContextMenu>
  129. <ContextMenu Width="200">
  130. <MenuItem Header="新建菜单" Click="CreateMenu"/>
  131. </ContextMenu>
  132. </hc:Card.ContextMenu>
  133. <WrapPanel Orientation="Horizontal">
  134. <ListBox x:Name="MenuListBox"
  135. Padding="2,3,0,2"
  136. ItemsSource="{Binding MenuList}"
  137. Tag="{Binding AppConfig.MenuCardWidth}"
  138. BorderThickness="0" Foreground="{x:Null}"
  139. SelectedIndex="{Binding AppConfig.SelectedMenuIndex}"
  140. VirtualizingPanel.VirtualizationMode="Recycling"
  141. SelectionChanged="Menu_SelectionChanged"
  142. PreviewMouseWheel="Menu_MouseWheel"
  143. >
  144. <ListBox.Resources>
  145. <ContextMenu x:Key="MenuDialog" Width="200">
  146. <MenuItem Header="新建菜单" Click="CreateMenu"/>
  147. <MenuItem Header="重命名" Click="RenameMenu" Tag="{Binding}"/>
  148. <MenuItem Header="修改图标" Click="EditMenuGeometry" Tag="{Binding}"/>
  149. <MenuItem Header="删除" Click="DeleteMenu" Tag="{Binding}"/>
  150. </ContextMenu>
  151. </ListBox.Resources>
  152. <ListBox.ItemContainerStyle>
  153. <Style TargetType="ListBoxItem" BasedOn="{StaticResource MenuStyle}">
  154. <Setter Property="ContextMenu" Value="{StaticResource MenuDialog}"/>
  155. </Style>
  156. </ListBox.ItemContainerStyle>
  157. <ListBox.Background>
  158. <SolidColorBrush Color="AliceBlue" Opacity="0"/>
  159. </ListBox.Background>
  160. <ListBox.ItemsPanel>
  161. <ItemsPanelTemplate>
  162. <DraggAnimatedPanel:DraggAnimatedPanel ItemsHeight="33" ItemsWidth="{Binding RelativeSource={RelativeSource FindAncestor,AncestorType={x:Type ListBox},AncestorLevel=1},Path=Tag, Mode=TwoWay, Converter={StaticResource MenuWidthConvert}, ConverterParameter=10}" HorizontalAlignment="Center" VerticalAlignment="Top" SwapCommand="{Binding SwapCommand, RelativeSource={RelativeSource AncestorType={x:Type UserControl}}}"/>
  163. </ItemsPanelTemplate>
  164. </ListBox.ItemsPanel>
  165. <ListBox.ItemTemplate>
  166. <DataTemplate>
  167. <StackPanel Tag="{Binding}"
  168. >
  169. <TextBox Text="{Binding Path=MenuName, Mode=TwoWay}"
  170. HorizontalAlignment="Left"
  171. Width="{Binding RelativeSource={RelativeSource FindAncestor,AncestorType={x:Type ListBox},AncestorLevel=1},Path=Tag, Mode=TwoWay, Converter={StaticResource MenuWidthConvert}, ConverterParameter=35}"
  172. FontSize="16"
  173. Height="28"
  174. VerticalAlignment="Center"
  175. TextAlignment="Left"
  176. LostFocus="LostFocusOrEnterDown"
  177. KeyDown="LostFocusOrEnterDown"
  178. Tag="{Binding}"
  179. Padding="2"
  180. BorderThickness="0"
  181. IsVisibleChanged="MenuEditWhenVisibilityChanged"
  182. Visibility="{Binding MenuEdit}"/>
  183. <StackPanel Orientation="Horizontal"
  184. IsVisibleChanged="MenuWhenVisibilityChanged"
  185. Visibility="{Binding NotMenuEdit}">
  186. <Button Background="Transparent"
  187. BorderThickness="0"
  188. hc:IconElement.Geometry="{Binding MenuGeometry}"
  189. hc:IconElement.Height="18"
  190. hc:IconElement.Width="18"
  191. IsEnabled="False"
  192. Opacity="1"
  193. Foreground="{Binding GeometryColor}"
  194. />
  195. <TextBlock Text="{Binding MenuName}"
  196. HorizontalAlignment="Center"
  197. TextAlignment="Center"
  198. VerticalAlignment="Center"
  199. />
  200. </StackPanel>
  201. </StackPanel>
  202. </DataTemplate>
  203. </ListBox.ItemTemplate>
  204. </ListBox>
  205. </WrapPanel>
  206. </hc:Card>
  207. </Grid>
  208. </UserControl>