iOS中利用CAGradientLayer繪製漸層色的方法執行個體

來源:互聯網
上載者:User

標籤:特定   cal   ati   很多   view   單位   with   omr   參考   

  原理詳解

  1、CAGradientLayer是CALayer圖層類的子類,用於處理漸層色的層結構。

  2、CAGradientLayer的座標系統是從座標(0,0)到(1,1)繪製的矩形。

  3、CAGradientLayer的frame值的size不為正方形的話,座標系統會被展開。

  4、CAGradientLayer的startPoint與endPoint會直接影響顏色的繪製方向。

  5、CAGradientLayer的顏色分割點是以0~1的比例來計算的,顏色分割點為漸層色開始或終止的地方。

  CAGradientLayer屬性介紹

  colors:漸層顏色數組

  locations:漸層顏色的區間分布(分割點),locations的數組長度和colors一致。這個屬性可不設,預設是nil,系統會平均分布顏色如果有特定需要可設定,數組設定為0 ~ 1之間單調遞增。

  startPoint:映射locations中起始位置,用單位向量表示。比如(0, 0)表示從左上方開始變化。預設值是:(0.5, 0.0)。

  endPoint:映射locations中結束位置,用單位向量表示。比如(1, 1)表示到右下角變化結束。預設值是:(0.5, 1.0)。

  type:預設值是kCAGradientLayerAxial,表示按像素均勻變化。

  CAGradientLayer例子

  最簡單的三原色漸層例子

  http://www.kmjdad.com/

  http://www.jnsjzyy.com/

  http://www.czhkwl.com/

  http://www.express-o2o.com/

  http://www.gzjindao.com/

  http://www.chumingchuanmeiyishu.com/

  http://www.thcxb.com/

  http://www.xingguangkeji.com/

  http://www.gdrhsy.com/

  http://www.clhuiji.com/

  http://www.nxjianye.com/

  http://www.tjmingsheng.com/

  http://www.gangguan022.com/

  http://www.zyjbp.com/

  http://www.qianhangmy.com/

  http://www.tzminbell.com/

  效果展示

  程式碼範例

  UIView * myView = [[UIView alloc] initWithFrame:CGRectMake(50, 50, 200, 200)];

  [self.view addSubview:myView];

  CAGradientLayer * gradientLayer = [CAGradientLayer layer];

  gradientLayer.frame = myView.bounds;

  // 設定漸層顏色數組

  gradientLayer.colors = @[(__bridge id)[UIColor redColor].CGColor,(__bridge id)[UIColor greenColor].CGColor,(__bridge id)[UIColor blueColor].CGColor];

  // 漸層顏色的區間分布

  gradientLayer.locations = @[@0.25,@0.5,@0.75];

  // 起始位置

  gradientLayer.startPoint = CGPointMake(0, 0);

  // 結束位置

  gradientLayer.endPoint = CGPointMake(0, 1);

  [myView.layer addSublayer:gradientLayer];

  複製代碼

  當然,實際使用的肯定比這個顏值高很多的,效果展示:

  代碼如下:

  #define FHCColorFromRGB(rgbValue) [UIColor colorWithRed:((float)((rgbValue & 0xFF0000) >> 16))/255.0 green:((float)((rgbValue & 0xFF00) >> 8))/255.0 blue:((float)(rgbValue & 0xFF))/255.0 alpha:1.0]

  UIView * myView = [[UIView alloc] initWithFrame:CGRectMake(50, 50, 200, 200)];

  [self.view addSubview:myView];

  CAGradientLayer * gradientLayer = [CAGradientLayer layer];

  gradientLayer.frame = myView.bounds;

  gradientLayer = [CAGradientLayer layer];

  gradientLayer.colors = @[(__bridge id)FHCColorFromRGB(0x01b6ff).CGColor, (__bridge id)FHCColorFromRGB(0x4392f6).CGColor];

  gradientLayer.locations = @[@0.1, @1.0];

  gradientLayer.startPoint = CGPointMake(0, 0);

  gradientLayer.endPoint = CGPointMake(1.0, 0);

  [myView.layer addSublayer:gradientLayer];

  複製代碼

  是不是美美噠?當然你可以把它封裝成一個類別,以便下次使用.

  總結

  以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對程式員之家的支援。

iOS中利用CAGradientLayer繪製漸層色的方法執行個體

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.