欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

iOS实现图片轮播效果

程序员文章站 2023-11-04 13:02:52
本文实例为大家分享了ios图片轮播效果的实现过程,供大家参考,具体内容如下 平时app中的广告位或者滚动的新闻图片等用到的就是图片轮播这种效果,实现方式主要有两种,一种s...

本文实例为大家分享了ios图片轮播效果的实现过程,供大家参考,具体内容如下

平时app中的广告位或者滚动的新闻图片等用到的就是图片轮播这种效果,实现方式主要有两种,一种scrollview+imageview,另一种则是通过collectionview,今天总结的是scrollview这种方式。

1.图片轮播效果实现

主要实现思路是:根据图片总数及宽高设置好scrollview的大小,每切换一张图片相当于在scrollview上进行一个图片宽度的移动行为,并加入定时器,实现自动轮播。

如图所示,设置好scrollview及pagecontrol,scrollview的contentsize根据图片数量确定,注意启用pagingenabled这个属性,确保整页移动,同样pagecontrol也是根据图片数量来确定,每一页代表一张图片。

iOS实现图片轮播效果

图片命名采用数字序号方式,方便使用,需要注意的是,pagecontrol是由0开始的,也就是0对应image1,1对应image2...依次类推

iOS实现图片轮播效果

加载图片并将准备好的图片在scrollview里设置好位置,即将这些图片一张紧挨着一张排列在scrollview中。

iOS实现图片轮播效果

通过scrollview的代理方法,在scrollview滚动结束的时候根据contentoffset更新页码。

iOS实现图片轮播效果

定时器设置,这里设置为每隔2秒滚动更新一次,实际上就是每隔2秒更新一次页码,根据页码的变化,让scrollview跟着移动,每次移动一张图片的距离

iOS实现图片轮播效果

这里还需要注意的是,由于加入定时器有自动轮播的效果了,会与手动拖拽scrollview冲突,即手动拖拽scrollview过程时scrollview可能自动移动更新图片了,显然这种效果是不符合用户习惯的,这时需要在scrollview的代理事件中进行处理,即开始拖拽scrollview时停止定时器,拖拽结束后再开启定时器。

iOS实现图片轮播效果

那到这里是不是就结束了呢?我们看看效果图:

iOS实现图片轮播效果

这里有两个问题:

(1)首先是移动到最后一张图片时无法移动了,如果是制作app的新特性页面,这样的滚动效果已经可以了,但如果在广告位或者是滚动新闻这些场景下这种效果是不够好的,一般滚动到最后一张图片时,继续拖拽都会移动到第一张图片,实现一种滚动循环效果。

(2)定时器自动轮播图片时,确实图片循环轮播了,但是仔细看会发现,scrollview是由最后一种图片位置生硬得拉回到第一张图片的位置,效果也不够理想。

解决办法,小编先留个悬念,在下面的一篇文章中会进行解答,不要错过。