//

//  HomeLiveRankCell.swift

//  YYSwiftProject

//

//  Created by Domo on 2018/7/28.

//  Copyright © 2018年 知言网络. All rights reserved.

//

import UIKit

class HomeLiveRankCell: UICollectionViewCell {

private var multidimensionalRankVosList: [MultidimensionalRankVosModel]?

private let LiveRankCellID = "LiveRankCell"

// MARK: - 滚动排行榜

private lazy var collectionView: UICollectionView = {

let layout = UICollectionViewFlowLayout.init()

layout.sectionInset = UIEdgeInsetsMake(0, 0, 0, 0)

layout.minimumInteritemSpacing = 0

layout.minimumLineSpacing = 0

layout.itemSize = CGSize(width: (YYScreenWidth-30), height:self.frame.size.height)

//        layout.sectionInset = UIEdgeInsetsMake(0, 0, 0, 0)

layout.scrollDirection = UICollectionViewScrollDirection.horizontal

let collectionView = UICollectionView.init(frame:.zero, collectionViewLayout: layout)

collectionView.contentSize = CGSize(width: (YYScreenWidth-30), height: self.frame.size.height)

collectionView.delegate = self

collectionView.dataSource = self

collectionView.backgroundColor = UIColor.white

collectionView.showsVerticalScrollIndicator = false

collectionView.showsHorizontalScrollIndicator = false

collectionView.isPagingEnabled = true

collectionView.register(LiveRankCell.self, forCellWithReuseIdentifier:LiveRankCellID)

return collectionView

}()

var timer: Timer?

override init(frame: CGRect) {

super.init(frame: frame)

self.backgroundColor = UIColor.white

self.addSubview(self.collectionView)

self.collectionView.snp.makeConstraints { (make) in

make.width.height.equalToSuperview()

make.center.equalToSuperview()

}

// 开启定时器

starTimer()

}

required init?(coder aDecoder: NSCoder) {

super.init(coder: aDecoder)

}

// 界面赋值并刷新

var multidimensionalRankVos:[MultidimensionalRankVosModel]? {

didSet {

guard let model = multidimensionalRankVos else { return }

self.multidimensionalRankVosList = model

self.collectionView.reloadData()

}

}

}

extension HomeLiveRankCell: UICollectionViewDataSource, UICollectionViewDelegate {

func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {

return (self.multidimensionalRankVosList?.count ?? 0)*100

}

func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {

let cell:LiveRankCell = collectionView.dequeueReusableCell(withReuseIdentifier: LiveRankCellID, for: indexPath) as! LiveRankCell

cell.backgroundColor = UIColor.init(red: 248/255.0, green: 245/255.0, blue: 246/255.0, alpha: 1)

cell.multidimensionalRankVos = self.multidimensionalRankVosList?[indexPath.row%(self.multidimensionalRankVosList?.count)!]

return cell

}

func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) {

print(indexPath.row%(self.multidimensionalRankVosList?.count)!)

}

/// 开启定时器

func starTimer () {

let timer = Timer.init(timeInterval: 3, target: self, selector: #selector(nextPage), userInfo: nil, repeats: true)

// 这一句代码涉及到runloop 和 主线程的知识,则在界面上不能执行其他的UI操作

RunLoop.main.add(timer, forMode: RunLoopMode.commonModes)

self.timer = timer

}

/// 在1秒后,自动跳转到下一页

@objc func nextPage() {

// 1.获取collectionView的X轴滚动的偏移量

let currentOffsetX = collectionView.contentOffset.x

let offsetX = currentOffsetX + collectionView.bounds.width

// 2.滚动该位置

collectionView.setContentOffset(CGPoint(x: offsetX, y: 0), animated: true)

}

//    // 监听collectionView的滚到

//    func scrollViewDidScroll(_ scrollView: UIScrollView) {

//        // 1、获取滚动的偏移量 + scrollView.bounds.width * 0.5给偏移量加一半,当滑动一般就滚动pageControl的当前选中

//        let offsetX = scrollView.contentOffset.x + scrollView.bounds.width * 0.5

//        // 2、计算pageContra的currentIndex。这 % (cycleModelArr?.count ?? 1)也是跟上同样道理

//        pageControl.currentPage = Int(offsetX / scrollView.bounds.width) % (imageArray?.count ?? 1)

//    }

//

/// 当collectionView开始拖动的时候,取消定时器

func scrollViewWillBeginDragging(_ scrollView: UIScrollView) {

self.timer?.invalidate()

self.timer = nil

}

/// 当用户停止拖动的时候,开启定时器

func scrollViewWillEndDragging(_ scrollView: UIScrollView, withVelocity velocity: CGPoint, targetContentOffset: UnsafeMutablePointer<CGPoint>) {

starTimer()

}

}

//

//  LiveRankCell.swift

//  YYSwiftProject

//

//  Created by Domo on 2018/7/28.

//  Copyright © 2018年 知言网络. All rights reserved.

//

import UIKit

class LiveRankCell: UICollectionViewCell {

private lazy var imageView : UIView = {

let imageView = UIView()

return imageView

}()

private lazy var titleLabel : UILabel = {

let label = UILabel()

label.font = UIFont.systemFont(ofSize: 18)

return label

}()

private lazy var label : UILabel = {

let label = UILabel()

label.text = ">"

label.textColor = UIColor.lightGray

return label

}()

override init(frame: CGRect) {

super.init(frame: frame)

self.addSubview(self.titleLabel)

self.titleLabel.snp.makeConstraints { (make) in

make.left.equalToSuperview().offset(10)

make.height.equalTo(40)

make.width.equalTo(100)

make.centerY.equalToSuperview()

}

self.addSubview(self.imageView)

self.imageView.snp.makeConstraints { (make) in

make.right.equalToSuperview().offset(-5)

make.top.equalToSuperview().offset(5)

make.bottom.equalToSuperview().offset(-5)

make.width.equalTo(180)

}

self.imageView.addSubview(self.label)

self.label.snp.makeConstraints { (make) in

make.right.equalToSuperview().offset(-5)

make.height.width.equalTo(10)

make.centerY.equalToSuperview()

}

}

required init?(coder aDecoder: NSCoder) {

super.init(coder: aDecoder)

}

var multidimensionalRankVos:MultidimensionalRankVosModel? {

didSet {

guard let model = multidimensionalRankVos else { return }

self.titleLabel.text = model.dimensionName

let num:Int = (model.ranks?.count)!

let margin:CGFloat = 50

for index in 0..<num {

let picView = UIImageView.init(frame: CGRect(x:margin*CGFloat(index)+5*CGFloat(index),y:5,width:margin,height:margin))

picView.layer.masksToBounds = true

picView.layer.cornerRadius = picView.frame.size.width/2

picView.kf.setImage(with: URL(string: (model.ranks?[index].coverSmall!)!))

self.imageView.addSubview(picView)

}

}

}

}

swift中使用UIColllectionView实现横向轮播的一般方法的更多相关文章

  1. js 实现横向轮播效果

    参考:https://www.cnblogs.com/LIUYANZUO/p/5679753.html html: <!DOCTYPE html> <html> <hea ...

  2. Bootstrap 历练实例-轮播(carousel)插件方法

    方法 下面是一些轮播(Carousel)插件中有用的方法: 方法 描述 实例 .carousel(options) 初始化轮播为可选的 options 对象,并开始循环项目. $('#identifi ...

  3. React中使用CSSTransitionGroup插件实现轮播图

    动画效果,是一个页面上必不可少的功能,学习一个新的东西,当然就要学习,如何用新的东西,用它的方法去实现以前的东西啦.今天呢,我就在这里介绍一个试用react-addons-css-transition ...

  4. html中使用JS实现图片轮播效果

    1.首先是效果图,要在网页中实现下图的轮播效果,有四张图片,每张图片有自己的标题,然后还有右下角的小方框,鼠标悬浮在小方框上,会切换到对应的图片中去. 2.先是HTML中的内容,最外层是轮播图整个的容 ...

  5. 记一个jquery 无缝轮播的制作方法

    接触前端也很久了,今天才发现,要做好一个轮播,其实有很多东西需要考虑进去,否则做出来的轮播效果并不好,下面我就来做一个轮播,是依赖jquery来写的 1.要做轮播,首先需要的是HTML的内容,css的 ...

  6. 移动端轮播图实现方法(dGun.js)

    本文章介绍在移动端无缝隙轮播图实现的原理,这个轮子比较简单,但可以方便刚刚入门的同学参考.最终效果是在移动端无缝隙无限滑动,可以自定义轮播的速度.支持手势左右滑动.最后会放上源码. HTML部分 &l ...

  7. H5制作显示轮播图的方法Swiper

    1.需要引入Swiper插件 <!-- swiper插件 --> <link rel="stylesheet" href="https://unpkg. ...

  8. swiper横向轮播--3d

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  9. swiper横向轮播(兼容IE8)

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

随机推荐

  1. NoSQL技术

    NoSQL技术使用场景: 在我们日常的开发中,无不都是使用数据库来进行数据的存储,由于一般的系统任务中通常不会存在高并发的情况,所以这样看起来并没有什么问题,可是一旦涉及大数据量的需求,比如一些商品抢 ...

  2. Spring框架中的JDK与CGLib动态代理

    JDK和CGLib动态代理区别 JDK动态代理:利用拦截器(拦截器必须实现InvocationHanlder)加上反射机制生成一个实现代理接口的匿名类, 在调用具体方法前调用InvokeHandler ...

  3. 一 CRM 注册功能实现

    前端:登陆页面按钮跳转到注册页面 dao:  配置连接池 配置session工厂,Hibernate核心配置,映射 配置UserDao,注入session工厂 UserDao:继承HibernateD ...

  4. SciPy 图像处理

    章节 SciPy 介绍 SciPy 安装 SciPy 基础功能 SciPy 特殊函数 SciPy k均值聚类 SciPy 常量 SciPy fftpack(傅里叶变换) SciPy 积分 SciPy ...

  5. 使用six库将Python2的项目完全转移到python3

    SIX是用于python2与python3兼容的库. 它存在的目的是为了拥有无需修改即可在Python 2和Python 3上同时工作的代码.话虽这么说,但是这并不代表在Python 3中引用该库就可 ...

  6. 分享一款免费的工控组态软件(PCHMI)

    PCHMI严格的讲它并不是一款组态软件,也不是一款SCADA软件,而是一个基于.NET构架的DLL文件,开发者可以使用微软的Visual Studio将PCHMI.DLL加载到工具箱里面进行二次开发. ...

  7. POJ 3273:Monthly Expense 二分好题啊啊啊啊啊啊

    Monthly Expense Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 19207   Accepted: 7630 ...

  8. 非极大抑制睔PYTHON实现

    非极大抑制(Non-maximum suppression)python代码实现原创Butertfly 发布于2018-11-20 18:48:57 阅读数 293 收藏展开定位一个物体,最后算法就找 ...

  9. 第四张5G牌照发给广电,能打破三大运营商的垄断吗?

    近段时间,多个国家处于莫须有的安全性考虑,禁止华为参与核心5G网络设备竞标.其实这就从侧面反映出,国内民族企业在5G层面的领先性.当然,这也让我们认知到,5G网络将是新时代的竞争关键节点.为此,国内正 ...

  10. 挖洞经验 | 绕过WAF限制利用php:方法实现OOB-XXE漏洞利用

    几个星期以前,作者在某个OOB-XXE漏洞测试中遇到过这样一种场景:目标应用后端系统WAF防火墙阻挡了包含DNS解析在内的所有出站请求(Outgoing Request),但最终,通过利用php:// ...