MWPhotoBrowser的使用,及注意事项

MWPhotoBrowser

地址:https://github.com/mwaterfall/MWPhotoBrowser

一款可以加载web Image对象的图片游览器,下面介绍它的使用。

1.简单使用总共分两步:

(1) 创建MWPhotoBrowser

要使用initWithDelegate方法,要遵循MWPhotoBrowserDelegate协议

    //创建MWPhotoBrowser ,要使用initWithDelegate方法,要遵循MWPhotoBrowserDelegate协议

    MWPhotoBrowser *browser = [[MWPhotoBrowser alloc] initWithDelegate:self];

    //设置当前要显示的图片

    [browser setCurrentPhotoIndex:indexPath.item];

    //push到MWPhotoBrowser

    [self.navigationController pushViewController:browser animated:YES];

(2) 实现代理

//返回图片个数

    - (NSUInteger)numberOfPhotosInPhotoBrowser:(MWPhotoBrowser *)photoBrowser{

            return count;

    }

//返回图片模型

    - (id )photoBrowser:(MWPhotoBrowser *)photoBrowser photoAtIndex:(NSUInteger)index{

            //创建图片模型

           MWPhoto *photo = [MWPhoto photoWithURL:photoUrl];  

           return photo;

    }

2.使用时的注意五个点:

(1) 数据源问题:

self.photos = imageArray;            //此处需要注意的是,self.photos  存放的都是MWPhoto 对象,需要把image 和webUrl ,调用如下几个方法,转成MWPhoto 。。如 :

MWPhoto *photo, *thumb;photo = [MWPhoto photoWithImage:image]; 。。。photo = [MWPhoto photoWithImage:image(httpUrl)];

photo.caption = @"此处设置图片标题,显示在屏幕下方";

方法还有:

+ (MWPhoto *)photoWithImage:(UIImage *)image;                                                                 //加载的image对象

+ (MWPhoto *)photoWithURL:(NSURL *)url;                                                                              //加载请求web获得的图片

+ (MWPhoto *)photoWithAsset:(PHAsset *)asset targetSize:(CGSize)targetSize;                     //加载相册图片对象

+ (MWPhoto *)videoWithURL:(NSURL *)url; // Initialise video with no poster image               //加载视频对象

在使用的时候每次加载。。会将  image对象,获取web请求的图片。。转换成它自己的模型(MWPhoto)

(2) 自定义photoBrowser的UI

MWPhotoBrowser  *browser = [[MWPhotoBrowser alloc]initWithDelegate:self];

browser.displayActionButton =NO;//分享按钮,默认是

browser.displayNavArrows = NO;//左右分页切换,默认否<屏幕下方的左右角标>

browser.displaySelectionButtons = NO;//是否显示选择按钮在图片上,默认否

browser.alwaysShowControls = NO;//控制条件控件 是否显示,默认否

browser.zoomPhotosToFill = NO;//是否全屏,默认是

browser.enableGrid = NO;//是否允许用网格查看所有图片,默认是

browser.enableSwipeToDismiss = NO;

[browser showNextPhotoAnimated:YES];

[browser showPreviousPhotoAnimated:YES];

[browser setCurrentPhotoIndex:0];

[Controller.navigationController pushViewController:browser animated:NO];

(3) 代理方法  这两个必须要实现

- (NSUInteger)numberOfPhotosInPhotoBrowser:(MWPhotoBrowser *)photoBrowser;

- (id )photoBrowser:(MWPhotoBrowser *)photoBrowser photoAtIndex:(NSUInteger)index;

(4)附加了好几个其他第三方库,注意项目中三方库的冲突

1 DACirculaProgress

2 MBProgressHUD

3 SDWebImage

(5)关于内部SDWebImage加载大图而导致的内存警告问题:

因为SDWebImage加载图片是没有做瘦身处理的,所以自己加,共3步(本方法也适用其他用SDWebImage内存过大而又不想全部清空内存问题)

首先,在SDWebImage子目录文件UIImage+MultiFormat添加一个方法:

//压缩图片(找到对应位置,直接粘)

+(UIImage *)compressImageWith:(UIImage *)image{

    float imageWidth = image.size.width;

    float imageHeight = image.size.height;

    float width = 640;

    float height = image.size.height/(image.size.width/width);

    float widthScale = imageWidth /width;

    float heightScale = imageHeight /height;

    // 创建一个bitmap的context// 并把它设置成为当前正在使用的            contextUIGraphicsBeginImageContext(CGSizeMake(width, height));

    if (widthScale > heightScale) {[image drawInRect:CGRectMake(0, 0, imageWidth /heightScale , height)];}

    else {[image drawInRect:CGRectMake(0, 0, width , imageHeight /widthScale)];}

    // 从当前context中创建一个改变大小后的图片

    UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext();

    // 使当前的context出堆栈

    UIGraphicsEndImageContext();

    return newImage;

}

然后,在+ (UIImage *)sd_imageWithData:(NSData *)data方法内找到image = [[UIImage alloc] initWithData:data],在此行代码下面添加代码如下:

if (data.length/1024 > 1024) {image = [self compressImageWith:image];}

最后,当data大于1M的时候做压缩处理。革命尚未成功,还需要一步处理。在SDWebImageDownloaderOperation的connectionDidFinishLoading方法里面的:

UIImage *image = [UIImage sd_imageWithData:self.imageData];

//将等比压缩过的image在赋在转成data赋给self.imageDataNSData *data = UIImageJPEGRepresentation(image, 1);self.imageData = [NSMutableData dataWithData:data];

注意:此处更改后,项目中用到SDWebImage都会随着更改.

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

推荐阅读更多精彩内容

  • 写iOS 程序的时候往往需要很多第三方框架的支持,可以大大减少工作量,讲重点放在软件本身的逻辑实现上。 GitHu...
    iOS_大菜鸟阅读 858评论 1 2
  • 1. Mantle Mantle 让我们能简化 Cocoa 和 Cocoa Touch 应用的 model 层。简...
    我是世界微小的存在阅读 582评论 0 1
  • 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥iOS动画全貌。在这里你可以看...
    F麦子阅读 5,111评论 5 13
  • 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥ios动画全貌。在这里你可以看...
    每天刷两次牙阅读 8,489评论 6 30
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,103评论 4 62