MWPhotoBrowser 属性详解 和代理解释
--------0.MWPhoto简单属性解释----------------
MWPhoto *photo = [MWPhoto photoWithURL:[NSURL URLWithString:@"http://farm4.static.flickr.com/3629/3339128908_7aecabc34b.jpg"]];
photo.caption = @"在将photo添加到数组中时,可以在这里设置标题名字";
photo = [MWPhotophotoWithURL:[NSURLfileURLWithPath:[[NSBundlemainBundle]pathForResource:@"photo2"ofType:@"jpg"]]];
photo.caption =@"The London Eye is a giant Ferris wheel situated on the banks of the River Thames, in London, England.";
[photos addObject:photo];
效果图
==============================1.属性详解==========================
MWPhotoBrowser *browser = [[MWPhotoBrowseralloc]initWithDelegate:self];
//分享按钮,默认是
browser.displayActionButton =NO;
//底部是否分页切换导航,默认否
browser.displayNavArrows =NO;
////是否显示选择按钮在图片上,默认否
browser.displaySelectionButtons =YES;
//控制条件控件是否显示,默认否
browser.alwaysShowControls =NO;
//自动适用大小,默认是
browser.zoomPhotosToFill =YES;
//是否允许用网格查看所有图片,默认是
browser.enableGrid =NO;
////是否第一张,默认否
browser.startOnGrid =YES;
//是否开始对缩略图网格代替第一张照片
browser.enableSwipeToDismiss =NO;
//是否自动播放视频
browser.autoPlayOnAppear =NO;
//播放页码
[browser setCurrentPhotoIndex:0];
//自定义选择按钮的样式
//大图时显示选择按钮,(图片大小要和ImageSelectedOn图大小一致)
// browser.customImageSelectedIconName = @"选中";
//选择多图的时候,图片大小要和ImageSelectedSmallOn图大小一致)
// browser.customImageSelectedSmallIconName = @"选中";
[self.navigationControllerpushViewController:browseranimated:YES];
==============================2.代理方法解释==========================
/*****************************必须实现的代理方法********************************/
//有多少个图片要显示
- (NSUInteger)numberOfPhotosInPhotoBrowser:(MWPhotoBrowser *)photoBrowser {
returnself.photoesArray.count;
}
//在具体的index中,显示网络加载或者本地的某一个图片
- (id<MWPhoto>)photoBrowser:(MWPhotoBrowser *)photoBrowser
photoAtIndex:(NSUInteger)index {
if (index <self.photoesArray.count) {
return [self.photoesArrayobjectAtIndex:index];
}
returnnil;
}
图片效果图:
/*****************************可选实现的代理方法********************************/
//自定义标题
- (NSString *)photoBrowser:(MWPhotoBrowser *)photoBrowser
titleForPhotoAtIndex:(NSUInteger)index {
return [NSStringstringWithFormat:@"%lu/%lu", (unsignedlong)index,
(unsignedlong)self.photoesArray.count];
}
图片效果图:
//加载多张网络缩略图(enableGrid= YES)时,才可以实现该委托方法
- (id <MWPhoto>)photoBrowser:(MWPhotoBrowser *)photoBrowser thumbPhotoAtIndex:(NSUInteger)index{
if (index <self.photoesArray.count) {
return [self.photoesArrayobjectAtIndex:index];
}
returnnil;
}
效果图显示 1 和 2:
//自定义底部视图,继承MWCaptionView这个类,在子类中重写-setupCaption和 -sizeThatFits:,或者加视图。
- (MWCaptionView *)photoBrowser:(MWPhotoBrowser *)photoBrowser captionViewForPhotoAtIndex:(NSUInteger)index{
MWPhoto *photo = [self.photoesArrayobjectAtIndex:index];
MWCaptionView *captionView = [[MWCaptionViewalloc]initWithPhoto:photo];
// captionView.
return captionView;
}
效果视图:
//将displayActionButton(分享按钮)设置为YES时,这个方法才会触发。之前的分享动作就不会出现。
- (void)photoBrowser:(MWPhotoBrowser *)photoBrowser actionButtonPressedForPhotoAtIndex:(NSUInteger)index{
NSLog(@"content %lu",(unsignedlong)index);
}
效果图
//当前将要显示第几张
- (void)photoBrowser:(MWPhotoBrowser *)photoBrowser didDisplayPhotoAtIndex:(NSUInteger)index{
NSLog(@"content %lu",(unsignedlong)index);
}
效果图:
//设置将要显示的视图,是否被选或者没有被选,把它放到一个数组中。
- (BOOL)photoBrowser:(MWPhotoBrowser *)photoBrowser isPhotoSelectedAtIndex:(NSUInteger)index {
return [[_selectionsobjectAtIndex:index] boolValue];
}
//当前显示图片,选择按钮是否被选,或者没有被选,会触发这个方法
- (void)photoBrowser:(MWPhotoBrowser *)photoBrowser photoAtIndex:(NSUInteger)index selectedChanged:(BOOL)selected {
[_selectionsreplaceObjectAtIndex:index withObject:[NSNumbernumberWithBool:selected]];
NSLog(@"Photo at index %lu selected %@", (unsignedlong)index, selected ? @"YES" :@"NO");
}
////如果是modal出来的,必须手动dismiss掉
/*
当要modal出来的时候,需要使用包装上一个UINavigationController,它可以来管理多张图问题。
UINavigationController *nc = [[UINavigationController alloc] initWithRootViewController:browser];
nc.modalTransitionStyle = UIModalTransitionStyleCoverVertical;
[self presentViewController:nc animated:YES completion:nil];
*/
- (void)photoBrowserDidFinishModalPresentation:(MWPhotoBrowser *)photoBrowser{
[self dismissViewControllerAnimated:YES completion:nil];
}
MWPhotoBrowser 属性详解 和代理解释的更多相关文章
- OutputCache属性详解(二)一 Location
目录 OutputCache概念学习 OutputCache属性详解(一) OutputCache属性详解(二) OutputCache属性详解(三) OutputCache属性详解(四)— SqlD ...
- Android组件---四大布局的属性详解
[声明] 欢迎转载,但请保留文章原始出处→_→ 文章来源:http://www.cnblogs.com/smyhvae/p/4372222.html Android常见布局有下面几种: LinearL ...
- Android中的windowSoftInputMode属性详解
这篇文章主要介绍了Android中的windowSoftInputMode属性详解,本文对windowSoftInputMode的9个属性做了详细总结,需要的朋友可以参考下 在前面的一篇文章中 ...
- [转]CSS vertical-align属性详解 作者:黄映焜
CSS vertical-align属性详解 posted @ 2014-08-26 17:44 黄映焜 前言:关于vertical-align属性. 实践出真知. 垂直居中. 第二种用法. ...
- Linux文件权限与属性详解 之 SUID、SGID & SBIT
Linux文件权限与属性详解 之 一般权限 Linux文件权限与属性详解 之 ACL Linux文件权限与属性详解 之 SUID.SGID & SBIT Linux文件权限与属性详解 之 ch ...
- Linux文件权限与属性详解 之 一般权限
目录 一般属性 1. iNode: 3152621 2. 文件类型 3.文件访问权限 4. 链接数目: 5. 文件所有者 6. 文件所属组 7. 文件大小 8. 修改时间 9. 文件名称 Linux文 ...
- border-sizing属性详解和应用
box-sizing用于更改用于计算元素宽度和高度的默认的 CSS 盒子模型.它有content-box.border-box和inherit三种取值.inherit指的是从父元素继承box-sizi ...
- JavaScript对象的property属性详解
JavaScript对象的property属性详解:https://www.jb51.net/article/48594.htm JS原型与原型链终极详解_proto_.prototype及const ...
- css 14-CSS3属性详解:Web字体
14-CSS3属性详解:Web字体 #前言 开发人员可以为自已的网页指定特殊的字体(将指定字体提前下载到站点中),无需考虑用户电脑上是否安装了此特殊字体.从此,把特殊字体处理成图片的方式便成为了过去. ...
随机推荐
- Android 4.4 Fence在SurfaceFlinger中的应用
网上关于android.fence的资料好少啊.差点儿没有,可是这个机制又在GUI系统中起着关键的数据,于是自己通读源代码和凝视.与大家分享下Fence究竟是怎么回事? Fence即栅栏.栅栏的角色与 ...
- 基于SVM的数据分类预測——意大利葡萄酒种类识别
update:把程序源代码和数据集也附上http://download.csdn.net/detail/zjccoder/8832699 2015.6.24 --------------------- ...
- 想学android进来看看吧~ ~
我深知学校里面有非常多同学想学习新的知识,而苦于没有指导. 事实上我想说的是,非常多东西须要靠自己,须要借助度娘,谷歌的.当然有人指导是最好的了. 对于刚接触android是不是也想做出像以下的效果: ...
- POJ 3038 贪心(multiset)
题意: 思路: 1. 贪心 我们考虑肯定是走最近的最合适 想象自己是一个黑一日游的司机: 1.如果有乘客要上车,那么就让他上,收钱! 2.如果超载了,把距目的地最远的几个乘客踢下去,退钱. 3.行驶到 ...
- 分享一下事件监听addEventListener----attachEvent的用法
来自:http://www.cnblogs.com/wkylin/archive/2011/10/09/2203161.html 事件监听addEventListener----attachEvent ...
- NewtonSoft对象转json时,把 NULL 转 "" , 过滤 NULL, DateTime 时间类型去除 T
IsoDateTimeConverter timeConverter = new IsoDateTimeConverter(); timeConverter.DateTimeFormat = &quo ...
- 洛谷 P1881 绳子对折
P1881 绳子对折 题目描述 FJ 有一个长度为L(1<= L <= 10,000)的绳子. 这个绳子上有N(1 <= N <= 100)个结,包括两个端点. FJ想将绳子对 ...
- iOS 创建静态库文件时去掉当中的Symbols
在project中创建静态库文件时.默认会将一些Symbols加到静态库文件里.这样做有两个缺点: 1.假设引用静态库文件的project中发生了bug.就会直接跳转到静态库的源代码. 也许有人问:静 ...
- 自己定义控件的onMeasure方法具体解释
在我们自己定义控件的时候可能你会用到onMeasure方法,以下就具体的给大家介绍一下这种方法: @Override protected void onMeasure(int widthMeasure ...
- Android Cordova 插件开发之编写自己定义插件
前言 本文适合Android+web的复合型人才,由于cordova本身就是混合开发,所以在Android开发的基础上,还要懂web相关技术(HTML+CSS+JS).可是也有例外,比方我.仅仅需负责 ...