仿SDCycleScrollView(Swift版本)

仿SDCycleScrollView(Swift版本)


废话不多说,在开发中,cycleScrollView是经常要用到的一个控件,以下是我封装的一个cycleScrollview的swift版本cycleScrollView+timer(GIT地址)


核心代码

/**
         *  配置轮播数据源
         */
        var newImageUrlStrings: [String] = imageUrlStrings
        if imageUrlStrings.count > 1 {
            newImageUrlStrings.insert(imageUrlStrings.last!, at: 0)
            newImageUrlStrings.append(imageUrlStrings.first!)
        }

        for imageUrlStrig in newImageUrlStrings {
            let tmpImageView = UIImageView.init(frame: CGRect.init(x: x, y: 0, width: mFrame.width, height: mFrame.height))
            tmpImageView.tag = imageUrlStrings.index(of: imageUrlStrig)!
            self.mScrollView.addSubview(tmpImageView)

            /**
             *  设置数据源
             */
            tmpImageView.kf.setImage(with: URL.init(string: imageUrlStrig), placeholder: mPlaceholderImage, options: nil, progressBlock: { (a, b) in

            }, completionHandler: { (image, error, cacheType, url) in

            })

            /**
             *  添加图片点击事件
             */
            tmpImageView.isUserInteractionEnabled = true
            tmpImageView.addGestureRecognizer(UITapGestureRecognizer.init(target: self, action: #selector(self.didSelectImageView(tap:))))

            x+=mFrame.width
        }

        self.mPage.numberOfPages = imageUrlStrings.count
        self.mScrollView.contentSize = CGSize.init(width: mFrame.width * CGFloat(newImageUrlStrings.count), height: mFrame.height)

        if newImageUrlStrings.count > 0 {
            mScrollView.scrollRectToVisible(CGRect.init(origin: CGPoint.init(x: mScrollView.frame.width, y: mScrollView.frame.origin.y), size: mScrollView.frame.size), animated: false)
        }

        self.startTimer()
因为swift最新版本提供的定时器只支持10.0以上版本,为了兼容低版本系统,Demo中也同时封装了一个定时器的类(通过GCD实现的),并且使用的API和系统相近。
如有错误,希望不吝指出共勉。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值