- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 WPF 和 C# 开发的新手,我正在制作这个应用程序。我不知道是否有人熟悉 VOIP App Discord,但他们有一个我非常喜欢的特定行为,并想尝试用 WPF 创建类似的风格。
当您在 Discord 上添加服务器时,您单击一个按钮,整个后窗消失,一个新窗口在前台打开,提示您添加服务器。在窗口外单击会导致窗口在背景窗口处关闭以重新聚焦。
无论如何,这是一个GIF以帮助证明这种特定行为(忽略星星,不想泄露个人信息)。
https://i.imgur.com/cn0sFlO.gifv
我对这一切真的很陌生,所以不知道如何模仿这种行为。
最佳答案
这是一个您可以使用和操作的自定义 Flyout 控件,它的工作方式与您正在寻找的一样。
下面将向您展示如何编写和使用与此类似的自定义 Flyout:
<Window.Resources>
<local:FlyoutControl x:Key="CustomFlyout">
<Grid Width="400" Height="200" Background="PeachPuff">
<TextBlock Text="Inside Flyout" VerticalAlignment="Center" HorizontalAlignment="Center"/>
</Grid>
</local:FlyoutControl>
</Window.Resources>
<Grid>
<Button Content="I have a flyout"
Width="120"
Height="40"
local:FlyoutAttach.Flyout="{StaticResource CustomFlyout}"/>
</Grid>
我看到您已经有了答案,但是当我看到这个问题时我就开始构建它了,所以如果您想接受它并按照您希望的方式使用它,那很好;我想我也会分享这个答案,因为我付出了努力。
我建议更进一步,添加一个 AttachableProperty,可用于将 Flyout 附加到控件,就像 UWP 应用程序中的按钮一样。在 AP 中,您可以找到 MainWindow 并将其添加到网格的底部并自动显示;然而,这假设 MainWindow 有一个 Grid 的根面板。编辑:我还添加了一个附加属性以供引用。
FlyoutControl.xaml
<ContentControl x:Name="ContentControl"
x:Class="Question_Answer_WPF_App.FlyoutControl"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Template="{DynamicResource ContentControlTemplate}"
Opacity="0"
Visibility="Hidden">
<ContentControl.Resources>
<Duration x:Key="OpenDuration">00:00:00.4</Duration>
<Storyboard x:Key="OpenStoryboard" Duration="{StaticResource OpenDuration}">
<DoubleAnimation Storyboard.TargetName="ContentControl" Storyboard.TargetProperty="Opacity" To="1" Duration="{StaticResource OpenDuration}">
<DoubleAnimation.EasingFunction>
<BackEase EasingMode="EaseOut" Amplitude="0.4"/>
</DoubleAnimation.EasingFunction>
</DoubleAnimation>
<ObjectAnimationUsingKeyFrames Storyboard.TargetName="ContentControl" Storyboard.TargetProperty="Visibility" Duration="{StaticResource OpenDuration}">
<DiscreteObjectKeyFrame Value="{x:Static Visibility.Visible}" KeyTime="00:00:00" />
</ObjectAnimationUsingKeyFrames>
</Storyboard>
<Storyboard x:Key="OpenInnerContentStoryboard" Duration="{StaticResource OpenDuration}">
<DoubleAnimation Storyboard.TargetName="scaleTransform" Storyboard.TargetProperty="ScaleX" To="1" Duration="{StaticResource OpenDuration}">
<DoubleAnimation.EasingFunction>
<BackEase EasingMode="EaseOut" Amplitude="0.4"/>
</DoubleAnimation.EasingFunction>
</DoubleAnimation>
<DoubleAnimation Storyboard.TargetName="scaleTransform" Storyboard.TargetProperty="ScaleY" To="1" Duration="{StaticResource OpenDuration}">
<DoubleAnimation.EasingFunction>
<BackEase EasingMode="EaseOut" Amplitude="0.4"/>
</DoubleAnimation.EasingFunction>
</DoubleAnimation>
</Storyboard>
<Storyboard x:Key="CloseStoryboard">
<DoubleAnimation Storyboard.TargetName="ContentControl" Storyboard.TargetProperty="Opacity" To="0" Duration="00:00:00"/>
<ObjectAnimationUsingKeyFrames Storyboard.TargetName="ContentControl" Storyboard.TargetProperty="Visibility">
<DiscreteObjectKeyFrame Value="{x:Static Visibility.Hidden}" KeyTime="00:00:00" />
</ObjectAnimationUsingKeyFrames>
</Storyboard>
<Storyboard x:Key="CloseInnerContentStoryboard">
<DoubleAnimation Storyboard.TargetName="scaleTransform" Storyboard.TargetProperty="ScaleX" To="0" Duration="00:00:00"/>
<DoubleAnimation Storyboard.TargetName="scaleTransform" Storyboard.TargetProperty="ScaleY" To="0" Duration="00:00:00"/>
</Storyboard>
<ControlTemplate x:Key="InnerContentButtonTemplate" TargetType="Button">
<ContentPresenter />
</ControlTemplate>
<ControlTemplate x:Key="BackgroundButtonTemplate" TargetType="Button">
<Grid Background="Black">
<Button VerticalAlignment="Center" HorizontalAlignment="Center" Click="InnerContentButtonClick" Template="{StaticResource InnerContentButtonTemplate}">
<ContentPresenter />
</Button>
</Grid>
</ControlTemplate>
<ControlTemplate x:Key="ContentControlTemplate" TargetType="ContentControl">
<Button x:Name="BackgroundButton" Template="{StaticResource BackgroundButtonTemplate}" Background="#B2000000" Click="BackgroundButtonClick">
<ContentPresenter RenderTransformOrigin="0.5, 0.5">
<ContentPresenter.RenderTransform>
<ScaleTransform x:Name="scaleTransform" ScaleX="0" ScaleY="0"/>
</ContentPresenter.RenderTransform>
</ContentPresenter>
</Button>
</ControlTemplate>
</ContentControl.Resources>
</ContentControl>
FlyoutControl.xaml.cs
using System.Windows;
using System.Windows.Controls;
using System.Windows.Media.Animation;
namespace Question_Answer_WPF_App
{
public partial class FlyoutControl : ContentControl
{
public FlyoutControl() => InitializeComponent();
private void OpenFlyout()
{
var openStoryboard = Resources["OpenStoryboard"] as Storyboard;
var openInnerContentStoryboard = Resources["OpenInnerContentStoryboard"] as Storyboard;
openStoryboard.Begin();
openInnerContentStoryboard.Begin(this, Template);
}
private void CloseFlyout()
{
var closeStoryboard = Resources["CloseStoryboard"] as Storyboard;
var closeInnerContentStoryboard = Resources["CloseInnerContentStoryboard"] as Storyboard;
closeStoryboard.Begin();
closeInnerContentStoryboard.Begin(this, Template);
}
public bool IsOpen
{
get { return (bool)GetValue(IsOpenProperty); }
set { SetValue(IsOpenProperty, value); }
}
public static readonly DependencyProperty IsOpenProperty =
DependencyProperty.Register(nameof(IsOpen),
typeof(bool),
typeof(FlyoutControl),
new PropertyMetadata(false,
new PropertyChangedCallback((s, e) =>
{
if (s is FlyoutControl flyoutControl && e.NewValue is bool boolean)
{
if (boolean)
{
flyoutControl.OpenFlyout();
}
else
{
flyoutControl.CloseFlyout();
}
}
})));
//Closes Flyout
private void BackgroundButtonClick(object sender, RoutedEventArgs e) => IsOpen = false;
//Disables clicks from within inner content from explicitly closing Flyout.
private void InnerContentButtonClick(object sender, RoutedEventArgs e) => e.Handled = true;
}
}
可以像这样使用:
<local:FlyoutControl>
<MyUserControlThatLooksLikeDiscord />
</local:FlyoutControl>
您可以手动控制它,也可以像这样通过绑定(bind)控制它:
代码隐藏
flyoutControl.IsOpen = !flyoutControl.IsOpen;
XAML 绑定(bind)
<Grid>
<local:FlyoutControl x:Name="flyoutControl">
<Grid Width="400" Height="200" Background="PeachPuff">
<TextBlock Text="Inside Flyout" VerticalAlignment="Center" HorizontalAlignment="Center"/>
</Grid>
</local:FlyoutControl>
<CheckBox IsChecked="{Binding IsOpen, ElementName=flyoutControl}" Content="Toggle Flyout" Margin="21" VerticalAlignment="Top" HorizontalAlignment="Left"/>
</Grid>
这是可附加属性,因此您可以更像 UWP 应用一样使用它
using System;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Controls.Primitives;
namespace Question_Answer_WPF_App
{
public class FlyoutAttach
{
public static FlyoutControl GetFlyout(ButtonBase button)
=> (FlyoutControl)button.GetValue(FlyoutProperty);
public static void SetFlyout(ButtonBase button, FlyoutControl value)
=> button.SetValue(FlyoutProperty, value);
public static readonly DependencyProperty FlyoutProperty =
DependencyProperty.RegisterAttached("Flyout",
typeof(FlyoutControl),
typeof(FlyoutAttach),
new PropertyMetadata(null,
new PropertyChangedCallback((s, e) =>
{
if (s is ButtonBase button && e.NewValue is FlyoutControl newFlyout)
{
if (Application.Current.MainWindow.Content is Grid grid)
{
if (e.OldValue is FlyoutControl oldFlyout)
{
grid.Children.Remove(oldFlyout);
}
grid.Children.Add(newFlyout);
button.Click -= buttonClick;
button.Click += buttonClick;
}
else
{
throw new Exception($"{nameof(Application.Current.MainWindow)} must have a root layout panel of type {nameof(Grid)} in order to use attachable Flyout.");
}
void buttonClick(object sender, RoutedEventArgs routedEventArgs)
{
newFlyout.IsOpen = true;
}
}
})));
}
}
使用起来就这么简单:
<Window.Resources>
<local:FlyoutControl x:Key="CustomFlyout" x:Name="flyoutControl">
<Grid Width="400" Height="200" Background="PeachPuff">
<TextBlock Text="Inside Flyout" VerticalAlignment="Center" HorizontalAlignment="Center"/>
</Grid>
</local:FlyoutControl>
</Window.Resources>
<Grid>
<Button Content="I have a flyout"
Width="120"
Height="40"
local:FlyoutAttach.Flyout="{StaticResource CustomFlyout}"/>
</Grid>
窗口
点击按钮
关于c# - 我如何在 WPF 中模仿这种行为?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51561656/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!