博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ios CGContext 学习1 画线 画矩形 渐变效果
阅读量:6293 次
发布时间:2019-06-22

本文共 1537 字,大约阅读时间需要 5 分钟。

void drawLinearGradient(CGContextRef context,

                        CGRect rect,

                        CGColorRef startColor,

                        CGColorRef endColor)

{

    CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB();

    CGFloat locations[] = {0.0,1.0}; //颜色所在位置

    

    NSArray *colors = [NSArrayarrayWithObjects:(id)startColor,(id)endColor, nil];//渐变颜色数组

    CGGradientRef gradient = CGGradientCreateWithColors(colorSpace, (CFArrayRef) colors, locations);//构造渐变

    

    CGPoint startPoint = CGPointMake(CGRectGetMidX(rect), CGRectGetMinY(rect));

    CGPoint endPoint = CGPointMake(CGRectGetMidX(rect), CGRectGetMaxY(rect));

    

    CGContextSaveGState(context);//保存状态,主要是因为下面用到裁剪。用完以后恢复状态。不影响以后的绘图

    CGContextAddRect(context, rect);//设置绘图的范围

    CGContextClip(context);//裁剪

    CGContextDrawLinearGradient(context, gradient, startPoint, endPoint, 0);//绘制渐变效果图

    CGContextRestoreGState(context);//恢复状态

    

    CGGradientRelease(gradient);

    CGColorSpaceRelease(colorSpace);

}

 

//使用

 

 CGContextRef context = UIGraphicsGetCurrentContext();

    CGColorRef whiteColor = [UIColorcolorWithRed:1.0green:1.0blue:1.0alpha:1.0].CGColor;

    CGColorRef lightGrayColor = [UIColorcolorWithRed: 230.0 / 255.0 

                                                green: 230.0 / 255.0 

                                                 blue: 230.0 / 255.0 

                                                alpha:1.0].CGColor;

    CGRect paperRect = self.bounds;

    drawLinearGradient(context, paperRect, whiteColor,lightGrayColor);

 

CGContextSetStrokeColorWithColor(context, lightGrayColor);

    CGRect newrRect = CGRectInset(paperRect, 1.5, 1.5);//构造位置

    CGContextSetLineWidth(context, 1);//设置笔宽

    CGContextStrokeRect(context, newrRect);//绘图

 

效果:

函数部分主要是渐变效果

后面的是笔刷画一条虚拟的边框。

转载于:https://www.cnblogs.com/greywolf/archive/2012/07/31/2616624.html

你可能感兴趣的文章
驰骋工作流引擎三种项目集成开发模式
查看>>
SUSE11修改主机名方法
查看>>
jdk6.0 + Tomcat6.0的简单jsp,Servlet,javabean的调试
查看>>
Android:apk签名
查看>>
2(2).选择排序_冒泡(双向循环链表)
查看>>
MySQL 索引 BST树、B树、B+树、B*树
查看>>
微信支付
查看>>
CodeBlocks中的OpenGL
查看>>
短址(short URL)
查看>>
第十三章 RememberMe——《跟我学Shiro》
查看>>
mysql 时间函数 时间戳转为日期
查看>>
索引失效 ORA-01502
查看>>
Oracle取月份,不带前面的0
查看>>
Linux Network Device Name issue
查看>>
IP地址的划分实例解答
查看>>
如何查看Linux命令源码
查看>>
运维基础命令
查看>>
入门到进阶React
查看>>
SVN 命令笔记
查看>>
检验手机号码
查看>>