iOS图片处理1---CGImageRef基本概念

最近遇到一个问题,需要对相机拍摄完的照片进行处理,达到一定的标准。所以研究一下图片、位图、像素这些,也找到了一些文章,研究学习一下。

一、位图基本概念---CGImageRef

CGImageRef是定义在QuartzCore框架中的一个结构体指针,用C语言编写。

    typedef struct CGImage *CGImageRef;

CGImageRef ,这个结构用来创建像素位图,可以通过操作存储的像素位来编辑图片。

二、CGImageRef的部分方法和属性

2.1、CFTypeID
  CGImageGetTypeID(void)

这个方法返回的是一个编号,每个Core Foundation框架中得结构都会有一个这样的编号;这个方法没有特殊的意义,只是一个标识符

2.2、CGImageRef,其中加粗字体为比较常用的方法
CGImageCreate(size_t width, size_t height,size_t bitsPerComponent, size_t bitsPerPixel, size_t bytesPerRow,CGColorSpaceRef space, CGBitmapInfo bitmapInfo, CGDataProviderRef provider,const CGFloat decode[], bool shouldInterpolate,CGColorRenderingIntent intent);

通过CGImageCreate方法,我们可以创建出一个CGImageRef类型的对象,下面分别对参数进行解释:

sizt_t是定义的一个可移植性的单位,在64位机器中为8字节,32位位4字节。
width:图片宽度像素
height:图片高度像素
bitsPerComponent:每个颜色的比特数,例如在rgba-32模式下为8
bitsPerPixel:每个像素的总比特数
bytesPerRow:每一行占用的字节数,注意这里的单位是字节
space:颜色空间模式,例如const CFStringRef kCGColorSpaceGenericRGB 这个函数可以返回一个颜色空间对象。
bitmapInfo:位图像素布局,这是个枚举
provider:数据源提供者
decode[]:解码渲染数组
shouldInterpolate:是否抗锯齿
intent:图片相关参数

 CGImageMaskCreate(size_t width, size_t height,size_t bitsPerComponent, size_t bitsPerPixel, size_t bytesPerRow, CGDataProviderRef provider, const CGFloat decode[], bool shouldInterpolate)

CGImageMaskCreate方法用于创建mask图片图层,可以设置其显示部分与不显示部分达到特殊的效果,参数意义同上。

 CGImageCreateCopy(CGImageRef image)

这个方法可以复制一个CGImageRef对象

CGImageCreateWithJPEGDataProvider(CGDataProviderRef source, const CGFloat decode[], bool shouldInterpolate,CGColorRenderingIntent intent)

通过JPEG数据源获取图像

CGImageCreateWithPNGDataProvider(CGDataProviderRef source,const CGFloat decode[], bool shouldInterpolate,CGColorRenderingIntent intent)

通过PNG数据源获取图像

CGImageCreateWithImageInRect(CGImageRef image,CGRect rect)

截取图像的一个区域重绘图像

CGImageCreateWithMask(CGImageRef image, CGImageRef mask)

截取mask图像的某一区域重绘

CGImageCreateWithMaskingColors(CGImageRef image,const CGFloat components[])

通过颜色分量数组创建位图

CGImageCreateCopyWithColorSpace(CGImageRef image,CGColorSpaceRef space)

通过颜色空间模式复制位图

CGImageRetain(CGImageRef image)//引用+1
void CGImageRelease(CGImageRef image)//引用-1
bool CGImageIsMask(CGImageRef image)//返回是否为Mask图层

下面这些方法分别获取相应属性---宽度和高度获取是比较常用的!

size_t   CGImageGetWidth(CGImageRef image)//**获取宽度像素**
size_t   CGImageGetHeight(CGImageRef image)//**获取高度像素**
size_t   CGImageGetBitsPerComponent(CGImageRef image)
size_t   CGImageGetBitsPerPixel(CGImageRef image)
size_t   CGImageGetBytesPerRow(CGImageRef image)
CGColorSpaceRef   CGImageGetColorSpace(CGImageRef image)
CG_EXTERN CGImageAlphaInfo CGImageGetAlphaInfo(CGImageRef image)
CGDataProviderRef CGImageGetDataProvider(CGImageRef image)
const CGFloat *CGImageGetDecode(CGImageRef image)
bool CGImageGetShouldInterpolate(CGImageRef image)
CGColorRenderingIntent CGImageGetRenderingIntent(CGImageRef image)
CGBitmapInfo CGImageGetBitmapInfo(CGImageRef image)

三、应用举例

使用CGImageRef进行图片截取

//原图片
UIImage * img = [UIImage imageNamed:@"11.11.52.png"];
//转化为位图
CGImageRef temImg = img.CGImage;
//根据范围截图
temImg=CGImageCreateWithImageInRect(temImg, CGRectMake(0, 0, 100, 100));
//得到新的图片
UIImage *new = [UIImage imageWithCGImage:temImg];
//释放位图对象
CGImageRelease(temImg);

注意:最后必须要调用这个函数,否则会造成内存泄露

 CGImageRelease(temImg)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342

推荐阅读更多精彩内容