首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >iOS 多section瀑布流实现(swift)

iOS 多section瀑布流实现(swift)

作者头像
我只不过是出来写写代码
发布于 2020-05-18 08:12:58
发布于 2020-05-18 08:12:58
2K00
代码可运行
举报
运行总次数:0
代码可运行

基于 UICollectionViewFlowLayout,实现一个支持多 section 的瀑布流组件

 最近因项目需求,写了一个支持多 section 的瀑布流实现组件,完全基于 swift 5 来实现。 先来直接看效果图:

 (PS:瀑布流的实现原理其实挺简单的,网上现有的教程一抓一大把,我也懒得复述了。。。)

稍微整理了下,让这个小组件尽量做到集成简单快捷。

1. 初始化

 因为基于 UICollectionViewFlowLayout 实现的,所以该 flowLayout 的初始化调用流程与系统的无异,只需要遵循 WaterfallMutiSectionDelegate 代理。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
let layout = WaterfallMutiSectionFlowLayout()
layout.delegate = self
let collection = UICollectionView(frame: self.view.bounds, collectionViewLayout: layout)

2. 代理实现

2.1 必须实现代理方法
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/// collectionItem高度
func heightForRowAtIndexPath(collectionView collection: UICollectionView, layout: WaterfallMutiSectionFlowLayout, indexPath: IndexPath, itemWidth: CGFloat) -> CGFloat
2.2 可选实现代理方法
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
  /// 每个section 列数(默认2列)
  @objc optional func columnNumber(collectionView collection: UICollectionView, layout: WaterfallMutiSectionFlowLayout, section: Int) -> Int
  
  /// header高度(默认为0)
  @objc optional func referenceSizeForHeader(collectionView collection: UICollectionView, layout: WaterfallMutiSectionFlowLayout, section: Int) -> CGSize
  
  /// footer高度(默认为0)
  @objc optional func referenceSizeForFooter(collectionView collection: UICollectionView, layout: WaterfallMutiSectionFlowLayout, section: Int) -> CGSize
  
  /// 每个section 边距(默认为0)
  @objc optional func insetForSection(collectionView collection: UICollectionView, layout: WaterfallMutiSectionFlowLayout, section: Int) -> UIEdgeInsets
  
  /// 每个section item上下间距(默认为0)
  @objc optional func lineSpacing(collectionView collection: UICollectionView, layout: WaterfallMutiSectionFlowLayout, section: Int) -> CGFloat
  
  /// 每个section item左右间距(默认为0)
  @objc optional func interitemSpacing(collectionView collection: UICollectionView, layout: WaterfallMutiSectionFlowLayout, section: Int) -> CGFloat
  
  /// section头部header与上个section尾部footer间距(默认为0)
  @objc optional func spacingWithLastSection(collectionView collection: UICollectionView, layout: WaterfallMutiSectionFlowLayout, section: Int) -> CGFloat

最后附上demo链接:https://github.com/RoganZheng/WaterfallMultiSectionFlowLayout 如果对你有帮助,记得点个 star。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
qml入门教程_前端从入门到放弃
<9>:Property and number animation in mouse event:
全栈程序员站长
2022/09/19
2K0
qml入门教程_前端从入门到放弃
QML入门教程:一、QML和QtQuick简介以及QML实例
从 Qt 4.7 开始,Qt 引入了一种声明式脚本语言,称为 QML(Qt Meta Language 或者 Qt Modeling Language),作为 C++ 语言的一种替代。而 Qt Quick 就是使用 QML 构建的一套类库。 QML 是一种基于 JavaScript 的声明式语言。在 Qt 5 中, QML 有了长足进步,并且同 C++ 并列成为 Qt 的首选编程语言。也就是说,使用 Qt 5,我们不仅可以使用 C++ 开发 Qt 程序,而且可以使用 QML。虽然 QML 是解释型语言,性能要比 C++ 低一些,但是新版 QML 使用 V8,Qt 5.2 又引入了专为 QML 优化的 V4 引擎,使得其性能不再有明显降低。在 Nokia 发布 Qt 4.7 的时候,QML 被用于开发手机应用程序,全面支持触摸操作、流畅的动画效果等。但是在 Qt 5 中,QML 已经不仅限于开发手机应用,也可以用户开发传统的桌面程序。 QML 文档描述了一个对象树。QML 元素包含了其构造块、图形元素(矩形、图片等)和行为(例如动画、切换等)。这些 QML 元素按照一定的嵌套关系构成复杂的组件,供用户交互。 ——摘自《Qt学习之路2》
全栈程序员站长
2022/11/01
5.6K0
QML入门教程:一、QML和QtQuick简介以及QML实例
Qt官方示例-QML标签页
❝TabWidget示例演示了如何使用属性别名和QML Object默认属性创建标签页。❞ TabWidget.qml Item { id: tabWidget // 核心实现 // 将默认属性设置为stack.children意味着TabWidget的所有子项实际上都已添加到"stack"项的子项中。 // 有关默认属性的详细信息,请参见"Property Binding"文档。 default property alias content: stack.c
Qt君
2023/03/17
1.4K0
Qt官方示例-QML标签页
完全依赖QML实现播放器
一直听闻QML无比强大好用,工作中需要扣一个同时播放视频的Demo,所以就趁这个机会研究了一下。
gongluck
2020/03/05
2.3K0
完全依赖QML实现播放器
【QML】基础语法
QtQuick是一种高级界面技术,可轻松创建供移动、嵌入式设备使用的触摸式界面、轻量级应用程序。QtQuick主要由3部分组成:QtQuick设计器,QML语言、quick模块。
半生瓜的blog
2023/05/13
9000
【QML】基础语法
【C++】Qt:QML介绍与入门示例
Qt Quick是一个用于构建现代、高效、可扩展用户界面的框架。它是Qt开发框架的一部分,旨在通过声明性语法和JavaScript绑定来简化用户界面的设计和实现。
DevFrank
2024/07/24
1.4K0
【C++】Qt:QML介绍与入门示例
【专业技术】还有人在用Qt开发app嘛?
编者按: 这个世界不缺工程师,但是缺大师。如果在Qt里写个app,传统做法,需要熟悉API,熟悉C++,熟悉Qt本身的实现,同时还要熟悉编程环境。 现在出现了一种类似于脚本Javascript的语言,利用它,我们可以少编写一些程序逻辑。可不,最近我就利用它开发出了个浏览器。大家都没有。 欢迎来到声明式UI语言QML的世界.在本入门教程中,我们使用QML创建一个简单的文本编辑器.阅读这个教程后,就可以使用QML和Qt C++开发应用程序了. 安装 首先需要安装包含Qt Quick的Qt最新版本,现在是Qt4.
程序员互动联盟
2018/03/14
5.2K0
【专业技术】还有人在用Qt开发app嘛?
Qt开发-QT Quick
Row 则是一个单独的 Item ,专门用来管理其它 Item 的,后面介绍的几种布局,也是类似的。
码客说
2021/11/10
2.8K0
Qt官方示例-Qml鼠标点击与拖拽
  当您在红色方块内单击鼠标时,界面下方区域文本将显示出单击鼠标的一些属性,这些属性可用于QML中。按下鼠标时,红色方块的不透明度将降低,并保留在MouseArea内。当其中发生单击或双击等其他操作时,MouseArea会发出对应的信号。
Qt君
2020/04/01
2.9K0
Qt官方示例-Qml翻转动画
❝示例演示翻转动画(沿着x轴或y轴翻转动画)。❞ 主要代码: import QtQuick 2.0 Flipable { id: container property alias source: frontImage.source property bool flipped: true property int xAxis: 0 property int yAxis: 0 property int angle: 0 width: front.
Qt君
2023/03/17
8720
Qt官方示例-Qml翻转动画
Qt界面UI之QML初见(学习笔记四)
一 概述 QML是一种专门用于构建用户界面的编程语言,它允许用户构建高性能,具有流畅特效的可视化应用程序,QML是可读的,声明式的文档,具有类似JSON的语法,支持使用JavaScrip表达式,具有动态属性绑定等特性。 二 QML语法基础 QMl的代码一般长如下: import QtQuick 2.2 Rectangle { width: 360 height: 360 MouseArea { anchors.fill: parent onClic
用户1198337
2018/01/19
2.7K0
Qt界面UI之QML初见(学习笔记四)
Qml数字键盘
双十一购物节为了避免剁手,给自己一个小目标,写个Qml数字键盘分享给大家。 1. Qml键盘代码 Rectangle { id: rootKeyboard property color backgroundColor: "#202120" //default property color pressedButtonColor: "#00a0fc" // default property color normalButtonColor: "#303751" // d
Qt君
2023/03/17
9270
Qml数字键盘
Qml失焦问题
Qml常见诡异失焦情况一般为明明设置了某一控件的焦点, 实际却是不生效。这到底时什么情况呢?用例子来分析这种情况。 1.常见失焦情况 被其他控件抢夺; 误以为设置成功。 2.关于控件被抢夺的情况 2.1 先看下列例子 Dialog { id: dialog width: 100; height: 100 onHidden: { dialog.forceReset() // restore focus to 'yes' button } } Rectangle
Qt君
2019/07/15
2.5K0
Qt5实战第十一篇:QML与Qt Quick详解
QML(Qt Meta-Object Language 或 Qt Modelling Language)和Qt Quick是Qt框架的重要组成部分,主要用于构建高性能、交互性强的用户界面。QML是一种基于JavaScript的声明性语言,而Qt Quick则是QML类型和功能的标准库。下面将详细讲解QML与Qt Quick的基本概念、特点、应用场景以及示例。
china马斯克
2025/01/04
1.1K0
一个好的Qml文件(翻译文)
  什么样的Qml文件(通常称为组件)是一个高质量的文件?   让我们看看示例1:
Qt君
2019/07/15
1.2K0
Qt Quick实践系列-函数绑定
  由于display函数内部使用了string1和string2变量,当其中任意一个变量变更都会更新text: display()表达式。这种动态绑定在界面编程中会变得更易用方便。
Qt君
2020/05/08
5220
【QML】简单动画实现
QML动画 **示例1:**动画作为属性值的来源 import QtQuick 2.0 //动画作为属性值的来源 //语法: 动画on属性 //easing属性来实现缓和曲线 Rectangle{ width: 100 height: 100 color: "red" PropertyAnimation on x{ to:50 duration: 1000 loops: Animation.Infinite //无限循环
半生瓜的blog
2023/05/13
6560
兼容Qt4/Qt5版本Qml控件Slider
通过滑动滑块选择一个值 导入方法: 文件导入 兼容性: QtQuick1.x与 QtQuick2.x 继承: Item 属性 background: Item from: real handle: Item orientation: enumeration position: real pressed: bool stepSize: real to: real value: real 方法 function decrease() function increase() 描述 通过滑动滑块选择一个值 Slid
Qt君
2019/07/15
7150
兼容Qt4/Qt5版本Qml控件Slider
pyqt5与QML开发小结
qt 5.11 与 qt 5.12 中Qquick的差异还是蛮大的,由开发环境:Pyqt5.11 + Qt5.12 部署到 Pyqt5.11 + Qt5.11时遇到以下问题:
py3study
2020/01/17
1.6K0
Qt开发-QT Quick之自定义组件
按钮 添加ZButton.qml import QtQuick 2.14 import QtQuick.Window 2.14 /* 文件名即自定义控件名 使用别名导出属性:相当于函数的变量形参 不同的是导出的属性,调用控件是可以不使用(赋值) */ Rectangle { id: root //导出自定义属性 property alias text: label.text property alias fontSize: label.font.po
码客说
2021/11/17
1.8K0
Qt开发-QT Quick之自定义组件
相关推荐
qml入门教程_前端从入门到放弃
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验