wpf之LinearGradientBrush线性渐变

1、从左到右渐变

Fill属性指定矩形Rectangle采用内部填充颜色,LinearGradientBrush指定填充颜色采用线性渐变画刷,StartPoint指定渐变的起点,EndPoint指定渐变的终点,StartPoint="0,0"代表矩形的左上角、EndPoint="1,0"代表矩形的右上角,所以实际等于从左到右渐变; 中GradientStop 定义渐变的节点,Offset="0" 代表渐变的起点, Color="Red"指定颜色,所以综合起来就是指定渐变起点为红色;,Offset="1" 代表渐变的终点,Color="Blue" 指定颜色,所以综合起来就是指定渐变终点为蓝色,Offset的值范围就是0到1之间,代表渐变从起点到终点的位置,所以下面的代码指的就是从矩形的左边开始使用红色一直到矩形的右边使用蓝色,这样一个红到蓝的渐变。

csharp 复制代码
 <Rectangle Width="200" Height="100">
                <Rectangle.Fill>
                    <!-- 线性渐变画刷 -->
                    <LinearGradientBrush StartPoint="0,0" EndPoint="1,0">
                        <!-- 定义两个或更多个渐变点 -->
                        <GradientStop Color="Red"  Offset="0" />
                        <GradientStop Color="Blue"  Offset="1" />
                    </LinearGradientBrush>
                </Rectangle.Fill>
            </Rectangle>

2、从上到下渐变

csharp 复制代码
<Rectangle Width="200" Height="100">
                <Rectangle.Fill>
                    <!-- 线性渐变画刷 -->
                    <LinearGradientBrush StartPoint="0,0" EndPoint="0,1">
                        <!-- 定义两个或更多个渐变点 -->
                        <GradientStop Color="Red" Offset="0" />
                        <GradientStop Color="Blue" Offset="1" />
                    </LinearGradientBrush>
                </Rectangle.Fill>
            </Rectangle>

3、从右到左渐变

csharp 复制代码
<Rectangle.Fill>
                    <!-- 线性渐变画刷 -->
                    <LinearGradientBrush StartPoint="1,0" EndPoint="0,0">
                        <!-- 定义两个或更多个渐变点 -->
                        <GradientStop Color="Red" Offset="0" />
                        <GradientStop Color="Blue" Offset="1" />
                    </LinearGradientBrush>
                </Rectangle.Fill>

4、从下到上渐变

csharp 复制代码
 <Rectangle Width="200" Height="100">
                <Rectangle.Fill>
                    <!-- 线性渐变画刷 -->
                    <LinearGradientBrush StartPoint="0,1" EndPoint="0,0">
                        <!-- 定义两个或更多个渐变点 -->
                        <GradientStop Color="Red" Offset="0" />
                        <GradientStop Color="Blue" Offset="1" />
                    </LinearGradientBrush>
                </Rectangle.Fill>
            </Rectangle>

5、从左上角到右下角

csharp 复制代码
 <Rectangle Width="200" Height="100">
                <Rectangle.Fill>
                    <!-- 线性渐变画刷 -->
                    <LinearGradientBrush StartPoint="0,0" EndPoint="1,1">
                        <!-- 定义两个或更多个渐变点 -->
                        <GradientStop Color="Red"  Offset="0" />
                        <GradientStop Color="Blue"  Offset="1" />
                    </LinearGradientBrush>
                </Rectangle.Fill>
            </Rectangle>

6、从左下角到右上角

csharp 复制代码
 <Rectangle Width="200" Height="100">
                <Rectangle.Fill>
                    <!-- 线性渐变画刷 -->
                    <LinearGradientBrush StartPoint="0,1" EndPoint="1,0">
                        <!-- 定义两个或更多个渐变点 -->
                        <GradientStop Color="Red" Offset="0" />
                        <GradientStop Color="Blue" Offset="1" />
                    </LinearGradientBrush>
                </Rectangle.Fill>
            </Rectangle>

7、从右上角到左下角

csharp 复制代码
<Rectangle Width="200" Height="100">
                <Rectangle.Fill>
                    <!-- 线性渐变画刷 -->
                    <LinearGradientBrush StartPoint="1,0" EndPoint="0,1">
                        <!-- 定义两个或更多个渐变点 -->
                        <GradientStop Color="Red" Offset="0" />
                        <GradientStop Color="Blue" Offset="1" />
                    </LinearGradientBrush>
                </Rectangle.Fill>
            </Rectangle>

8、从右下角到左上角

csharp 复制代码
 <Rectangle Width="200" Height="100">
                <Rectangle.Fill>
                    <!-- 线性渐变画刷 -->
                    <LinearGradientBrush StartPoint="1,1" EndPoint="0,0">
                        <!-- 定义两个或更多个渐变点 -->
                        <GradientStop Color="Red" Offset="0" />
                        <GradientStop Color="Blue" Offset="1" />
                    </LinearGradientBrush>
                </Rectangle.Fill>
            </Rectangle>

9、定义3个渐变颜色

csharp 复制代码
<Rectangle Width="200" Height="100">
                <Rectangle.Fill>
                    <!-- 线性渐变画刷 -->
                    <LinearGradientBrush StartPoint="0,0" EndPoint="1,0">
                        <!-- 定义两个或更多个渐变点 -->
                        <GradientStop Color="Red"  Offset="0" />
                        <GradientStop Color="green"  Offset="0.5" />
                        <GradientStop Color="Blue"  Offset="1" />
                    </LinearGradientBrush>
                </Rectangle.Fill>
            </Rectangle>
相关推荐
Chris _data8 天前
WPF 学习第三天 — Modbus RTU 串口通信
hadoop·学习·wpf
布吉岛的石头8 天前
Java 程序员第 43 阶段05:微服务整合大模型,跨服务调用架构设计实战,Seata分布式事务实战
wpf
步步为营DotNet8 天前
基于.NET Aspire 实现云原生应用的高效监控与可观测性
云原生·.net·wpf
芒鸽9 天前
HarmonyOS 分布式开发实战:设备协同、数据共享与跨设备迁移
分布式·wpf·harmonyos
Volunteer Technology9 天前
Flink状态管理与容错(二)
大数据·flink·wpf
happyprince10 天前
07_verl-Trainer模块详解
人工智能·架构·wpf·强化学习
bugcome_com10 天前
WPF + Prism 技术指南与实战项目(二、模板搭建)
wpf
小满Autumn10 天前
log4net 日志框架 — 从配置到实战速查手册
笔记·c#·.net·wpf·上位机·log4net
政沅同学10 天前
基于 C# WPF + HALCON 的工业视觉算法工具框架(开源)
开发语言·c#·wpf
happyprince11 天前
03_verl-设计理念与核心原理
wpf