[CALayer renderInContext:] 之后 CGBitmapContextCreateImage() ,图片质量变差,方法不对还是什么原因?

2012-03-14 18:51:53 +08:00
 changx
- (void)drawLayer:(CALayer *)layer inContext:(CGContextRef)ctx
{
UIGraphicsBeginImageContext(layer.bounds.size);
CGContextRef _ctx = UIGraphicsGetCurrentContext();
[self.view.layer renderInContext:_ctx];
CGImageRef image = CGBitmapContextCreateImage(_ctx);
UIGraphicsEndImageContext();

CGImageRef flipImage = CGImageCreateWithImageInRect(image, layer.bounds);

CGContextSaveGState(ctx);
CGContextTranslateCTM(ctx, 0, layer.bounds.size.height);
CGContextScaleCTM(ctx, 1.0f, -1.0f);
CGContextDrawImage(ctx, layer.bounds, flipImage);
CGContextRestoreGState(ctx);
LogMessage(@"drawLayer", 1, @"draw layer content");
}


上面这番处理之后,图像中的一些线条边缘出现锯齿。
6652 次点击
所在节点    iDev
1 条回复
changx
2012-03-14 19:02:06 +08:00
补充一个我做过的尝试

CGContextSetShouldAntialias(ctx, YES);
CGContextSetAllowAntialiasing(ctx, YES);
CGContextSetInterpolationQuality(ctx, kCGInterpolationHigh);
CGContextDrawImage(ctx, layer.bounds, flipImage);

仍然有轻微锯齿,达不到原屏幕显示质量。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/29637

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX