国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Swift > 正文

swift實(shí)現(xiàn)自動輪播圖效果(UIScrollView+UIPageControl+Timer)

2020-03-09 17:44:10
字體:
供稿:網(wǎng)友

本文實(shí)例為大家分享了swift實(shí)現(xiàn)自動輪播圖效果的具體代碼,供大家參考,具體內(nèi)容如下

比較簡單,原理就不說了,這里只做記錄:

代碼如下:

1、準(zhǔn)備

var pageControl:UIPageControl?  var myscrollView:UIScrollView?  var myTimer:Timer?  var mycurrentPage:NSInteger?      var courses = [    ["name":"first","pic":"1.jpeg"],    ["name":"second","pic":"2.jpeg"],    ["name":"third","pic":"3.jpeg"]  ]

2、內(nèi)容的添加

 //添加scrollview    self.addScrollView()    //添加圖片    self.addImages()    //添加pagecontrol    self.addPageControl()        mycurrentPage = 1        //添加定時(shí)器    self.setupTimer()

具體方法:

 

func addScrollView(){    self.myscrollView = UIScrollView()    self.myscrollView?.frame = CGRect(x:0,y:0,width:kScreenWidth,height:kScreenHeight/2)    self.myscrollView?.contentSize = CGSize(width:kScreenWidth*3,height:kScreenHeight/2)    self.myscrollView?.showsHorizontalScrollIndicator = false    self.myscrollView?.showsVerticalScrollIndicator = false    self.myscrollView?.scrollsToTop = false    self.myscrollView?.delegate = self    self.myscrollView?.isPagingEnabled = true    self.view.addSubview(self.myscrollView!)  }    func addImages(){    let size = self.myscrollView?.bounds.size    for (seq,course) in courses.enumerated() {      let page = UIView(frame:CGRect(x:0,y:64,width:kScreenWidth,height:kScreenHeight/2))      let imageView=UIImageView(image:UIImage(named:course["pic"]!))      imageView.frame = page.frame      page.addSubview(imageView)      page.backgroundColor = UIColor.gray      let lab1 = UILabel(frame:CGRect(x:15,y:kScreenHeight/2-100,width:kScreenWidth-30,height:40))      lab1.textAlignment = .center      lab1.backgroundColor = UIColor.red      lab1.text = course["name"]      page.addSubview(lab1)            page.frame = CGRect(x:CGFloat(seq)*(size?.width)!,y:0,width:(size?.width)!,height:(size?.height)!)      self.myscrollView?.addSubview(page)          }  }    func addPageControl(){    self.pageControl = UIPageControl(frame:CGRect(x:kScreenWidth/2-50/2,y:kScreenHeight/2-40,width:50,height:35))    self.pageControl?.backgroundColor = UIColor.blue    self.pageControl?.numberOfPages = courses.count    self.view.addSubview(self.pageControl!)  }    func setupTimer() {    self.myTimer = Timer.init(timeInterval: 2.0, target: self, selector: #selector(timerAction), userInfo: nil, repeats: true)    RunLoop.main.add(self.myTimer!, forMode: RunLoopMode.defaultRunLoopMode)    //    DispatchQueue.main.asyncAfter(deadline: DispatchTime.now() + 2) { //      self.myTimer?.fire()//    }      }    func closeTimer(){    self.myTimer?.invalidate()    self.myTimer = nil  }    func timerAction(){    self.pageControl?.currentPage += mycurrentPage!        if self.pageControl?.currentPage == 0 || self.pageControl?.currentPage == 2 {      mycurrentPage = -mycurrentPage!    }    self.myscrollView?.contentOffset = CGPoint(x:CGFloat(kScreenWidth)*CGFloat((pageControl?.currentPage)!),y:0)  }

3、一些代理方法的實(shí)現(xiàn),手動拖動的時(shí)候,銷毀定時(shí)器,節(jié)省內(nèi)存

internal func scrollViewDidEndDecelerating(_ scrollView: UIScrollView) {    let page = Int(scrollView.contentOffset.x/scrollView.frame.size.width)    self.pageControl?.currentPage = page      }    func scrollViewWillBeginDragging(_ scrollView: UIScrollView) {    self.closeTimer()  }    func scrollViewDidEndDragging(_ scrollView: UIScrollView, willDecelerate decelerate: Bool) {    self.setupTimer()  }    func scrollViewWillBeginDecelerating(_ scrollView: UIScrollView) {    self.pageControl?.currentPage = Int(scrollView.contentOffset.x/kScreenWidth)  }

效果如下:

swift,輪播圖,UIScrollVie,UIPageControl,Timer

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持VEVB武林網(wǎng)。


注:相關(guān)教程知識閱讀請移步到swift教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 饶河县| 嵊泗县| 博爱县| 伊宁市| 淅川县| 新疆| 常熟市| 湛江市| 襄樊市| 康保县| 高阳县| 炎陵县| 永清县| 大悟县| 略阳县| 平湖市| 江川县| 如东县| 台东市| 闸北区| 沙田区| 虞城县| 洞口县| 浠水县| 灯塔市| 乌拉特前旗| 滁州市| 兴化市| 广饶县| 宜城市| 西乌| 固始县| 玛沁县| 蒙城县| 舒兰市| 运城市| 枞阳县| 普陀区| 双江| 雅安市| 广元市|