首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

WWDC2016 Session笔记 - iOS 10 UICollectionView新特性

我们来分析一下,我们模拟一下系统如何处理重用机制的,效果如下图 在上图中,我们可以看出,当cell准备加载进屏幕的时候,整个cell都已经加载完成,等待在屏幕外面了。...执行完willDisplayCell之后,cell就进入屏幕了。 ? 当cell完全离开屏幕之后,就会调用didEndDisplayingCell方法。...当2个cell都准备好了之后,接着我们再调用willDisplayCell给每个cell,发送完这个消息之后,cell就会出现在屏幕上了。...还是和iOS 9一样,我们来模拟一下系统是如何加载cell的情况。 我们可以很明显的看到,iOS 系统是一个个的加载cell的,一个cell加载完之后再去加载下一个cell。...UITableViewCell的Pre-Fetching预加载 在iOS 10中,UITableViewCell也跟着UICollectionView一起得到了性能的提升,一样拥有了Pre-Fetching

2K30

iOS小经验:UITableView&UICollectionView设置单元格的默认选中状态

场景需求 一个表格视图(或者宫格视图)中,当一个单元格被选中时设置彩色样式,选中其它单元格时设置灰色样式。 2. 一个思路 通过实现选中和非选择的代理,以在适当的时机进行UI更新操作。 3....tableView:(UITableView *)tableView didDeselectRowAtIndexPath:(NSIndexPath *)indexPath; 3.2 代码设置默认选中状态 (要等数据加载完成之后再调用...UICollectionView 4.1 通过屏幕点击改变的选中状态回调给代理 //选中 - (void)collectionView:(UICollectionView *)collectionView...collectionView didDeselectItemAtIndexPath:(NSIndexPath *)indexPath; 4.2 代码设置默认选中状态 (要等数据加载完成之后再调用) 执行方法的主体...之后,通过屏幕点击选中其它cell的时候,可以执行- (void)collectionView:(UICollectionView *)collectionView didDeselectItemAtIndexPath

3.6K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Swift 探索 UICollectionView 之 SupplementaryView 和 Decoration View

    答案当然是肯定的,在 UICollectionView 控件中我们管这叫 Supplementary View, 翻译过来就是 "追加视图",那在 UICollectionView 中该怎么实现给每个...来表示3.注册视图的标识符,用于 UICollectionView 在加载视图的时候能分辨加载的是 header 还是 footer 还是普通的 cell 第二个方法是 UICollectionViewDataSource...协议里的,返回一个 UICollectionReusableView 对象,实现它用于返回 Supplementary View 的实例,然后 UICollectionView 将其加载;它有三个参数...在接下来的内容中,你将会学到以下知识点: 1.如何在 UICollectionView 中创建 Decoration View2.自定义布局属性,计算 section 的背景图位置和大小3.实现 UICollectionView...UIGestureRecognizer 手势拖拽 在 iOS9 之后,UICollectionView 的属性自带重新排序的效果,这里不得不提 Apple 为 UICollectionView 推出的几个重要方法

    2.2K10

    使用 UICollectionView 实现首页卡片轮播效果

    UICollectionView 是 iOS6 之后引入的一个新的 UI 控件,与 UITableView 有着很多相似的地方,在开发过程中我们都会选择使用它们俩来为 App 的整个页面进行布局,比如说淘宝的首页...如何使用 UICollectionView 实现网易云首页卡片轮播效果。..., cellForItemAt indexPath: IndexPath) -> UICollectionViewCell { if self.imageUrlStrArray !...self.currentIndex() + 1 self.scrollToIndex(targetIndex: &targetIndex) } 到这里这个轮播控件的功能已经初步完成了,但是如果要正式在...万事具备,只欠东风啊(数据),最后还得给轮播控件提供一个对外的数据加载接口,代码如下: // 网络图片URL private var imageUrlStrArray: [BannerModel

    2.1K20

    iOS 面试策略之系统框架-UIScrollView及其子类

    9.说说实现预加载的方法 关键词:#网络传输 #无限滚动 #Threshold 在实际开发中,列表经常需要随着滑动而不停的展示新的内容。在滑动到一定程度后,我们就需要发送网络请求,以获得新的数据。...以上就是一种最简单的预加载方法。它的缺点十分明显,就是当列表很长时,会出现新加载的页面还没看,应用就会发出另一次请求的情况。...例如用惰性加载只处理用户想看到的内容,或是用 ASDK 进行智能预加载。这样可以进一步提高用户体验,并使整个滑动的性能效率最大化。 10.如何用 UICollectionView 实现瀑布流界面?...高度我们可以先设定为 0,之后在 prepare() 里进行更新。 prepare()。该方法发生在 UICollectionView 数据准备好,但界面还未布局之时。...prepare() 完成布局之后该方法被调用,它决定了哪些 item 在 CollectionView 给定的区域内可见。我们只要取交集(intersect)即可。

    2.7K21

    Swift 自定义布局实现瀑布流视图

    自打 Apple 在 iOS6 中引入 UICollectionView 这个控件之后,越来越多的 iOS 开发者选择将它作为构建 UI 的首选,如此吸引人的原因在于它的可定制化程度非常的高,非常的灵活...说到布局 layout,大家在开发过程中与 UICollectionView 搭配使用最多的 应该就是 UICollectionViewFlowLayout 了,这是 UIKit 提供给开发者最基础的的网格布局...那么,我们该如何来实现一个自定义布局呢!...,我们先了解一下 UICollectionView 的布局过程,它与布局对象之间的关系是一种协作的关系,当 UICollectionView 需要一些布局信息的时候,它会去调用布局对象的一些函数,这些函数的执行是有一定的次序的..., cellForItemAt indexPath: IndexPath) -> UICollectionViewCell { let cell = collectionView.dequeueReusableCell

    2.6K30

    (转)iOS开发之UICollectionViewController系列(一) :Ready CollectionViewController

    在一些开源社区上分享的效果比较炫的代码,有不少是使用UICollectionView做的,UICollectionViewController是很实用的,很有必要好好的搞一下。 一....UIContentContainer 是iOS8之后添加的新的协议,也是和Size Class相关的协议。该协议中的方法可以帮助你适配视图控制器上的内容,比如内容尺寸和位置等。...2.当从nib文件或者Storyboard中加载集合视图时,集合视图的数据源(Data source)和代理对象(Delegate Object)是从nib或者Storyboard中获取的。...你可以重写loadView或者其他超类中的方法,但是如果你这样做, 你必须确保在你实现的方法中使用super调用了超类中相应的方法。...布局会控制集合视图上的单元格(Cell)的排列方式。默认的是Flow Layout. ?

    5.5K40

    iOS开发之窥探UICollectionViewController(一) -- Ready Your CollectionViewController

    在一些开源社区上分享的效果比较炫的代码,有不少是使用UICollectionView做的,UICollectionViewController是很实用的,很有必要好好的搞一下。 一. ...UIContentContainer 是iOS8之后添加的新的协议,也是和Size Class相关的协议。该协议中的方法可以帮助你适配视图控制器上的内容,比如内容尺寸和位置等。...你可以重写loadView或者其他超类中的方法,但是如果你这样做, 你必须确保在你实现的方法中使用super调用了超类中相应的方法。...布局会控制集合视图上的单元格(Cell)的排列方式。默认的是Flow Layout. ? 2....3.在代码中实现相应的代理,和TableView非常类似 (1) 返回Section个数的方法 - (NSInteger)numberOfSectionsInCollectionView:(UICollectionView

    1.6K60

    浏览器将标签转成 DOM 的过程

    对于文本存在许多可能的编码—浏览器的工作是找出如何正确地解码文本。服务器应该通过 Content-Type 提供的信息同时在文本文件头部使用 Byte Order Mark 告知浏览器编码格式。...最坏的情况是,浏览器进行了有根据的猜测,然后开始解析之后发现一个矛盾的 标签。在这些罕见的情况下,解析器必须重新启动,丢弃之前解码的内容。...预解析 在执行脚本时,其他线程会解析文档的其余部分,找出并加载需要通过网络加载的其他资源。通过这种方式,资源可以在并行连接上加载,从而提高总体速度。...使用 JavaScript,网页可以几乎以任何方式重新排列 DOM 树,即使它没有意义,例如,添加表格单元格作为 标签的子项,渲染系统负责弄清楚如何处理任何前后不一致标签。...,以及用于从表中删除和添加行和单元格的快捷方式。

    2.1K00

    浏览器是如何将标签转成 DOM ?

    对于文本存在许多可能的编码—浏览器的工作是找出如何正确地解码文本。服务器应该通过 Content-Type 提供的信息同时在文本文件头部使用 Byte Order Mark 告知浏览器编码格式。...最坏的情况是,浏览器进行了有根据的猜测,然后开始解析之后发现一个矛盾的 标签。在这些罕见的情况下,解析器必须重新启动,丢弃之前解码的内容。...预解析 在执行脚本时,其他线程会解析文档的其余部分,找出并加载需要通过网络加载的其他资源。通过这种方式,资源可以在并行连接上加载,从而提高总体速度。...使用 JavaScript,网页可以几乎以任何方式重新排列 DOM 树,即使它没有意义,例如,添加表格单元格作为 标签的子项,渲染系统负责弄清楚如何处理任何前后不一致标签。...,以及用于从表中删除和添加行和单元格的快捷方式。

    1.9K10

    (转)iOS开发之UICollectionViewController系列(三) :UICollectionView自定义瀑布流

    1.布局预加载函数 当布局首次被加载时会调用prepareLayout函数,见名知意,就是预先加载布局,在该方法中可以去初始化布局相关的数据。...1.重写prepareLayout方法去初始化一些数据,该方法在CollectionView重新加载时只会调用一次,所以把一些参数的配置,计算每个Cell的宽度,每个Cell的高度等代码放在预处理函数中...在该函数中具体调用的函数如下所示: Objective-C #pragma mark -- 虚基类中重写的方法 /** * 该方法是预加载layout, 只会被执行一次 */...在此函数中会调用求CellY数组中的最大值。...把上述写死的配置参数,通过Delegate提供,使其在UICollectionView可进行配置,其配置方式类似于UICollectionViewDelegateFlowLayout的代理方法。

    6.1K40

    iOS开发之窥探UICollectionViewController(三) --使用UICollectionView自定义瀑布流

    1.布局预加载函数 当布局首次被加载时会调用prepareLayout函数,见名知意,就是预先加载布局,在该方法中可以去初始化布局相关的数据。...1.重写prepareLayout方法去初始化一些数据,该方法在CollectionView重新加载时只会调用一次,所以把一些参数的配置,计算每个Cell的宽度,每个Cell的高度等代码放在预处理函数中...在该函数中具体调用的函数如下所示: 1 #pragma mark -- 虚基类中重写的方法 2 3 /** 4 * 该方法是预加载layout...在此函数中会调用求CellY数组中的最大值。...把上述写死的配置参数,通过Delegate提供,使其在UICollectionView可进行配置,其配置方式类似于UICollectionViewDelegateFlowLayout的代理方法。

    1.4K100

    教你写个多表视图

    解决的办法是可以自己写个重用机制,不过这显然没必要,用自带重用机制的UICollectionView应该是个更好的选择。...然后要用 layout 控制布局,用最常用的 UICollectionViewFlowLayout 就行了,设置单元格的宽高,既然是翻页,宽肯定是跟屏幕等宽,高度就看你需求了,但是不要超过 collectionView...lazyLayout.minimumLineSpacing = 0 lazyLayout.scrollDirection = .Horizontal return lazyLayout }() 之后就可以用这个...好现在我们看看如何定义这个 dataSource: class HomeTableDataSource: NSObject, UITableViewDataSource { var cellData...这边 cell 是会被复用的,在翻到第三页时,会复用第一页的 cell ,第四页复用第二页的 cell……依此类推,所以需要给 cell 中的tableView调用 reloadData方法,不然就算改变了表中的数据

    1.3K30

    优雅的处理网络数据,你真的会吗?不如看看这篇.

    ,然后在控件底部显示一个 Loading 动画,待请求数据返回后,Loading 动画消失,由 UITableView 或者 UICollectionView 控件继续加载这些数据并显示给用户,效果如下图所示...为了改善应用程序体验,在 iOS 10 上,Apple 对 UICollectionView 和 UITableView 引入了 Prefetching API,它提供了一种在需要显示数据之前预先准备数据的机制...image 如何实现 由于 Instagram 的 UI 过于复杂,在这我就不去模仿实现了,但是我模仿了它的加载机制,同样的实现了一个简单的数据无限滚动和无缝加载的效果。...viewDidLoad 中先请求网络数据来获取一些初始化数据,然后再利用 UITableView 的 Prefetching API 来对数据进行预加载,从而来实现数据的无缝加载。...我们可以在 tableView:willDisplayCell:forRowAtIndexPath: 这个方法中进行数据绑定,这个方法在显示cell之前会被调用。

    1.4K20

    iOS开发之窥探UICollectionViewController(五) --一款炫酷的图片浏览组件

    二.该自定义布局的使用方式 我们先看一下该自定义布局是如何使用的,然后再通过使用方式来逐步介绍它是如何实现的。这也是一个由浅入深的过程,因为用起来要比做起了更容易。比如开汽车容易,造汽车可就麻烦多了。...所以在本篇博客的第二部分,将要介绍如何去使用该自定义组件。...如何实现 上面介绍了如何去使用该自定义组件,接下来就是“造车”的过程了。本篇博客的第三部分介绍如何去实现这个自定义布局。 1. ...预加载布局方法, 该方法会在UICollectionView加载数据时执行一次,在该方法中负责调用一些初始化函数。具体如下所示。...SCREEN_WIDTH/2; 11 12 return proposedContentOffset; 13 } View Code 4.下方就是我自己实现的方法了,也就在重写的方法中调用的函数

    1.5K80
    领券