[UWP]使用CompositionLinearGradientBrush实现渐变画笔并制作动画
admin
2023-02-15 05:40:06
0

1. 什么是 CompositionBrush

CompositionBrush(合成画笔)是操作可视化层时用于绘制 SpriteVisual 区域的画笔。

使UWP 应用时可以选择使用 XAML 画笔或 CompositionBrush(合成画笔) 绘制 UIElement。很多时候XAML画笔和合成画笔都能实现同样的效果,在官方文档 使用 XAML 画笔 vs。CompositionBrush 这一节中有详细的对比介绍。

[UWP]使用CompositionLinearGradientBrush实现渐变画笔并制作动画

CompositionBrush性能更好且能做更复杂的动画。XAML Brush的能力是有极限的,我从短暂的UWP生涯当中学到一件事,XAML Brush越是玩弄动画,动画就越可能因为没有料到的事态而失败……除非超越XAML Brush。所以我不做XAML Brush动画啦。

2. 使用CompositionLinearGradientBrush

CompositionLinearGradientBrush 是线性渐变画笔,它是最基本的画笔之一,可以实现类似 LinearGradientBrush的效果。基本使用步骤如下:

  1. 通过Compositor创建CompositionLinearGradientBrush;
  2. 通过Compositor创建并配置CompositionColorGradientStop,然后添加到CompositionLinearGradientBrush的ColorStops里;
  3. 创建SpriteVisual并将它的Brush设置为CompositionLinearGradientBrush;
  4. 使用ElementCompositionPreview.SetElementChildVisual 将SpriteVisual设置到某个UIElement的可视化层里。

具体代码如下:

var compositor = Window.Current.Compositor;

//创建 CompositionLinearGradientBrush。
var gradientBrush = compositor.CreateLinearGradientBrush();
gradientBrush.StartPoint = Vector2.Zero;
gradientBrush.EndPoint = new Vector2(1.0f);

var blueGradientStop = compositor.CreateColorGradientStop();
blueGradientStop.Offset = 0f;
blueGradientStop.Color = Color.FromArgb(255, 43, 210, 255);
var redGradientStop = compositor.CreateColorGradientStop();
redGradientStop.Offset = 1f;
redGradientStop.Color = Color.FromArgb(255, 255, 43, 136);
gradientBrush.ColorStops.Add(blueGradientStop);
gradientBrush.ColorStops.Add(redGradientStop);

//创建SpriteVisual并设置Brush
var backgroundVisual = compositor.CreateSpriteVisual();
backgroundVisual.Brush = gradientBrush;

//将自定义 SpriteVisual 设置为元素的可视化树的最后一个子元素。
ElementCompositionPreview.SetElementChildVisual(Gradient, backgroundVisual);

Gradient.SizeChanged += (s, e) =>
{
    if (e.NewSize == e.PreviousSize)
        return;

    //设置gradientBrush的尺寸
    backgroundVisual.Size = e.NewSize.ToVector2();
    gradientBrush.CenterPoint = backgroundVisual.Size / 2;
};

运行效果如下:

[UWP]使用CompositionLinearGradientBrush实现渐变画笔并制作动画

写了这么多代码,最终的效果其实和下面的XAML一样。


    
        
            
            
        
    

到目前为止看起来CompositionBrush没什么优势。

3. 使用合成动画

其实CompositionBrush其中一个好玩的地方是灵活的合成动画。

要使用合成动画,简单来说就是三个步骤:

  1. 创建CompositionAnimation;
  2. 配置CompositionAnimation;
  3. 在要实现动画效果的CompositionObject及其属性上调用StartAnimation;

下面这段代码是对CompositionColorGradientStop的Offset属性进行动画:

//创建动画
var relaxGradientStopOffsetAnimation = _compositor.CreateScalarKeyFrameAnimation();
//配置动画
relaxGradientStopOffsetAnimation.Duration = TimeSpan.FromSeconds(1);
relaxGradientStopOffsetAnimation.InsertKeyFrame(1.0f, ViewModel.IsInPomodoro ?1.0f : 0.75f);
//运行动画
_relaxGradientStop.StartAnimation(nameof(_relaxGradientStop.Offset), relaxGradientStopOffsetAnimation);

完整代码在 这里,具体运行效果如下:

[UWP]使用CompositionLinearGradientBrush实现渐变画笔并制作动画

4. 结语

其实上面的动画也可以用XAML画刷及Storyboard实现,但和这些技术已经老夫老妻了,再玩下去也没什么激情,所以想要玩点新花样。最近一直在搞番茄钟应用,有什么新的想法都会塞进去,可以在下面地址安装:

一个番茄钟

5. 参考

合成画笔 - Windows UWP applications _ Microsoft Docs
合成动画 - Windows UWP applications _ Microsoft Docs
CompositionLinearGradientBrush Class (Windows.UI.Composition) - Windows UWP applications _ Microsoft Docs
SpriteVisual Class (Windows.UI.Composition) - Windows UWP applications _ Microsoft Docs
ElementCompositionPreview.SetElementChildVisual(UIElement, Visual) Method (Windows.UI.Xaml.Hosting) - Windows UWP applications _ Microsoft Docs

6. 源码

OnePomodoro_Gradients.xaml.cs at master

相关内容

热门资讯

玩家攻略科普“新广西老友麻将有... 家人们!今天小编来为大家解答新广西老友麻将透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪...
【第一资讯】“上海滩究竟有挂吗... 【第一资讯】“上海滩究竟有挂吗?”(透视曝光猫腻)您好,上海滩这个游戏其实有挂的,确实是有挂的,需要...
玩家分享攻略“科尔沁麻将有挂吗... 网上科普关于“科尔沁麻将有没有挂”话题很是火热,小编也是针对科尔沁麻将作*弊开挂的方法以及开挂对应的...
玩家分享攻略“九酷众娱炸/金/... 您好:九酷众娱炸/金/花这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家...
我来教教您“蜀友汇到底有挂吗?... 我来教教您“蜀友汇到底有挂吗?”(其实是有挂)您好,蜀友汇这个游戏其实有挂的,确实是有挂的,需要了解...
今日重大消息“新老夫子牛牛可以... 今日重大消息“新老夫子牛牛可以开挂吗?”(其实是有挂)您好,新老夫子牛牛这个游戏其实有挂的,确实是有...
终于懂了“闽游麻将可以开挂吗?... 有 亲,根据资深记者爆料闽游麻将是可以开挂的,确实有挂(咨询软件无需打开...
今日重大消息“决战血流麻将开挂... 今日重大消息“决战血流麻将开挂神器?”(其实是有挂)您好,决战血流麻将这个游戏其实有挂的,确实是有挂...
【今日要闻】“极速暗宝究竟有挂... 您好:极速暗宝这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游戏...
【第一资讯】“四川游戏家园有挂... 网上科普关于“四川游戏家园有没有挂”话题很是火热,小编也是针对四川游戏家园作*弊开挂的方法以及开挂对...