前言: 这篇你可以学会自定义视图,创建collectionView,协议的使用,定时器;

首先新建一个继承于UIView的视图,且用collectionView实现所以需要签订两个协议代码如下:

let sectionNum: Int = 100 // 区的数量
let width = UIScreen.mainScreen().bounds.size.width  // 屏幕宽度
let height = UIScreen.mainScreen().bounds.size.width // 屏幕高度 
// 因为要实现轮播图片可以点击定义一个协议
// 协议
protocol XTCycleViewDelegate {
    func didSelectIndexCollectionViewCell(index: Int)->Void
}
class XTCycleScrollView: UIView,UICollectionViewDelegate,UICollectionViewDataSource{

使用到的变量以及创建视图

var delegate: XTCycleViewDelegate?
    var cycleCollectionView: UICollectionView?
    var images = NSMutableArray()
    var pageControl = UIPageControl()
    var flowlayout = UICollectionViewFlowLayout()
    var timer = NSTimer()
    override init(frame: CGRect) {
        super.init(frame: frame)
        self.createSubviews(frame)
    }

    required init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }

布局必要的UI以及创建定时器

func createSubviews(frame: CGRect){
        cycleCollectionView = UICollectionView.init(frame: CGRectMake(0,0,frame.size.width,frame.size.height),collectionViewLayout: flowlayout)
        flowlayout.itemSize = CGSizeMake(frame.size.width,frame.size.height);
        flowlayout.minimumInteritemSpacing = 0;
        flowlayout.minimumLinespacing = 0;
        flowlayout.scrollDirection = UICollectionViewScrollDirection.Horizontal;
        cycleCollectionView!.backgroundColor = UIColor.lightGrayColor()
        cycleCollectionView!.pagingEnabled = true
        cycleCollectionView!.dataSource  = self
        cycleCollectionView!.delegate = self
        cycleCollectionView!.showsHorizontalScrollIndicator = false
        cycleCollectionView!.showsverticalScrollIndicator = false
        cycleCollectionView!.registerClass(ZJCustomCycleCell.self,forCellWithReuseIdentifier: "cellId")
        self.addSubview(cycleCollectionView!)
        pageControl = UIPageControl.init(frame: CGRectMake(0,frame.size.width / 2,30))
        pageControl.center = CGPointMake(frame.size.width / 2,frame.size.height - 20);
        self.addSubview(pageControl);
        self.addTimer()
    }

定时器初始化

func addTimer(){
        let timer1 = NSTimer.init(timeInterval: 2,target: self,selector: "nextPageView",userInfo: nil,repeats: true)
        NSRunLoop.currentRunLoop().addTimer(timer1,forMode: NSRunLoopCommonModes)
        timer = timer1
    }

销毁定时器

func removeTimer(){
        self.timer.invalidate()
    }

实现循环滚动

func returnIndexPath()->NSIndexPath{
        var currentIndexPath = cycleCollectionView!.indexPathsForVisibleItems().last
        currentIndexPath = NSIndexPath.init(forRow: (currentIndexPath?.row)!,inSection: sectionNum / 2)
        cycleCollectionView!.scrollToItemAtIndexPath(currentIndexPath!,atScrollPosition: UICollectionViewScrollPosition.Left,animated: false)
        return currentIndexPath!;
    }
 func nextPageView(){

        let indexPath = self.returnIndexPath()
        var item = indexPath.row + 1;
        var section = indexPath.section;
        if item == images.count {
            item = 0
            section++
        }
        self.pageControl.currentPage = item;
        let nextIndexPath = NSIndexPath.init(forRow: item,inSection: section)
        cycleCollectionView!.scrollToItemAtIndexPath(nextIndexPath,animated: true)
    }

collectionView Delegate

// 重用池
     func collectionView(collectionView: UICollectionView,cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell {
        // 这里使用的自定义cell,下面会贴出自定义cell代码
        let cell = collectionView.dequeueReusableCellWithReuseIdentifier("cellId",forIndexPath: indexPath) as! ZJCustomCycleCell
        // 这个Label实现显示数字,表示是第几张图片
        cell.labelTitle.text = Nsstring(format: "%d",indexPath.row) as String
        // 这里是图片赋值
        let url:String = self.images[indexPath.row] as! String
        // 这里我使用的是一个赋值图片的三方库,看自己喜好,为方便我没有自己写
        cell.imageView.hnk_setimageFromURL(NSURL.init(string: url)!)
        return cell
    }
    func numberOfSectionsInCollectionView(collectionView: UICollectionView) -> Int {
        return sectionNum
    }
    func collectionView(collectionView: UICollectionView,numberOfItemsInSection section: Int) -> Int {
        // 在这里给出了pageControl的数量
        pageControl.numberOfPages = images.count
        return images.count
    }
// 重新添加定时器
    func scrollViewDidEndDragging(scrollView: UIScrollView,willDecelerate decelerate: Bool) {
        self.addTimer()
    }
    // 手动滑动的时候销毁定时器
    func scrollViewWillBeginDragging(scrollView: UIScrollView) {
        self.removeTimer()
    }

设置当前的pagecontrol

func scrollViewDidEndDecelerating(scrollView: UIScrollView) {
        let page = (Int(scrollView.contentOffset.x) / Int(width)) % images.count
        pageControl.currentPage = page
    }

点击方法

func collectionView(collectionView: UICollectionView,didSelectItemAtIndexPath indexPath: NSIndexPath) {
        self.delegate?.didSelectIndexCollectionViewCell(indexPath.row)
    }

下面是我在自定义cell中的代码

var urlImage: String = ""
    var imageView = UIImageView()
    var labelTitle = UILabel()
    override init(frame: CGRect) {
        super.init(frame: frame)
        self.createSubviews(frame)
    }

    required init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }
    func createSubviews(frame: CGRect){
        imageView = UIImageView.init(frame: CGRectMake(0,frame.size.height))
        self.contentView.addSubview(imageView)
        labelTitle = UILabel.init(frame: CGRectMake(10,10,30,30))
        imageView.addSubview(labelTitle)
    }

封装基本完成了,下面看看如何使用

// 创建
        let cycle = XTCycleScrollView.init(frame: CGRectMake(0,70,width,175))
        // 要实现点击需要制定代理人
        cycle.delegate = self;
        // 图片链接数组
        let images: NSMutableArray = ["","",""]
        // 数组赋值
        cycle.images = images
        self.view.addSubview(cycle)

实现代理方法

func didSelectIndexCollectionViewCell(index: Int) {
        print("\(index)")
    }

总结: 这样就实现了简单的图片轮播效果,并且带有点击方法,都看到这里就点个赞吧. 哈哈

Swift 使用CollectionView 实现图片轮播封装的更多相关文章

  1. bootstrapv4轮播图去除两侧阴影及线框的方法

    这篇文章主要介绍了bootstrapv4轮播图去除两侧阴影及线框的方法,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  2. AmazeUI图片轮播效果的示例代码

    这篇文章主要介绍了AmazeUI图片轮播效果的示例代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  3. ios – UICollectionView在帧更改后错误地显示单元格

    我错过了什么吗?

  4. ios – 如何将UICollectionViewCell从一个UICollectionView拖到另一个UICollectionView?

    如果是这样,我将如何实施它?

  5. ios – 在uicollectionview底部添加加载指示符

    解决方法不,没有“内置”的方式.您需要做的是有一个包含加载器的额外单元格.检测此单元格何时出现非常简单,此时您可以启动调用以加载更多数据.

  6. ios – 使用自定义布局的UICollectionView接口旋转

    方法返回的布局属性的center属性时,一切看起来都是正确的–所有都沿着水平轴均匀分布.没有正确动画的单元格的唯一区别特征是,当调用initialLayout…方法时,它的单元格不会在[collectionViewvisibleCells]数组中返回.layoutAttributesForElementsInRect:在它之前确实正确地标识了它的布局属性.发生什么了?对引擎盖下发生的事情的一些见解会非常有用……

  7. ios – UICollectionView神秘崩溃

    我有一个UICollectionView,我用从Internet下载的图像填充单元格.为此我使用SDWebImage.我的代码如下所示:我相信我已经正确地设置了它.但应用程序完全随机崩溃,有时会留下此堆栈跟踪:日志区域中没有其他消息.我尝试设置异常断点,但每次发生此崩溃时,都会显示此堆栈跟踪.有谁知道可能是什么问题?解决方法如果有人在寻找答案,我已经解决了问题,并回答了与同一问题有关的另一个问题.你可以找到它here.希望它有所帮助!

  8. ios – performBatchUpdates上的UICollectionView性能问题

    我们正在尝试使用自定义布局设置UICollectionView.每个CollectionViewCell的内容都是一个图像.总之,将会有数千张图像,并且在某个特定时间可以看到大约140-150张图像.在动作事件中,可能会在位置和大小上重新组织所有单元格.目标是使用performBatchUpdates方法为当前所有移动事件设置动画.在一切变得动画之前,这会导致很长的延迟时间.到目前为止,我们发现内

  9. ios – UICollectionView 2种不同的背景颜色

    如果用户向下滚动,我会尽量避免在我的collectionview单元格顶部显示白色背景颜色.所以在我的单元格顶部只有collectionview背景颜色可见.但如图所示,我需要2种不同的颜色.对于第一部分,背景应为蓝色,因此间隙不是白色而是蓝色,而对于其他部分,它应保持白色.所以我想要的是,在不改变我的uicollectionview的完整背景颜色的情况下,白色的间隙将变为蓝色.解决方法您可以通过在UICollectionView或UITableView的顶部添加视图来实现所需的效果–它将与内容一起滚动并

  10. ios – 如何自动重新加载集合视图?

    我使用集合视图开发了一个RSS阅读器应用程序.我的问题是,在第一次启动时,应用程序出现空白.过程是,RSS提要从Web中提取,存储到设备上的临时文件中,然后通过集合视图显示.我的问题是如何在文件加载后让应用程序自动重新加载数据?这样用户就看不到初始的空白屏幕.我试过添加这段代码但是它不适用于初始视图.我应该从appdelegate做些什么吗?或者从集合视图控制器本身?请指教下面是用于获取和显示我的数据的代码…

随机推荐

  1. Swift UITextField,UITextView,UISegmentedControl,UISwitch

    下面我们通过一个demo来简单的实现下这些控件的功能.首先,我们拖将这几个控件拖到storyboard,并关联上相应的属性和动作.如图:关联上属性和动作后,看看实现的代码:

  2. swift UISlider,UIStepper

    我们用两个label来显示slider和stepper的值.再用张图片来显示改变stepper值的效果.首先,这三个控件需要全局变量声明如下然后,我们对所有的控件做个简单的布局:最后,当slider的值改变时,我们用一个label来显示值的变化,同样,用另一个label来显示stepper值的变化,并改变图片的大小:实现效果如下:

  3. preferredFontForTextStyle字体设置之更改

    即:

  4. Swift没有异常处理,遇到功能性错误怎么办?

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  5. 字典实战和UIKit初探

    ios中数组和字典的应用Applicationschedule类别子项类别名称优先级数据包contactsentertainment接触UIKit学习用Swift调用CocoaTouchimportUIKitletcolors=[]varbackView=UIView(frame:CGRectMake(0.0,0.0,320.0,CGFloat(colors.count*50)))backView

  6. swift语言IOS8开发战记21 Core Data2

    上一话中我们简单地介绍了一些coredata的基本知识,这一话我们通过编程来实现coredata的使用。还记得我们在coredata中定义的那个Model么,上面这段代码会加载这个Model。定义完方法之后,我们对coredata的准备都已经完成了。最后强调一点,coredata并不是数据库,它只是一个框架,协助我们进行数据库操作,它并不关心我们把数据存到哪里。

  7. swift语言IOS8开发战记22 Core Data3

    上一话我们定义了与coredata有关的变量和方法,做足了准备工作,这一话我们来试试能不能成功。首先打开上一话中生成的Info类,在其中引用头文件的地方添加一个@objc,不然后面会报错,我也不知道为什么。

  8. swift实战小程序1天气预报

    在有一定swift基础的情况下,让我们来做一些小程序练练手,今天来试试做一个简单地天气预报。然后在btnpressed方法中依旧增加loadWeather方法.在loadWeather方法中加上信息的显示语句:运行一下看看效果,如图:虽然显示出来了,但是我们的text是可编辑状态的,在storyboard中勾选Editable,再次运行:大功告成,而且现在每次单击按钮,就会重新请求天气情况,大家也来试试吧。

  9. 【iOS学习01】swift ? and !  的学习

    如果不初始化就会报错。

  10. swift语言IOS8开发战记23 Core Data4

    接着我们需要把我们的Rest类变成一个被coredata管理的类,点开Rest类,作如下修改:关键字@NSManaged的作用是与实体中对应的属性通信,BinaryData对应的类型是NSData,CoreData没有布尔属性,只能用0和1来区分。进行如下操作,输入类名:建立好之后因为我们之前写的代码有些地方并不适用于coredata,所以编译器会报错,现在来一一解决。

返回
顶部