C# 實現(xiàn)顏色漸變窗體控件詳細講解
1.建議設置窗體為雙緩沖繪圖,可有效避免界面刷時引起的閃爍
this.SetStyle(ControlStyles.AllPaintingInWmPaint | ControlStyles.OptimizedDoubleBuffer, true);
2、代碼實現(xiàn)
private Color Color1 = Color.Gray; //起始顏色 private Color Color2 = Color.White ; //目標顏色 private float changeAngle = 0f; //漸變角度
3.窗體繪制函數(shù)
private void Form1_Paint(object sender, PaintEventArgs e)
{
Graphics g = e.Graphics;
Rectangle grounRect = new Rectangle(0, 0, this.Width, this.Height);
System.Drawing.Drawing2D.LinearGradientBrush backGround = new System.Drawing.Drawing2D.LinearGradientBrush(grounRect, Color1, Color2, changeAngle);
g.FillRectangle(backGround, grounRect);
backGround.Dispose();
}
補充:WPS中 LinearGradientBrush線性漸變的使用
1、顏色列排列
注:
(1)列排列的起始坐標為(0,0.5)終止坐標為(1,0.5)
(2)其中offset放置的位置參數(shù)是需要計算的
例如:一共四個顏色,那么就是1/4=0.25;表示一個顏色0.25,第一個顏色為0.25,第二個就是再加上0.25=0.5,第三個就是0.75,第四個就是1
public MainWindow()
{
InitializeComponent();
//實例化一個Border控件,來設置這個背景線性漸變
Border bord1 = new Border();
bord1.Width = bord1.Height=200;
indext.Children.Add(bord1);
//線性漸變設置開始
LinearGradientBrush brush = new LinearGradientBrush();//實例化線性漸變對象
//列排列的起始坐標為(0,0.5)終止坐標為(1,0.5)
brush.StartPoint = new Point(0, 0.5);//設置線性漸變的二維起始坐標
brush.EndPoint=new Point(1,0.5);//設置線性漸變的二維終止坐標
brush.GradientStops.Add(new GradientStop(color: Colors.Pink,offset:0.25));
//GradientStops表示設置漸變的終止點
//GradientStop第一個參數(shù)color是設置顏色,第二個參數(shù)offset是設置的位置
brush.GradientStops.Add(new GradientStop(color: Colors.IndianRed,offset:0.50));
brush.GradientStops.Add(new GradientStop(color: Colors.LightSteelBlue,offset:0.75));
brush.GradientStops.Add(new GradientStop(color: Colors.LightSeaGreen,offset:1.0));
bord1.Background = brush;
//最后將設置好的漸變背景賦值給Border控件
}
2、顏色行排列
注:
行排列的時候,起始位置和終止位置只是改變了位置
列排列的起始坐標為(0.5,0)終止坐標為(0.5,1)
public MainWindow()
{
InitializeComponent();
Border bord1 = new Border();
bord1.Width = bord1.Height=200;
indext.Children.Add(bord1);
LinearGradientBrush brush = new LinearGradientBrush();
//顏色行排列位置改變
brush.StartPoint = new Point(0.5,0);
brush.EndPoint=new Point(0.5,1);
brush.GradientStops.Add(new GradientStop(color: Colors.Pink,offset:0.25));
brush.GradientStops.Add(new GradientStop(color: Colors.IndianRed,offset:0.50));
brush.GradientStops.Add(new GradientStop(color: Colors.LightSteelBlue,offset:0.75));
brush.GradientStops.Add(new GradientStop(color: Colors.LightSeaGreen,offset:1.0));
bord1.Background = brush;
}
3、左上角到右下角斜著排列
注:
如果說要斜著排列,那么它的起始位置和終止位置不用設置計算,默認排列,只需要計算offset的位置大小
public MainWindow()
{
InitializeComponent();
Border bord1 = new Border();
bord1.Width = bord1.Height=200;
indext.Children.Add(bord1);
LinearGradientBrush brush = new LinearGradientBrush();
brush.GradientStops.Add(new GradientStop(color: Colors.Pink,offset:0.25));
brush.GradientStops.Add(new GradientStop(color: Colors.IndianRed,offset:0.50));
brush.GradientStops.Add(new GradientStop(color: Colors.LightSteelBlue,offset:0.75));
brush.GradientStops.Add(new GradientStop(color: Colors.LightSeaGreen,offset:1.0));
bord1.Background = brush;
}
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關文章
基于WebClient實現(xiàn)Http協(xié)議的Post與Get對網(wǎng)站進行模擬登陸和瀏覽實例
這篇文章主要介紹了基于WebClient實現(xiàn)Http協(xié)議的Post與Get對網(wǎng)站進行模擬登陸和瀏覽的方法,以實例形式詳細分析了WebClient模擬POST與GET登陸與瀏覽的過程,對于C#項目開發(fā)來說具有不錯的參考借鑒價值,需要的朋友可以參考下2014-11-11

