gpt4 book ai didi

WPF滑动面板

转载 作者:行者123 更新时间:2023-12-02 03:17:42 24 4
gpt4 key购买 nike

我想制作一个行为类似于混合菜单控件的控件:

enter image description here

如图所示,单击资源,菜单将滑出,窗口另一侧的菜单将缩小,并为新的滑动菜单留出空间。菜单应该驻留在那里,直到执行任何操作将其滑回。(就像我将按钮放在图像中的取消按钮(x)相同的位置)。

也不应该像另一个地方的停靠面板一样,就像我们在 Blend 上使用 VS 的 Toolbox 所做的那样。

我怎样才能实现这个目标?

最佳答案

我创建了一个窗口来向您展示如何实现您的目标。它在窗口的右上方有 2 个按钮,如果单击每个按钮,就会展开红色或黑色边框。

<Window x:Class="WpfApplicationUpper.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:my="clr-namespace:WpfApplicationUpper" Height="100" Width="200">

<Window.Resources>
<ControlTemplate x:Key="VerticalExpander" TargetType="{x:Type Expander}">
<Border Name="ContentBorder"
Width="0">
<ContentPresenter />
</Border>
<ControlTemplate.Triggers>
<Trigger Property="IsExpanded"
Value="True">
<Setter TargetName="ContentBorder"
Property="Width"
Value="Auto" />
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Window.Resources>
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*" />
<ColumnDefinition Width="20" />
</Grid.ColumnDefinitions>
<StackPanel Grid.Column="1" Orientation="Vertical">
<Button Name="B1" Content="T" Click="B1_Click"/>
<Button Name="B2"
Content="F" Click="B2_Click"/>
</StackPanel>
<DockPanel LastChildFill="True">
<Grid DockPanel.Dock="Right">
<Expander Name="MainExpander1"
Template="{StaticResource VerticalExpander}"
IsExpanded="False">
<Border Background="Black"
Width="50">
</Border>
</Expander>
<Expander Name="MainExpander2"
Template="{StaticResource VerticalExpander}"
IsExpanded="False"
DockPanel.Dock="Right">
<Border Background="Red"
Width="50">
</Border>
</Expander>
</Grid>
<Border Name="NonSliding"
Width="100"
Height="50"
Background="Green">

</Border>
</DockPanel>
</Grid>
</Window>

并在后面的代码中:

    private void B1_Click(object sender, RoutedEventArgs e)
{
MainExpander1.IsExpanded = !MainExpander1.IsExpanded;
}

private void B2_Click(object sender, RoutedEventArgs e)
{
MainExpander2.IsExpanded = !MainExpander2.IsExpanded;
}

关于WPF滑动面板,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13989655/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com