iOS CoreGraphic

iOS_CoreGraphics

2018-10-12  本文已影响83人  Hunter琼

CoreGraphics是提供2D绘图的框架,使用C结构和C函数模拟了一套面向对象的变成机制,没有OC/Swift对象方法机制;2D绘图并不能操作单独的像素;所以绘制机制都是在context上下文进行的.数据结构和函数可以通过CG来识别.
CoreGraphics的优点:
1 快速,高效绘图,可以减少文件大小
2 可以自由使用动态的,搞质量的图像
3 可以创建直线,路径,渐变,文字与图像等内容,并可以做变现处理
CoreGraphics常用的API:

  CGContextRef:获取上下文画布:CGContextRef ctx =  UIGraphicsGetCurrentContext();
  CGContextAddRect:绘制闭合曲
  CGContextSetFillColorWithColor:设置填充颜色
  CGContextFillPath:填充路径
  CGContextStrokePath:绘制路径
  CGContextAddArc:绘弧线 
  CGContextAddEllipseInRect:绘制椭圆
  CGContextMoveToPoint:绘制多边形从一个点开始新的子路径
  CGContextAddlineToPoint:在当前点追加直线段
  CGContextClosePath:关闭路径
  CGContextDrawPath:绘制坐标路径
  CGContextmAddQuadCureToPoint:给定控制点和终点
  CGContextSetStrokeColorWithColor://设置描边颜色
  CGContextSetLineWidth:设置线的宽度
  CGContextSetLineCap:设置线条终点的形状
  CGContextSetLineDash:画虚线
  CGContextAddCurveTopiont:绘制阴影
  CGContextDrawRadialGradient:放射性渐变
  CGGradientCreatWithColorComponment:线性渐变 从某种颜色开始,到另外一种颜色结束
  CGContextDrawLinenearGraditent::线性渐变

(1) 绘制一个矩形

   CGContextRef ctx =  UIGraphicsGetCurrentContext();
   CGContextAddRect(ctx, rect);
   CGContextSetFillColorWithColor(ctx, [UIColor greenColor].CGColor);
   CGContextFillPath(ctx);

(2)绘制一个圆

     x:圆弧的中心点坐标x
     y:曲线控制点的y坐标 
     radius:指定的x坐标值
     startAngle:弧的起点与x轴的夹角
     endAngle:弧的终点与x轴的夹角
     clockWise:指定值1
     CGContextRef ctx = UIGraphicsGetCurrentContext();
     CGContextAddArc(ctx, rect.origin.x + rect.size.width/2, rect.origin.y + rect.size.width/2, rect.size.width/2, 0, 2* M_PI, 1);
     CGContextSetFillColorWithColor(ctx, [UIColor orangeColor].CGColor);
     CGContextFillPath(cox);

(3)绘制一个椭圆

       CGContextRef ctx = UIGraphicsGetCurrentContext();
       CGContextAddEllipseInRect(ctx, rect);
       CGContextSetFillColorWithColor(ctx, [UIColor redColor].CGColor);
       CGContextFillPath(ctx);
       CGContextStrokePath(ctx);

(4)绘制多边形

      CGContextRef ctx = UIGraphicsGetCurrentContext();
      CGContextBeginPath(ctx);
      CGContextMoveToPoint(ctx, 100, 40);
      CGContextAddLineToPoint(ctx, 80, 80);
      CGContextAddLineToPoint(ctx, 130, 80);
      CGPDFContextClose(ctx);
      CGContextSetFillColorWithColor(ctx, [UIColor yellowColor].CGColor);
      CGContextFillPath(ctx);

(5)绘制不规则图形

       CGContextRef ctx = UIGraphicsGetCurrentContext();
      CGContextBeginPath(ctx);
      CGContextMoveToPoint(ctx, 0,40);
      // cpx:曲线控制点的x轴
      // cpy:曲线控制点的y轴
      CGContextAddQuadCurveToPoint(ctx, 0, 100, 25, 25);
      CGContextSetLineWidth(ctx, 5);
      //CGContextSetLineCap(<#CGContextRef  _Nullable c#>, <#CGLineCap cap#>)
      CGContextSetStrokeColorWithColor(ctx, [UIColor redColor].CGColor);
      CGContextSetFillColorWithColor(ctx, [UIColor blueColor].CGColor);
      CGContextStrokePath(ctx);

(6)绘制一个放射性渐变

        CGContextRef ctx = UIGraphicsGetCurrentContext();
        CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB();
        NSArray *gradientArray = [NSArray arrayWithObjects:(id)[UIColor greenColor].CGColor,(id)[UIColor redColor].CGColor, nil];
       CGFloat gradLoactions[] = {0,1};
       CGGradientRef gradient = CGGradientCreateWithColors(colorSpace, (__bridge CFArrayRef)gradientArray, gradLoactions);
       CGPoint point = CGPointMake(CGRectGetMidX(rect), CGRectGetMaxY(rect));
       CGFloat radius = MAX(CGRectGetHeight(rect), CGRectGetWidth(rect));
      //startCenter 起点中心圆点
      // startRadius:起点的半径
      //endCenter:终点
     // endRadius:终点半径
     CGContextDrawRadialGradient(ctx, gradient, point, 0, point, radius, 0);
     CGGradientRelease(gradient);
     CGColorSpaceRelease(colorSpace);

(7)绘制一个线性渐变

       CGContextRef ctx = UIGraphicsGetCurrentContext();
       CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB();
       NSArray *gradientArray = [NSArray arrayWithObjects:(id)[UIColor greenColor].CGColor,(id)[UIColor redColor].CGColor, nil];
      CGFloat gradLoactions[] = {0,1};
      CGGradientRef gradient = CGGradientCreateWithColors(colorSpace, (__bridge CFArrayRef)gradientArray, gradLoactions);
      CGContextSaveGState(ctx);
      CGContextDrawLinearGradient(ctx, gradient, CGPointMake(0, 0), CGPointMake(100, 100), 0);
      CGContextRestoreGState(ctx);
      CGGradientRelease(gradient);
      CGColorSpaceRelease(colorSpace);

demo:https://github.com/joinGitWenze/IOS_CoreGraphics

上一篇下一篇

猜你喜欢

热点阅读