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>
相关推荐
Java面试题总结8 小时前
AgentScope Harness 深度实战:让Java智能体从“Demo可用”走向“生产可用”
java·开发语言·wpf
-凌凌漆-10 小时前
WPF应用层框架介绍
wpf
小满Autumn12 小时前
依赖注入设计模式速查手册
开发语言·c#·wpf·mvvm·依赖注入
Xin_ye1008613 小时前
C# 零基础到精通教程 - WPF 专题三:高级控件与自定义控件
开发语言·c#·wpf
Xin_ye1008615 小时前
C# 零基础到精通教程 - WPF 深度专题:自定义布局与性能优化
开发语言·c#·wpf
小满Autumn15 小时前
WPF 依赖属性速查手册
笔记·c#·wpf·上位机·mvvm
Xin_ye1008616 小时前
C# 零基础到精通教程 - WPF 深度专题:3D 图形与视觉增强
开发语言·c#·wpf
加号31 天前
【WPF】 自定义 Image 控件实现图像缩放与平移
wpf
闪电悠米2 天前
黑马点评-分布式锁-02_simple_redis_lock_setnx
java·数据库·spring boot·redis·分布式·缓存·wpf
闪电悠米2 天前
黑马点评-分布式锁-03_lua_atomic_unlock
java·数据库·分布式·缓存·oracle·wpf·lua