码迷,mamicode.com
首页 > 其他好文 > 详细

drawRect: 小注

时间:2014-07-14 09:50:15      阅读:221      评论:0      收藏:0      [点我收藏+]

标签:style   color   使用   strong   width   art   

drawRect:()默认是什么都不做的,

1.如果基础一个UIView,子类可以使用Core Graphics框架和UIKit在这个方法中完成绘制操作。

2.如果使用其他方法设置子类的content,可以不适用这个方法。

如:你只是改变背景颜色,或者使用他的underlying layer对象(包括直接使用子类的基本层,或者子类添加subview)。

3.如果是直接从一个UIView对象(包括所有系统提供的UIView的子类)继承来的selfVIew,打开这个方法的时候可以不用call super,但是如果你是继承一个自定义的UIView子类,这样myView:selfView,则如果myView需要使用到drawRect:方法的时候需要call super at some point in your implementation。

4.这个方法在第一次displayed view的时候,或者一个事件发生需要改变可见视图的时候被自动调用,你不能够直接调用这个方法,如果需要,可以使用方法setNeedsDisplay或者setNeedsDisplayInRect:替代方法来实现。

5、若使用UIView绘图,只能在drawRect:方法中获取相应的contextRef并绘图。如果在其他方法中获取将获取到一个invalidate的ref并且不能用于画图。drawRect:方法不能手动显示调用,必须通过调用setNeedsDisplay 或者 setNeedsDisplayInRect ,让系统自动调该方法。

6、若使用calayer绘图,只能在drawInContext: 中(类似鱼drawRect)绘制,或者在delegate中的相应方法绘制。同样也是调用setNeedDisplay等间接调用以上方法。

7、若要实时画图,不能使用gestureRecognizer,只能使用touchbegan等方法来掉用setNeedsDisplay实时刷新屏幕

——————————代码:

#import "InfoView.h"

@interface UIView (CanvasImageView)//类别加一个

//多边形

-(void)drawPolygon:(NSArray *)pointArray;

@end

@implementation UIView (CanvasImageView)

-(void)drawPolygon:(NSArray *)pointArray

{

//    NSAssert(pointArray.count>=2,@"数组长度必须大于等于2");

//    NSAssert([[pointArray[0] class] isSubclassOfClass:[NSValue class]], @"数组成员必须是CGPoint组成的NSValue");

    CGContextRef     context = UIGraphicsGetCurrentContext();

    NSValue *startPointValue = pointArray[0];

    CGPoint  startPoint      = [startPointValue CGPointValue];

    CGContextMoveToPoint(context, startPoint.x, startPoint.y);

    for(int i = 1;i<pointArray.count;i++)

    {

//        NSAssert([[pointArray[i] class] isSubclassOfClass:[NSValue class]], @"数组成员必须是CGPoint组成的NSValue");

        NSValue *pointValue = pointArray[i];

        CGPoint  point      = [pointValue CGPointValue];

        CGContextAddLineToPoint(context, point.x,point.y);

    }

    [[UIColor redColor] setFill];

    [[UIColor yellowColor] setStroke];

     CGContextDrawPath(context, kCGPathFillStroke);

}

@end

 

@implementation InfoView

 

- (id)initWithFrame:(CGRect)frame

{

    self = [super initWithFrame:frame];

    if (self) {

        // Initialization code 

    }

    return self;

}

 

/* Only override drawRect: if you perform custom drawing. An empty implementation adversely affects performance during animation.*/

- (void)drawRect:(CGRect)rect

{

    // Drawing code

    CGPoint uppoint = CGPointMake(rect.size.width/2, rect.size.height/2-15);

    CGPoint downpoint = CGPointMake(rect.size.width/2, rect.size.height/2+15);

    CGPoint arrowpoint = CGPointMake(0, rect.size.height);

    NSArray *pointArr = [NSArray arrayWithObjects:[NSValue valueWithCGPoint:uppoint],[NSValue valueWithCGPoint:downpoint],[NSValue valueWithCGPoint: arrowpoint],[NSValue valueWithCGPoint:uppoint], nil];

    //这一块代码绘图使用的CGContext,只能够再DrawRect:方法中使用,放到别的地方将失效,因为最终调用了这个方法,会将VIew的从新绘制,并将之前的尝试给覆盖了。在别的地方可以进行underlying layer层次的绘图操作~

    [self drawPolygon:pointArr];

}

@end

 

drawRect: 小注,布布扣,bubuko.com

drawRect: 小注

标签:style   color   使用   strong   width   art   

原文地址:http://www.cnblogs.com/longtaozi/p/3839951.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!