欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C# 實(shí)現(xiàn)顏色漸變窗體控件詳細(xì)講解

 更新時(shí)間:2021年01月14日 15:07:45   作者:牧羊君  
這篇文章主要介紹了C# 實(shí)現(xiàn)顏色漸變窗體控件詳細(xì)講解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧

1.建議設(shè)置窗體為雙緩沖繪圖,可有效避免界面刷時(shí)引起的閃爍

this.SetStyle(ControlStyles.AllPaintingInWmPaint | ControlStyles.OptimizedDoubleBuffer, true); 

2、代碼實(shí)現(xiàn)

 private Color Color1 = Color.Gray; //起始顏色
 private Color Color2 = Color.White ; //目標(biāo)顏色
 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();
}

補(bǔ)充:WPS中 LinearGradientBrush線性漸變的使用

1、顏色列排列

注:

(1)列排列的起始坐標(biāo)為(0,0.5)終止坐標(biāo)為(1,0.5)

(2)其中offset放置的位置參數(shù)是需要計(jì)算的

​ 例如:一共四個(gè)顏色,那么就是1/4=0.25;表示一個(gè)顏色0.25,第一個(gè)顏色為0.25,第二個(gè)就是再加上0.25=0.5,第三個(gè)就是0.75,第四個(gè)就是1

public MainWindow()
    {
      InitializeComponent();
  //實(shí)例化一個(gè)Border控件,來設(shè)置這個(gè)背景線性漸變
      Border bord1 = new Border();
      bord1.Width = bord1.Height=200;
      indext.Children.Add(bord1);
  //線性漸變設(shè)置開始
      LinearGradientBrush brush = new LinearGradientBrush();//實(shí)例化線性漸變對象
  //列排列的起始坐標(biāo)為(0,0.5)終止坐標(biāo)為(1,0.5)
      brush.StartPoint = new Point(0, 0.5);//設(shè)置線性漸變的二維起始坐標(biāo)
      brush.EndPoint=new Point(1,0.5);//設(shè)置線性漸變的二維終止坐標(biāo)
      brush.GradientStops.Add(new GradientStop(color: Colors.Pink,offset:0.25));
  //GradientStops表示設(shè)置漸變的終止點(diǎn)
  //GradientStop第一個(gè)參數(shù)color是設(shè)置顏色,第二個(gè)參數(shù)offset是設(shè)置的位置
      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;
  //最后將設(shè)置好的漸變背景賦值給Border控件
    }

2、顏色行排列

注:

行排列的時(shí)候,起始位置和終止位置只是改變了位置

列排列的起始坐標(biāo)為(0.5,0)終止坐標(biāo)為(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、左上角到右下角斜著排列

注:

如果說要斜著排列,那么它的起始位置和終止位置不用設(shè)置計(jì)算,默認(rèn)排列,只需要計(jì)算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;
    }

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

相關(guān)文章

  • 基于WebClient實(shí)現(xiàn)Http協(xié)議的Post與Get對網(wǎng)站進(jìn)行模擬登陸和瀏覽實(shí)例

    基于WebClient實(shí)現(xiàn)Http協(xié)議的Post與Get對網(wǎng)站進(jìn)行模擬登陸和瀏覽實(shí)例

    這篇文章主要介紹了基于WebClient實(shí)現(xiàn)Http協(xié)議的Post與Get對網(wǎng)站進(jìn)行模擬登陸和瀏覽的方法,以實(shí)例形式詳細(xì)分析了WebClient模擬POST與GET登陸與瀏覽的過程,對于C#項(xiàng)目開發(fā)來說具有不錯(cuò)的參考借鑒價(jià)值,需要的朋友可以參考下
    2014-11-11
  • C#中API調(diào)用的多種方法

    C#中API調(diào)用的多種方法

    今天通過本文給大家分享C#中API調(diào)用的多種方法,通過API進(jìn)行解析掃入的二維碼,實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2021-09-09
  • C#日期格式字符串的相互轉(zhuǎn)換操作實(shí)例分析

    C#日期格式字符串的相互轉(zhuǎn)換操作實(shí)例分析

    這篇文章主要介紹了C#日期格式字符串的相互轉(zhuǎn)換操作,結(jié)合實(shí)例形式分析了C#日期格式字符串的相互轉(zhuǎn)換操作函數(shù)與相關(guān)使用技巧,需要的朋友可以參考下
    2019-08-08
  • C#基礎(chǔ)知識(shí)之this關(guān)鍵字介紹

    C#基礎(chǔ)知識(shí)之this關(guān)鍵字介紹

    本文主要介紹this關(guān)鍵字的幾種使用方法,this可以代表當(dāng)前實(shí)例,可以調(diào)用其他構(gòu)造函數(shù),還可以用來構(gòu)建索引器,這里都有一一舉例說明。
    2016-04-04
  • 基于Unity實(shí)現(xiàn)3D版2048游戲的示例代碼

    基于Unity實(shí)現(xiàn)3D版2048游戲的示例代碼

    這篇文章主要為大家詳細(xì)介紹了如何利用Unity實(shí)現(xiàn)簡易的3D版2048游戲,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,需要的可以參考一下
    2023-02-02
  • C#畫圖之餅圖折線圖的實(shí)現(xiàn)方法

    C#畫圖之餅圖折線圖的實(shí)現(xiàn)方法

    這篇文章主要介紹了C#畫圖之餅圖折線圖的實(shí)現(xiàn)方法,以實(shí)例形式講述了C#畫圖的完整實(shí)現(xiàn)過程,是非常實(shí)用的技巧,有不錯(cuò)的借鑒價(jià)值,需要的朋友可以參考下
    2014-09-09
  • C#入?yún)⑹褂靡妙愋鸵觬ef的原因解析

    C#入?yún)⑹褂靡妙愋鸵觬ef的原因解析

    這篇文章主要介紹了C#入?yún)⑹褂靡妙愋鸵觬ef的原因解析,我們在實(shí)際開發(fā)中還是能夠碰到一些引用類型添加ref的場景,其實(shí)道理也是一樣的,就是將引用類型的棧的地址傳遞到了方法中,那么和不添加有啥區(qū)別,感興趣的朋友跟隨小編一起看看吧
    2022-11-11
  • C#實(shí)現(xiàn)批量更改文件名稱大小寫或擴(kuò)展名

    C#實(shí)現(xiàn)批量更改文件名稱大小寫或擴(kuò)展名

    這篇文章主要為大家詳細(xì)介紹了如何利用C#實(shí)現(xiàn)批量更改文件名稱大小寫或擴(kuò)展名的功能,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)C#有一定的幫助,感興趣的小伙伴可以跟隨小編一起了解一下
    2022-12-12
  • C#算法之羅馬數(shù)字轉(zhuǎn)整數(shù)

    C#算法之羅馬數(shù)字轉(zhuǎn)整數(shù)

    本文詳細(xì)講解了C#算法之羅馬數(shù)字轉(zhuǎn)整數(shù),文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-01-01
  • 利用C#實(shí)現(xiàn)進(jìn)程管理器

    利用C#實(shí)現(xiàn)進(jìn)程管理器

    這篇文章主要為大家詳細(xì)介紹了如何利用C#實(shí)現(xiàn)自己的進(jìn)程管理器,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)C#有一定的幫助,感興趣的小伙伴可以了解一下
    2022-12-12

最新評論