<code>// 文字计算
[@"text" boundingRectWithSize:CGSizeMake(100, MAXFLOAT) options:NSStringDrawingUsesLineFragmentOrigin attributes:nil context:nil];
// 文字绘制
[@"text" drawWithRect:CGRectMake(0, 0, 100, 100) options:NSStringDrawingUsesLineFragmentOrigin attributes:nil context:nil];
/<code>
- 图片处理(解码、绘制)
图片处理(解码、绘制)我们一般都会用imageView.image = [UIImage imageNamed:@"***"];这种方式来获取图片,但这种方式是系统负责解码,而系统解码默认又是在主线程所以如果你的图片数据很大的时候就可能阻塞主线程从而造成卡顿,所以我们一般都是提前解码并且在子线程里进行,这样主线程就少了解码的操作到时候直接把解码的图片数据拿来用就好了,其实我们现在用的一些第三方图片处理库都有异步解码的功能了,我们来看一个例子(也是从三方库里拷贝过来的)代码有点多,其实核心步骤就是:获取到图片的CGImage解码(解码的步骤就是)2.1 创建位图上下文2.2 把cgImage draw到上下文里,这样就完成了解码操作从上下文里获取刚解码过的图片最好再把解码过的图片包装成UIImage回到主线程的时候我们直接用解码过的图片就OK了(这样解码的操作都是在子线程里做的并不会阻塞主线程)
下面我们来看看具体的代码实现 :
<code>- (void)image
{
UIImageView *imageView = [[UIImageView alloc] init];
imageView.frame = CGRectMake(100, 100, 100, 56);
[self.view addSubview:imageView];
self.imageView = imageView;
dispatch_async(dispatch_get_global_queue(0, 0), ^{
// 获取CGImage
CGImageRef cgImage = [UIImage imageNamed:@"***"].CGImage;
// alphaInfo
CGImageAlphaInfo alphaInfo = CGImageGetAlphaInfo(cgImage) & kCGBitmapAlphaInfoMask;
BOOL hasAlpha = NO;
if (alphaInfo == kCGImageAlphaPremultipliedLast ||
alphaInfo == kCGImageAlphaPremultipliedFirst ||
alphaInfo == kCGImageAlphaLast ||
alphaInfo == kCGImageAlphaFirst) {
hasAlpha = YES;
}
// bitmapInfo
CGBitmapInfo bitmapInfo = kCGBitmapByteOrder32Host;
bitmapInfo |= hasAlpha ? kCGImageAlphaPremultipliedFirst : kCGImageAlphaNoneSkipFirst;
// size
size_t width = CGImageGetWidth(cgImage);
size_t height = CGImageGetHeight(cgImage);
// context
CGContextRef context = CGBitmapContextCreate(NULL, width, height, 8, 0, CGColorSpaceCreateDeviceRGB(), bitmapInfo);
// draw
CGContextDrawImage(context, CGRectMake(0, 0, width, height), cgImage);
// get CGImage
cgImage = CGBitmapContextCreateImage(context);
// into UIImage
UIImage *newImage = [UIImage imageWithCGImage:cgImage];
// release
CGContextRelease(context);
CGImageRelease(cgImage);
// back to the main thread
dispatch_async(dispatch_get_main_queue(), ^{
self.imageView.image = newImage;
});
});
}
/<code>
閱讀更多 新新猿類 的文章