- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我真的很喜欢可以在 iOS 中看到的效果,它基本上看起来像是在当前 View 顶部绘制的图层,模糊了视觉内容并将其用作背景。有没有办法在 WPF 中实现类似的功能?
我见过人们大多在窗口级别处理这种模糊/透明,但我需要在窗口内处理。
假设这是我窗口的内容。
<StackPanel HorizontalAlignment="Center" Orientation="Horizontal">
<Image Source="pack://application:,,,/Resources/Penguins.jpg"/>
<Image Source="pack://application:,,,/Resources/Penguins.jpg"/>
</StackPanel>
看起来像
现在我想在上面画一些东西(而不是使用红色背景)模糊它下面的任何东西并将它用作背景,保持它的内容不模糊。
<DockPanel Margin="15" Background="Red">
<StackPanel Orientation="Horizontal" VerticalAlignment="Center" HorizontalAlignment="Center">
<Label Content="Some label"/>
<TextBox Width="100" Height="20"/>
</StackPanel>
</DockPanel>
最佳答案
结果:
我们将在网格中使用分层。背景:您的主要申请内容。前景:你的伪对话将有一个模糊的背景。
我们将把背景放在一个边框中,并用它的名字来引用这个边框。这将在 VisualBrush
中使用并提供我们要模糊的图像。
前景也将是分层网格。背景:一个矩形,用画笔填充并使用模糊效果。前景:任何你想放在前面的东西。
添加对 System.Windows.Interactivity
的引用。
添加以下行为代码:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Interactivity;
using System.Windows.Media;
using System.Windows.Media.Effects;
using System.Windows.Shapes;
namespace WpfApplication1
{
public class BlurBackgroundBehavior : Behavior<Shape>
{
public static readonly DependencyProperty BlurContainerProperty
= DependencyProperty.Register(
"BlurContainer",
typeof (UIElement),
typeof (BlurBackgroundBehavior),
new PropertyMetadata(OnContainerChanged));
private static readonly DependencyProperty BrushProperty
= DependencyProperty.Register(
"Brush",
typeof (VisualBrush),
typeof (BlurBackgroundBehavior),
new PropertyMetadata());
private VisualBrush Brush
{
get { return (VisualBrush) this.GetValue(BrushProperty); }
set { this.SetValue(BrushProperty, value); }
}
public UIElement BlurContainer
{
get { return (UIElement) this.GetValue(BlurContainerProperty); }
set { this.SetValue(BlurContainerProperty, value); }
}
protected override void OnAttached()
{
this.AssociatedObject.Effect = new BlurEffect
{
Radius = 80,
KernelType = KernelType.Gaussian,
RenderingBias = RenderingBias.Quality
};
this.AssociatedObject.SetBinding(Shape.FillProperty,
new Binding
{
Source = this,
Path = new PropertyPath(BrushProperty)
});
this.AssociatedObject.LayoutUpdated += (sender, args) => this.UpdateBounds();
this.UpdateBounds();
}
protected override void OnDetaching()
{
BindingOperations.ClearBinding(this.AssociatedObject, Border.BackgroundProperty);
}
private static void OnContainerChanged(DependencyObject d, DependencyPropertyChangedEventArgs e)
{
((BlurBackgroundBehavior) d).OnContainerChanged((UIElement) e.OldValue, (UIElement) e.NewValue);
}
private void OnContainerChanged(UIElement oldValue, UIElement newValue)
{
if (oldValue != null)
{
oldValue.LayoutUpdated -= this.OnContainerLayoutUpdated;
}
if (newValue != null)
{
this.Brush = new VisualBrush(newValue)
{
ViewboxUnits = BrushMappingMode.Absolute
};
newValue.LayoutUpdated += this.OnContainerLayoutUpdated;
this.UpdateBounds();
}
else
{
this.Brush = null;
}
}
private void OnContainerLayoutUpdated(object sender, EventArgs eventArgs)
{
this.UpdateBounds();
}
private void UpdateBounds()
{
if (this.AssociatedObject != null && this.BlurContainer != null && this.Brush != null)
{
Point difference = this.AssociatedObject.TranslatePoint(new Point(), this.BlurContainer);
this.Brush.Viewbox = new Rect(difference, this.AssociatedObject.RenderSize);
}
}
}
}
像这样在 XAML 中使用它:
<Grid>
<Border x:Name="content">
<Border.Background>
<ImageBrush ImageSource="bild1.jpg" />
</Border.Background>
<StackPanel>
<TextBox Width="200" Margin="10" />
<TextBox Width="200" Margin="10" />
<TextBox Width="200" Margin="10" />
</StackPanel>
</Border>
<Grid Margin="59,63,46,110">
<Rectangle ClipToBounds="True">
<i:Interaction.Behaviors>
<wpfApplication1:BlurBackgroundBehavior BlurContainer="{Binding ElementName=content}" />
</i:Interaction.Behaviors>
</Rectangle>
<TextBox VerticalAlignment="Center" Text="Blah" Width="200" Height="30" />
</Grid>
</Grid>
关于c# - 具有模糊效果的分层窗口,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27432466/
我可以使用 javascript 和其他所有东西,但在重新发明轮子之前,我想知道是否已经有一个类似的 jquery 插件,因为我想使用那个框架而不是 mootools。 我没有钱的问题,特别是 5 欧
我正在 React 应用程序中处理动画。我需要动画在悬停 后开始工作。我尝试了 :hover:after css 但不起作用。将鼠标悬停在图像上后动画可以工作,但我需要在悬停后开始。将鼠标悬停在图像上
我正在使用 jQuery 在按钮单击时实现 slider 效果。我的代码是: $(document).ready(function() { $("#mybutton").click(functio
我需要一个div标签在屏幕右侧滑出,如何使用jQuery获得这种效果?我一直在看这里:http://api.jquery.com/category/effects/sliding/而且这似乎不是我要找
我正在使用此代码实现页面 curl 效果......它在模拟器和设备中工作正常......但它不是(setType:@“pageCurl”)苹果记录的api,这导致它被iPhone拒绝App Stor
我见过各种关于 WPF 效果的引用,但它们似乎是针对位图的,而不是针对文本的。是否可以将除模糊或投影以外的效果应用于XAML中的TextBlock对象? 我想要做的示例可能是轮廓笔划,或斜角/浮雕效果
我见过各种关于 WPF 效果的引用,但它们似乎是针对位图的,而不是针对文本的。是否可以将除模糊或投影以外的效果应用于XAML中的TextBlock对象? 我想要做的示例可能是轮廓笔划,或斜角/浮雕效果
我正在尝试模拟这种效果:http://meyerweb.com/eric/css/edge/complexspiral/demo.html在我的博客上:http://segment6.blogspot
我尝试将样式应用到 Accordion Pane ,但遇到了问题。 这行不通。 accordion.setEffect(new DropShadow(BlurType.ONE_PASS_BOX, Co
关于 Datatables website 的教程足够清楚了: 在我告诉 Datatables 我正在谈论哪一列后,我只需将切换按钮放入: column.visible( ! column.visib
我正在寻找 scratchOut 效果,随便叫它什么。 这是从前景中删除图像的效果,因此背景图像变得可见。 我曾尝试使用 jquery 插件重新创建此效果,但它并不像我希望的那样流畅。 有没有人有这种
本文实例讲述了android实现文字和图片混排(文字环绕图片)效果。分享给大家供大家参考,具体如下: 在平时我们做项目中,或许有要对一张图片或者某一个东西进行文字和图片说明,这时候要求排版美观,所
本文实例讲述了Javafx简单实现【我的电脑资源管理器】效果。分享给大家供大家参考。具体如下: 1. java代码: ?
我是 ngrx 的新手,正在尝试让我的 ngrx 商店的 @Effect 函数正常工作。下面的代码显示了如果我没有使用 ngrx 商店,服务是如何工作的。我首先调用 http.get 来获取列表,然后
基本上我搜索了很多,解决方案建议应用一些 PNG 掩码或不提供所需的解决方案。 我发现了什么。 ffmpeg -i main.mkv -i facecloseup.mkv -filter_compl
有关使用从商店中选择的状态的效果的 Ngrx 文档状态(没有双关语意) Note: For performance reasons, use a flattening operator like co
我有一个数据网格控件,我在其中使用名为 FastShadow 的自定义效果,它就像一个光晕。 我希望效果在其边界之外发光,这样很好,但是当我在顶部绘制另一个形状时,我不希望这个形状受到影响。在本例中,
除了子 div.exception 中的所有内容,我想将 div.main 中的所有文本设为灰色。 div.exception 应该看起来好像类 main 从未添加到父 div。 这可能吗?如果是这样
我有一个 PDF 文件,我想重现此包页面中的页面 curl 效果: https://pub.flutter-io.cn/packages/page_turn 我试过用这个 page_turn插件,它需
我想测试一个效果如下: 如果调度了 LoadEntriesSucces 操作,则效果开始 等待 5 秒 5 秒后发送 http 请求 当响应到达时,将分派(dispatch)新的操作(取决于响应是成功
我是一名优秀的程序员,十分优秀!