图片选择常用的框架总结:

  1. 前段时间负责公司图片上传的的工作,现在已经做完了,总结下,方便以后使用。首先了解图片选择的框架:为了符合设计要求,本人最终选择了TZImagePickerController框架。
1. TZImagePickerController - 一个支持多选、选原图和视频的图片选择器,同时有预览功能,适配了iOS6789系统。
2. JFImagePickerController - vvebo作者:多选照片、预览已选照片、针对超大图片优化。
3. AGImagePickerController - 是一个图片选择器,支持图片多选,支持大图横滑预览,支持放大预览,支持横竖屏,支持所有的iOS设备。
4. QBImagePickerController - 这是一个首先进入相册列表,然后进行选择图片的框架,支持的功能不是很多。
5. AJPhotoPicker 是基于AssetsLibrary、UICollectionView、Masonry 支持 视频、图片选择,同时支持多选、滑动多选、预览等功能的框架。
6. OGImagePickerController 一款基于TZImagePickerController 在封装的图片选择框架。
7. DLCImagePickerController 等
  1. 框架回调返回的有ALAset PHAset 或者直接返回UIImage的数组,所以ALASet 如何转换为UIImage 或者 转换为NSData 类型呢,那么就需要了解下面知识:
    <pre>
    UIImage* ni = [UIImage imageNamed:@"new.png"];
    //修改指定路径的图片资源内容,替换掉原来的内容
    [asset setImageData:UIImageJPEGRepresentation(ni, 1.0) metadata:nil completionBlock:^(NSURL *assetURL, NSError error) {
    NSLog(@"new:%@",assetURL);
    }];
    //根据给定的图片内容,重新生成一张新图
    [asset writeModifiedImageDataToSavedPhotosAlbum:UIImageJPEGRepresentation(ni, 1.0) metadata:nil completionBlock:^(NSURL assetURL, NSError error) {
    NSLog(@"new:%@",assetURL);
    }];
    //获取资源图片的详细资源信息
    ALAssetRepresentation
    representation = [asset defaultRepresentation];
    //获取资源图片的长宽
    CGSize dimension = [representation dimensions];
    //获取资源图片的高清图
    [representation fullResolutionImage];
    //获取资源图片的全屏图
    [representation fullScreenImage];
    //获取资源图片的名字
    NSString
    filename = [representation filename];
    NSLog(@"filename:%@",filename);
    //缩放倍数
    [representation scale];
    //图片资源容量大小
    [representation size];
    //图片资源原数据
    [representation metadata];
    //旋转方向
    [representation orientation];
    //资源图片url地址,该地址和ALAsset通过ALAssetPropertyAssetURL获取的url地址是一样的
    NSURL
    url = [representation url];
    NSLog(@"url:%@",url);
    //资源图片uti,唯一标示符
    NSLog(@"uti:%@",[representation UTI]);
    </pre>
  2. UIImage的两种读取图片数据的方法:
    <pre>
    1、UIImageJPEGRepresentation这个是读取UIImage的JPEG格式的数据
    2、UIImagePNGRepresentation.这个是读取UIImage的PNG格式的数据
    </pre>
    UIImageJPEGRepresentation的方法需要两个参数:UIImage和压缩系数.而UIImagePNGRepresentation只需要UIImage作为参数,比较了两个方法发现: UIImagePNGRepresentation(UIImage* image) 要比UIImageJPEGRepresentation(UIImage* image, 1.0) 返回的图片的大小要大很多,同时,1.0 是图片质量参数比例,改的比较小的话,会减小图片所占用的内存开销。
  3. 等比例压缩图片的方法, 只要传入一张图片,然后在传入想要的尺寸,就会返回对应的图片。
    <pre> + (UIImage *)compressImage:(UIImage )image size:(CGSize)size{
    UIImage newImage = nil;
    CGSize originalsize = image.size;
    CGFloat originalWidth = originalsize.width;
    CGFloat originalHeight = originalsize.height;
    if ((originalWidth < size.width) && (originalHeight < size.height)) {
    newImage = image;
    }else {
    CGFloat scale =(float)size.width/originalWidth < (float)size.height/originalHeight ? (float)size.width/originalWidth : (float)size.height/originalHeight;
    NSLog(@"%f",scale);
    CGSize newImageSize = CGSizeMake(originalWidth
    scale , originalHeight
    scale); UIGraphicsBeginImageContextWithOptions(CGSizeMake(newImageSize.width, newImageSize.height), NO, 0);
    [image drawInRect:CGRectMake(0, 0, newImageSize.width, newImageSize.height)];
    newImage = UIGraphicsGetImageFromCurrentImageContext();
    UIGraphicsEndImageContext();
    }
    return newImage;
    }
    </pre>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,793评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,567评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,342评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,825评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,814评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,680评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,033评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,687评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,175评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,668评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,775评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,419评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,020评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,206评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,092评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,510评论 2 343

推荐阅读更多精彩内容