3

考虑一个启用 ARC 的 iOS 应用程序中的这个简单的 UIView 子类,它在触摸屏幕时在视图上绘制:

- (void)touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event {

    CGPoint location = [[touches anyObject] locationInView:self];

    int padding = brushSize / 2;

    CGRect brushRect = CGRectMake(
        location.x - padding, location.y - padding,
        brushSize, brushSize
    );

    [self setNeedsDisplayInRect:brushRect];

}

- (void)drawRect:(CGRect)rect {

    NSDate *start = [NSDate date];

    CGContextRef context = UIGraphicsGetCurrentContext();
    CGContextDrawImage(context, rect, brushImage);

    NSLog(@"%f", [start timeIntervalSinceNow]);

}

在本例中,brushImage是一个方形位图,brushSize是一个描述位图宽度和高度的 int。

我一直得到这样的日志输出:

-0.131658
-0.133998
-0.143314
-0.007132
-0.006968
-0.007444
-0.006733
-0.008574
-0.007163
-0.006560
-0.006958

对 drawRect 的第一次调用比随后的调用花费更长的时间来完成,并且 drawRect 此后继续保持快速。只有在视图初始化后的第一次调用中,drawRect 很慢。

我在模拟器和我尝试过的所有物理设备中都看到了类似的结果。最初的调用总是需要更长的时间才能完成。

为什么在初始调用时 drawRect / CGContextDrawImage 这么慢?更重要的是,我该如何解决这个问题?

4

1 回答 1

3

检查矩形。我敢打赌前三个是全屏更新。我之前遇到过这个问题。不管你做什么,IOS都会强制更新前几次全屏(可能是因为它的GL缓冲系统)。如果您将其放置大约 5 秒钟,然后再次绘制某些东西,您将获得相同的行为。我从来没有弄清楚真正的原因是什么,我怀疑我永远不会:(。

请参阅我最初提出的问题: UIGraphicsGetCurrentContext() short life

于 2012-09-20T03:20:27.460 回答