Quartz2D 的使用

Quartz2D 与 UIBezierPath 类似,用于绘制图像。

基本方法

在 - (void)drawRect:(CGRect)rect 方法中进行绘制渲染。

    // 获取上下文
    CGContextRef contextRef = UIGraphicsGetCurrentContext();
    // 线条宽度
    CGContextSetLineWidth(contextRef, 5);
    // 连接处圆角
    CGContextSetLineJoin(contextRef, kCGLineJoinRound);
    // 线条末端圆角
    CGContextSetLineCap(contextRef, kCGLineCapRound);
    // 画矩形
    CGContextAddRect(contextRef, CGRectMake(50, 50, 100, 100));
    
    // 画直线
    CGContextMoveToPoint(contextRef, 100, 200);
    CGContextAddLineToPoint(contextRef, 200, 200);
    
    // 圆心x,y 半径radius  开始结束弧度  绘制方向:YES - 逆时针
    CGContextAddArc(contextRef, 100, 200, 100, 0, M_PI_2, 0);
    
    // 贝塞尔曲线 控制点1,控制点2,结束点
    CGContextAddCurveToPoint(contextRef, 100, 400, 200, 300, 300, 400);
    
    // 二次曲线 控制点,结束点
    CGContextAddQuadCurveToPoint(contextRef, 300, 700, 50, 500);

    // 闭合
    CGContextClosePath(contextRef);

  

通过以上基本设定可绘制出想要的图像,在通过以下几种方法得到相应的效果。

画线条

// 线条颜色
[[UIColor redColor] set];
//渲染
CGContextStrokePath(contextRef);
线条

填充

// 填充颜色
CGContextSetRGBFillColor(contextRef, 0.3, 0.7, 0.6, 1);
CGContextFillPath(contextRef);
填充

 裁剪

// 裁剪
CGContextClip(contextRef);

UIImage * image = [UIImage imageNamed:@"11.jpg"];
[image drawInRect:rect];
裁剪

 

对图片上下文操作

- (void)test
{
    // 开启图片类型的图形上下文
    UIGraphicsBeginImageContextWithOptions(CGSizeMake(300, 300), NO, 0);
    
    // 获取当前上下文
    CGContextRef ctx = UIGraphicsGetCurrentContext();
    
    // 画线
    CGContextMoveToPoint(ctx, 100, 100);
    CGContextAddRect(ctx, CGRectMake(0, 0, 200, 200));
    
    // 裁剪
    CGContextClip(ctx);
    [self.imageView.image drawAtPoint:CGPointZero];
    
    // 文字水印
    [@"这是水印" drawAtPoint:CGPointMake(100, 150) withAttributes:@{NSFontAttributeName:[UIFont systemFontOfSize:15]}];
    
    // 图片水印
    UIImage * logo = [UIImage imageNamed:@"44"];
    [logo drawAtPoint:CGPointMake(50, 150)];
    
    // 得到新图片
    UIImage * image = UIGraphicsGetImageFromCurrentImageContext();
    
    // 关闭上下文
    UIGraphicsEndImageContext();
    
    // 保存相册
    UIImageWriteToSavedPhotosAlbum(image, NULL, NULL, NULL);
    
    self.imageView.image = image;
}

可通过裁剪、添加水印等获得新图片。

裁剪并添加水印后

总结

Quartz2D  的用法和 UIBezierPath 很像,可用于基本的线条处理及图片处理,同样也可以制作柱状图,饼状图等等。

可参考之前的文章 UIBezierPath 画折线图

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值