日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Swift-ScrollView轮播图的简易封装和使用

發布時間:2023/12/14 编程问答 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Swift-ScrollView轮播图的简易封装和使用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

不多說,輪播圖是開發中必要一項技能,直接上代碼:

先說我的思路:首次繼承于UIScrollView類自定義MyScrollView,在MyScrollView里自定制方法,func creatMyScrollView(imageName:[String],height:CGFloat)在里面完成動態布局,通過傳入的兩個參數imageName,height來制作輪播圖的圖片和高度,設置contentSize屬性和pagingEnabled屬性,上代碼:

首先繼承于UIScrollView自定義MyScrollView類

class ZYF_MyScrollView: UIScrollView {}

自定義方法

scrollView的輪播就是利用其偏移量來進行設置,如果實現n張圖片自動輪播,創建計時器是必須的,在scrollView中創建n+1張圖片,容量也是n+1張圖片的容量。讓第1張和最后一張是同一張圖片,在偏移量達到n*width的時候,讓偏移量置零,這樣,在即將顯示最后一張圖的時候,scrollView的展示圖片瞬間變成第一張,然后繼續往后播。這樣形成了我們常見的輪播效果

class ZYF_MyScrollView: UIScrollView {func creatMyScrollView(imageName:[String],height:CGFloat) {//動態布局for i in 0...(imageName.count - 1) {let imageView = UIImageView(frame: CGRectMake(CGFloat(i) * width,0,width,height))self.addSubview(imageView)//設置輪播圖圖片imageView.image = UIImage(named: imageName[i])}//設置輪播圖容量self.contentSize = CGSizeMake(CGFloat(imageName.count ) * width, height)//設置吸附屬性self.bounces = false//設置書頁效果self.pagingEnabled = true//單獨創建第n+1張輪播圖,和第一張圖片是同一張圖let imageView = UIImageView(frame:CGRectMake(CGFloat(imageName.count) * width, 0, width, height))imageView.image = UIImage(named:imageName[0])self.addSubview(imageView)} }

這樣就算是簡單的封裝了一下,使用方法如下:

在你要放置的輪播圖的.swift文件中生成 ZYF_MyScrollView的對象

let scr = ZYF_MyScrollView()

創建圖片名稱數組

let iamgeNames = ["App公測","簡書出版","簡書官方專題","簡書月刊","簡書出版","簡書官方專題"]

調用creatUI方法,傳入圖片名稱數組,設置高度

func creatScrollView() {let view = UIView(frame: CGRectMake(0,0,UIScreen.mainScreen.bounds.size.width,280))scr.creatUI(imageNames,height:200)view.addSubView(scr) }

到此,一個能夠拖動的輪播圖就制作結束了,實現自動輪播,下面我們需要借助計時器NSTimer

創建NSTimer

//創建輪播圖定時器func creatTimer() {let timer = NSTimer.scheduledTimerWithTimeInterval(3, target: self, selector: #selector(self.timerManager), userInfo: nil, repeats: true)//這句話實現多線程,如果你的ScrollView是作為TableView的headerView的話,在拖動tableView的時候讓輪播圖仍然能輪播就需要用到這句話NSRunLoop.currentRunLoop().addTimer(timer, forMode: NSRunLoopCommonModes)}//創建定時器管理者func timerManager() {//設置偏移量scr.setContentOffset(CGPointMake(scr.contentOffset.x + width, 0), animated: true)//當偏移量達到最后一張的時候,讓偏移量置零if scr.contentOffset.x == CGFloat(width) * CGFloat(imageNames.count) {scr.contentOffset = CGPointMake(0, 0)}}

到此,自動輪播圖制作完畢,在使用中還缺少了一個組件,就是小白點UIPageControl,回到func creatScrollView(){}中

func creatScrollView() {let view = let view = UIView(frame: CGRectMake(0,0,UIScreen.mainScreen.bounds.size.width,280))scr.creatUI(imageNames,height:200)`view.addSubView(scr)let page = UIPageControl()page.frame = CGRectMake(width / 2 - 50,160,100,30)page.numberOfPages = imageNames.count//將小白點放到scr之上view.insertSubview(page, aboveSubview: scr) }

遵守UIScrollViewDelegate協議,設置小白點的跟隨輪動

//當手動滾動視圖翻頁時調用該方法var cnt = 0func scrollViewDidEndDecelerating(scrollView: UIScrollView) {let cPage = scr.contentOffset.x / widthpage.currentPage = Int(cPage)cnt = Int(cPage)}//自動播放時,調用該方法func scrollViewDidEndScrollingAnimation(scrollView: UIScrollView) {cnt += 1page.currentPage = cnt % imageNames.count}

到此,全部工程就完成了

效果如下

總結

以上是生活随笔為你收集整理的Swift-ScrollView轮播图的简易封装和使用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。