RightCardControl.xaml 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. <UserControl x:Class="GeekDesk.Control.UserControls.PannelCard.RightCardControl"
  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:DraggAnimatedPanel="clr-namespace:DraggAnimatedPanel"
  10. mc:Ignorable="d"
  11. d:DesignHeight="450" d:DesignWidth="800">
  12. <UserControl.Resources>
  13. <!--右侧栏样式动画-->
  14. <Style x:Key="imageStyle" TargetType="Image">
  15. <Setter Property="Width" Value="{Binding ImageWidth}"/>
  16. <Setter Property="Height" Value="{Binding ImageHeight}"/>
  17. <Setter Property="Source" Value="{Binding BitmapImage}"/>
  18. <Style.Triggers>
  19. <MultiTrigger>
  20. <MultiTrigger.Conditions>
  21. <Condition Property="IsMouseOver" Value="True"/>
  22. </MultiTrigger.Conditions>
  23. <MultiTrigger.EnterActions>
  24. <BeginStoryboard>
  25. <Storyboard>
  26. <DoubleAnimation To="80" Duration="0:0:0.001" Storyboard.TargetProperty="Width"/>
  27. <DoubleAnimation To="80" Duration="0:0:0.001" Storyboard.TargetProperty="Height"/>
  28. </Storyboard>
  29. </BeginStoryboard>
  30. </MultiTrigger.EnterActions>
  31. <MultiTrigger.ExitActions>
  32. <BeginStoryboard>
  33. <Storyboard>
  34. <DoubleAnimation To="60" Duration="0:0:0.5" Storyboard.TargetProperty="Width"/>
  35. <DoubleAnimation To="60" Duration="0:0:0.5" Storyboard.TargetProperty="Height"/>
  36. </Storyboard>
  37. </BeginStoryboard>
  38. </MultiTrigger.ExitActions>
  39. </MultiTrigger>
  40. </Style.Triggers>
  41. </Style>
  42. <cvt:MenuWidthConvert x:Key="MenuWidthConvert"/>
  43. <cvt:OpcityConvert x:Key="OpcityConvert"/>
  44. </UserControl.Resources>
  45. <!--右侧栏-->
  46. <hc:Card AllowDrop="True"
  47. Drop="Wrap_Drop"
  48. BorderThickness="1"
  49. Effect="{DynamicResource EffectShadow2}"
  50. Margin="5,0,5,5" Grid.ColumnSpan="2">
  51. <hc:Card.Background>
  52. <SolidColorBrush Color="#FFFFFFFF" Opacity="{Binding AppConfig.CardOpacity, Mode=TwoWay, Converter={StaticResource OpcityConvert}}"/>
  53. </hc:Card.Background>
  54. <hc:Card.BorderBrush>
  55. <SolidColorBrush Color="#FFFFFFFF" Opacity="0"/>
  56. </hc:Card.BorderBrush>
  57. <WrapPanel Orientation="Horizontal">
  58. <ListBox x:Name="icons" ItemsSource="{Binding AppConfig.SelectedMenuIcons, Mode=TwoWay}"
  59. BorderThickness="0"
  60. SelectionChanged="IconSelectionChanged "
  61. VirtualizingPanel.VirtualizationMode="Recycling"
  62. >
  63. <ListBox.Background>
  64. <SolidColorBrush Opacity="0"/>
  65. </ListBox.Background>
  66. <ListBox.ItemsPanel>
  67. <ItemsPanelTemplate>
  68. <DraggAnimatedPanel:DraggAnimatedPanel ItemsHeight="115" ItemsWidth="100" HorizontalAlignment="Center" SwapCommand="{Binding SwapCommand, RelativeSource={RelativeSource AncestorType={x:Type UserControl}}}"/>
  69. </ItemsPanelTemplate>
  70. </ListBox.ItemsPanel>
  71. <ListBox.Resources>
  72. <ContextMenu x:Key="iconDialog" Width="200">
  73. <MenuItem Header="管理员方式运行" Click="IconAdminStart" Tag="{Binding}"/>
  74. <MenuItem Header="打开文件所在位置" Click="ShowInExplore" Tag="{Binding}"/>
  75. <MenuItem Header="资源管理器菜单" Click="MenuItem_Click" Tag="{Binding}"/>
  76. <MenuItem Header="属性" Click="PropertyConfig" Tag="{Binding}"/>
  77. <MenuItem Header="从列表移除" Click="RemoveIcon" Tag="{Binding}"/>
  78. </ContextMenu>
  79. </ListBox.Resources>
  80. <ListBox.ItemContainerStyle>
  81. <Style TargetType="ListBoxItem">
  82. <Setter Property="ContextMenu" Value="{StaticResource iconDialog}"/>
  83. </Style>
  84. </ListBox.ItemContainerStyle>
  85. <ListBox.ItemTemplate>
  86. <DataTemplate>
  87. <StackPanel Tag="{Binding}"
  88. MouseLeftButtonUp="IconClick"
  89. HorizontalAlignment="Center"
  90. Margin="5,5,5,5"
  91. hc:Poptip.HitMode="None"
  92. hc:Poptip.IsOpen="{Binding IsMouseOver, RelativeSource={RelativeSource Self}}"
  93. hc:Poptip.Content="{Binding Content}"
  94. hc:Poptip.Placement="BottomLeft"
  95. >
  96. <Image Style="{StaticResource imageStyle}" />
  97. <TextBlock MaxWidth="80"
  98. MaxHeight="40"
  99. TextWrapping="Wrap"
  100. TextTrimming="WordEllipsis"
  101. TextAlignment="Center"
  102. VerticalAlignment="Center"
  103. Text="{Binding Name}"/>
  104. </StackPanel>
  105. </DataTemplate>
  106. </ListBox.ItemTemplate>
  107. </ListBox>
  108. </WrapPanel>
  109. </hc:Card>
  110. </UserControl>