美文网首页
CGContextRef画出扫一扫的区域

CGContextRef画出扫一扫的区域

作者: CowboyBebop | 来源:发表于2016-07-27 16:37 被阅读79次
5C2197C3-D440-49E1-A25D-C8A71584A502.png

CGContextRef 基本的知识点:

drawRect调是在Controller->loadView, Controller->viewDidLoad 两方法之后掉用的.所以不用担心在控制器中,这些View的drawRect就开始画了.这样可以在控制器中设置一些值给View(如果这些View draw的时候需要用到某些变量值).

1.如果在UIView初始化时没有设置rect大小,将直接导致drawRect不被自动调用。
2.该方法在调用sizeThatFits后被调用,所以可以先调用sizeToFit计算出size。然后系统自动调用drawRect:方法。
3.通过设置contentMode属性值为UIViewContentModeRedraw。那么将在每次设置或更改frame的时候自动调用drawRect:。
4.直接调用setNeedsDisplay,或者setNeedsDisplayInRect:触发drawRect:,但是有个前提条件是rect不能为0.
以上1,2推荐;而3,4不提倡
1、若使用UIView绘图,只能在drawRect:方法中获取相应的contextRef并绘图。如果在其他方法中获取将获取到一个invalidate的ref并且不能用于画图。drawRect:方法不能手动显示调用,必须通过调用setNeedsDisplay 或者 setNeedsDisplayInRect ,让系统自动调该方法。
2、若使用calayer绘图,只能在drawInContext: 中(类似鱼drawRect)绘制,或者在delegate中的相应方法绘制。同样也是调用setNeedDisplay等间接调用以上方法。
3、若要实时画图,不能使用gestureRecognizer,只能使用touchbegan等方法来掉用setNeedsDisplay实时刷新屏幕

例子:基本的API画出一个正方形
   -(void)drawRect:(CGRect)rect{
//获得处理的上下文    
CGContextRef context = UIGraphicsGetCurrentContext();    
//设置线条样式    
CGContextSetLineCap(context, kCGLineCapSquare);     
//设置线条粗细宽度    
CGContextSetLineWidth(context, 1.0);     
  //设置颜色    
CGContextSetRGBStrokeColor(context, 1.0, 0.0, 0.0, 1.0);     
//开始一个起始路径    
CGContextBeginPath(context);     
//起始点设置为(0,0):注意这是上下文对应区域中的相对坐标,    
CGContextMoveToPoint(context, 0, 0);     
//设置下一个坐标点    
CGContextAddLineToPoint(context, 100, 100);     
//设置下一个坐标点    
CGContextAddLineToPoint(context, 0, 150);    
//设置下一个坐标点    
CGContextAddLineToPoint(context, 50, 180);    
//连接上面定义的坐标点    
CGContextStrokePath(context);  
}
CGContextRef画出扫一扫的区域
 1,画正方形框
-(void)drawRect:(CGRect)rect{
CGContextRef ctx = UIGraphicsGetCurrentContext();
//    [self addScreenFillRect:ctx rect:self.bounds];
//    [self addCenterClearRect:ctx rect:CGRectMake(100, 10, 100, 100)];
CGContextSetRGBStrokeColor(ctx, 1, 1, 1, 0.7);
CGContextSetLineWidth(ctx, 1);
CGContextAddRect(ctx, CGRectMake(100, 100, 200, 200));
CGContextStrokePath(ctx);
}

2,画4个角
-(void)addCenterClearRect:(CGContextRef)ctx rect:(CGRect)rect{
CGContextClearRect(ctx, rect);
}
-(void)addCorner:(CGContextRef)ctx rect:(CGRect)rect{
CGContextSetLineWidth(ctx, 2);
 CGContextSetRGBStrokeColor(ctx,255 /255.0, 255/255.0, 255/255.0, 1 );
//    左上角
CGPoint leftPointsA[] = {
    CGPointMake(rect.origin.x - 5, rect.origin.y + 5),
    CGPointMake(rect.origin.x - 5, rect.origin.y - 5),
    CGPointMake(rect.origin.x + 15, rect.origin.y - 5),
};
CGContextAddLines(ctx, leftPointsA, 3);
// 右上角
  CGPoint rightPointsA[] = {
    CGPointMake(rect.origin.x + rect.size.width + 5, rect.origin.y + 5),
    CGPointMake(rect.origin.x + rect.size.width + 5, rect.origin.y - 5),
    CGPointMake(rect.origin.x + rect.size.width -15, rect.origin.y - 5)
};
CGContextAddLines(ctx, rightPointsA, 3);
//左下角
CGPoint leftPointsB[] = {
    CGPointMake(rect.origin.x - 5, rect.origin.y +rect.size.height - 5),
    CGPointMake(rect.origin.x - 5, rect.origin.y + rect.size.height + 5),
    CGPointMake(rect.origin.x + 15, rect.origin.y +rect.size.height + 5)
};
CGContextAddLines(ctx, leftPointsB, 3);
//右下角
CGPoint rightPointsB[] = {
    CGPointMake(rect.origin.x + rect.size.width + 5, rect.origin.y +rect.size.height - 5),
    CGPointMake(rect.origin.x + rect.size.width + 5, rect.origin.y + rect.size.height + 5),
    CGPointMake(rect.origin.x + rect.size.width - 15, rect.origin.y +rect.size.height + 5)
};
CGContextAddLines(ctx, rightPointsB, 3);
CGContextStrokePath(ctx);

}

相关文章

  • CGContextRef画出扫一扫的区域

    CGContextRef 基本的知识点: drawRect调是在Controller->loadView, Con...

  • Android 扫一扫,绘制指定区域透明区域

    一、概述在实现扫一扫的功能的时候,我们需要绘制一个中间为透明的扫码框,其余部分为半透明。通常情况下,例如微信或者支...

  • iOS原生二维码生成&扫描

    扫一扫这个功能我们并不陌生,微信QQ加好友扫一扫,路边搞推广的扫一扫,吃饭付钱扫一扫。看来这个扫一扫应用的地方还真...

  • 关于扫一扫,是时候放弃第三方了

    原文地址:张飞的技术博客 扫一扫这个功能我们并不陌生,微信QQ加好友扫一扫,路边搞推广的扫一扫,吃饭付钱扫一扫。看...

  • 支付宝有关的URL schemes

    微信扫一扫 weixin://scanqrcode (跳转微信扫一扫) 支付宝扫一扫 alipayqr://pla...

  • 支付宝有关的URL schemes

    微信扫一扫weixin://scanqrcode(跳转微信扫一扫)支付宝扫一扫alipayqr://platfor...

  • “扫一扫”

    毫无悬念,大家一看到这个字眼,一定会想要在前加上两个字——微信,想必都已成为了口头禅,再立马会想起些什么。我是准...

  • 2018-10-05

    扫楼状态比之前好,这场预售第一次扫楼,分到的区域不是拆迁就是进不去。不过也还好...扫楼一扫完资源加的顺,后面天黑...

  • 垃圾分类不慌 淘宝、支付宝、百度助力垃圾分类

    淘宝App“扫一扫”AI识垃圾功能 7月4日,淘宝App宣布推出“扫一扫”AI识垃圾功能,官方称“打开‘扫一扫’,...

  • iOS应用跳转微信扫一扫

    最新版的微信扫一扫跳转,亲测可以:// 跳转扫一扫[[UIApplication sharedApplicatio...

网友评论

      本文标题:CGContextRef画出扫一扫的区域

      本文链接:https://www.haomeiwen.com/subject/fnbojttx.html