CGContextAddArc画圆的使用(附CGContext画图基本过程)

本文详细介绍了如何使用CGContextAddArc方法绘制圆,并通过双缓冲技术在iPhone中实现高效的图形绘制,包括创建bitmapcontext、设置颜色、路径绘制及最终将图形显示在屏幕上。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近老画圆,所以对CGContextAddArc的接触比较多。

CGContextAddArc(Context, CGFloat x , CGFloat y, CGFloat radius, CGFloat startAngle , CGFloat endAngle, int clockwise);

这个方法牛人门都很熟悉了,我只是记录我自己的。

关于角度,由x,y可确定圆心坐标,而0,0角度位于圆心的正下方。

startAngle是由0,0偏移的。

偏移方向是由clockwise控制的,0为顺时针,1为逆时针。


 

iPhone中双缓冲的实现

原理不复杂:

  1. 创建一个bitmap context

  2. 在bitmap context上画东西

  3. 通过bitmap context生成一个CGImage

  4. 通过UIImage把CGImage内容画到屏幕上

  示例代码:

  // create the bitmap context

  CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB();

  CGContextRef context = CGBitmapContextCreate(nil,27,27,8,0, colorSpace,kCGImageAlphaPremultipliedLast);

  CFRelease(colorSpace);

  // create an arrow image

  // set the fill color

  CGColorRef fillColor = [[UIColor blackColor] CGColor];

  CGContextSetFillColor(context, CGColorGetComponents(fillColor));

  CGContextBeginPath(context);

  CGContextMoveToPoint(context, 8.0f, 13.0f);

  CGContextAddLineToPoint(context, 24.0f, 4.0f);

  CGContextAddLineToPoint(context, 24.0f, 22.0f);

  CGContextClosePath(context);

  CGContextFillPath(context);

  // convert the context into a CGImageRef

  CGImageRef image = CGBitmapContextCreateImage(context);

  CGContextRelease(context);

  UIImage* image2 = [UIImage imageWithCGImage:image];

  [image2 drawInRect:CGRectMake(0, 0, 120, 160)];

  其中对context绘图的部分可以用来画耗时的3d动画等。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值