01.轮播图之一 :scrollView 轮播
接触的每个项目,都会用到轮播图的部分,轮播图都写了好多次,用过各种各样的方式写:
这篇总结的博客,我将分为几个篇幅写,希望写完这几篇博客之后,我能总结出自己写这个轮播的优缺和不同之处
- scrollview 制作轮播
- tableview 制作轮播
- collectionview 制作轮播
- 三个imageview 制作轮播,两个imageView 制作轮播
- 一个imageView 制作轮播
- 设计轮播计时器 和 总结代码的优缺点(希望顺利写到这篇博客)
介绍完篇幅了,现在进入本篇的主题,用scrollview 制作 轮播;
使用的还是那个很老套的思路,就是填补最初一张和最后一张 图片,向后滚动到最后一张的时候,设置成第二张的,向左滚动到第一张的时候,
设置成倒数第二张;逻辑图 就是这样了:::::
2 | 0 | 1 | 2 | 0 |
总之就是这样的吧:
顺利的谱写代码--- 写代码的艺术家 v^v
1.创建一个view 作为轮播图封装 ----ScrollViewShuffling
@interface ScrollViewShuffling : UIView
// 这个是滚动视图 传入的数组
@property (nonatomic,strong)NSArray *array; @end
下面就是具体实现了,重中之重:::::::
@interface ScrollViewShuffling ()<UIScrollViewDelegate> @property (nonatomic,strong)UIScrollView *scrollView;
@property (nonatomic,strong)NSMutableArray *scrollArray; @end @implementation ScrollViewShuffling
@synthesize array = _array; -(instancetype)initWithFrame:(CGRect)frame{ if (self == [super initWithFrame:frame]) {
}
return self;
} -(UIScrollView*)scrollView{ if (_scrollView == nil) {
CGRect scrollRect = CGRectMake(, , self.frame.size.width, self.frame.size.height);
_scrollView = [[UIScrollView alloc]initWithFrame:scrollRect];
[self addSubview:_scrollView];
_scrollView.pagingEnabled = YES;
_scrollView.delegate = self;
}
return _scrollView;
} -(void)setArray:(NSArray *)array{ NSAssert(array.count != , @"传入的滚动数组是 空的");
_array = array;
[self prepareData];
[self initImageViews];
} -(void)prepareData{ self.scrollArray = [NSMutableArray new];
// 首位 添加数组最后的元素
[self.scrollArray addObject:_array.lastObject];
// 添加数组元素
[self.scrollArray addObjectsFromArray:_array];
// 末尾 补充第一个元素
[self.scrollArray addObject:_array.firstObject];
} -(void)initImageViews{ self.scrollView.contentSize = CGSizeMake(self.scrollArray.count *self.frame.size.width, );
self.scrollView.contentOffset = CGPointMake(self.frame.size.width, ) ; for (int index = ; index < self.scrollArray.count; index++) { CGRect imageRect = CGRectMake(index*self.frame.size.width, , self.frame.size.width, self.frame.size.height);
UIImageView *imageView = [[UIImageView alloc]initWithFrame:imageRect];
// imageView.image =
imageView.backgroundColor = (UIColor*)self.scrollArray[index];
[self.scrollView addSubview:imageView];
}
} -(void)scrollViewDidScroll:(UIScrollView *)scrollView{ if (scrollView == self.scrollView) {
//检测移动的位移
if (scrollView.contentOffset.x == (self.scrollArray.count-) * self.frame.size.width ) { CGPoint startPoint = CGPointMake(self.frame.size.width, );
[self.scrollView setContentOffset:startPoint animated:false]; }else if (scrollView.contentOffset.x == ){ CGPoint endPoint = CGPointMake((self.scrollArray.count-) * self.frame.size.width,);
[self.scrollView setContentOffset:endPoint animated:false];
}else{
// 正常的滚动
}
}
}
现在实现了滚动的基本功能。
- 一定要设置scollview 的contensize和 contentoffset
- 设置scollview 的代理
- 数组asset 这个是考虑传空值,才加入的,如果有更好的方法,可以换掉吧
外界调用::::
/*
引入头文件
创建 + 赋值
*/
-(void)prepareScrollShuffling{ ScrollViewShuffling *scrollShuffling = [[ScrollViewShuffling alloc]initWithFrame:CGRectMake(, , self.view.frame.size.width-, )]; [self.view addSubview:scrollShuffling];;
scrollShuffling.array = self.arr;
}
scollview 就先写到这里好了,待续………………
01.轮播图之一 :scrollView 轮播的更多相关文章
- Android开发工程师文集-Fragment,适配器,轮播图,ScrollView,Gallery 图片浏览器,Android常用布局样式
Android开发工程师文集-Fragment,适配器,轮播图,ScrollView,Gallery 图片浏览器,Android常用布局样式 Fragment FragmentManager frag ...
- swiper轮播问题之一:轮播图内容为动态数据生成时轮播图无法自动轮播
本人在用H5做移动端项目中使用Swiper遇到的两个问题,因此加深了对Swiper的掌握,分享出来对刚开始接触Swiper的童鞋们或多或少会有帮助. 首先,new Swiper的初始化最 ...
- vue-music 使用better-scroll遇到轮播图不能自动轮播
根据vue-music视频中slider组建的使用,当安装新版本的better-scroll,轮播组件,不能正常轮播 这是因为,better-scroll发布新版本之后,参数设置发生改变 这是旧版本: ...
- 焦点轮播图(tab轮播)
主要有两部分:1.列表导航(小图片) 2.展示区(大图片) 页面布局: HTML部分: <div class="s_conC"> ...
- swiper手滑动轮播图后自动轮播失效解决办法
设置autoplay:true之后,再设置 autoplay:{disableOnInteraction: false} --------------------------------------- ...
- Android开发进程0.1 轮播图 Scrollview Fragment
轮播图的实现 轮播图通过banner可以较为便捷的实现 1.添加本地依赖,在dependence中搜索相关依赖 2.添加banner的view组件 3.创建适配器GlideImageLoader ex ...
- iOS回顾笔记(05) -- 手把手教你封装一个广告轮播图框架
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,bi ...
- iOS中 轮播图放哪最合适? 技术分享
我们知道,轮播图放在cell或collectionViewCell上会影响用户层级交互事件,并且实现起来比较麻烦,现在推出一个技术点:答题思路是:将UIScrollView放在UIView或UICol ...
- Swift-ScrollView轮播图的简易封装和使用
不多说,轮播图是开发中必要一项技能,直接上代码: 先说我的思路:首次继承于UIScrollView类自定义MyScrollView,在MyScrollView里自定制方法,func creatMySc ...
- JavaScript--缓动动画+轮播图
上效果: 实现步骤: 最重要的是运动公式!!! <!DOCTYPE html> <html> <head> <meta charset="UTF-8 ...
随机推荐
- 多继承以及MRO顺序
class A: def test(self): print("A --- test方法") def demo(self): print("A --- demo方法&qu ...
- ubuntu下新立得(synaptic)软件包管理器安装
1.从ubuntu下的软件中心(面板主页中输入soft即可找到)搜索安装synaptic后,打开新立得一闪就自动关了.解决办法为: 1.1命令行下卸载,命令行下重新安装: 卸载: #purge表示卸载 ...
- 突然萌发关于 redis 的想法(1)
本来昨天就打算写这篇了,但是熬到忘了,至于为什么要写这个是因为我昨天在写 redis 的时候突然想到的 注:此篇文章并没有讲解 redis 内部的使用 或 如何使用redis写代码,等等..仅仅只是突 ...
- 题解 [51nod1340]地铁环线
题解 [51nod1340]地铁环线 题面 解析 本文参考这篇博客 一开始看到只有120行就打算写一写, 结果一刚就是三个星期摆摆摆 本来是当查分约束入门学的. step 1 首先来考虑下如果已知总长 ...
- Python解释器安装问题-windows
问题一-更新问题(update your machine) 解决方案 1 搜索 windows update 2 检查更新 3 安装更新重启 问题二-0x80072efd错误 问题原因: 安装包需要在 ...
- 分治FFT学习笔记
用途 在\(O(n\log^2 n)\)的时间内做诸如 \[ f_n=\sum_{i=0}^{n-1} f_ig_{n-i} \] 或是 \[ f_n=\sum_{i=0}^{n-1} f_if_{n ...
- [Shell]CVE-2017-8464漏洞复现
0x01 漏洞原理 Windows系统通过解析 .LNK 后缀文件时,是使用二进制来解析的,而当恶意的二进制代码被系统识别执行的时候就可以实现远程代码执行,由于是在explorer.exe进程中运行的 ...
- 在开发iOS程序时对日期处理的总结
小贴士(Tips)-iOS 由于iOS的设备对应多国语言,用户也可以选择不同的日历模式.比如日本的和历,泰国日历等等. 用户也可以自行设定24小时制或者12小时制来显示时间.这些设置会直接影响应用程序 ...
- Mininet系列实验(五):Mininet设置带宽之简单性能测试
1.实验目的 该实验通过Mininet学习python自定义拓扑实现,可在python脚本文件中设计任意想要的拓扑,简单方便,并通过设置交换机和主机之间链路的带宽.延迟及丢包率,测试主机之间的性能.在 ...
- Python 自学笔记(六)
PK小游戏 1.要有玩家敌人:那就是需要定义两个角色的属性变量 2.相互攻击:需要两个角色都有血量和攻击的变量(也就是四个变量) 3.攻击减少血量:比如玩家血量=敌人攻击力-玩家当前血量 4.最终胜负 ...