iOS:如何复用两个view实现可无限滚动的全屏页面

学iOS的应该没有没用过tableView的吧,tableView里面会对dequeueReusableCellWithIdentifier申明的cell根据identifier进行复用,而cell的复用相信会让一些初学者有一些困扰,它是怎么实现复用的,为什么我这么写,cell会变得好乱,完全不是我想要的。
而在平常的需求里面也会遇到一些需要横向的可循环使用的视图的需求
如下图,

headTabbarWithViews.gif

如果每需要一个就重新创建一个view的话,这么多view会占用太多的内存了,而且其实很多view,完全是占着茅坑不拉屎。所以,我们一般都会用复用其中的view,如果我们实现了这样一个有复用视图,对于以后多个imageViewtableView等就有一个比较好的处理方法了

以上就是我写这个pageListView的原因, 1.增强对于复用的理解 2.便于平常项目里面对于一些可重复使用的view做一个简单地集成封装。

其实我们要实现的pageListView复用的原理和tableView对于cell的复用的原理基本一致,只是简单了很多。因为我们目前考虑的都是一页一页的切换。所以不必考虑这个viewsize和滑动完之后停留在两个view中间的情况。

简单说一下我们目前的思路,其实和tableViewCell复用的机制类似,创建两个池子,一个放可视区域的views,另一个放可复用views。当需要展示一个view,而复用池为空时,就创建一个新的view,并将这个view放在可视views池,如果一个view已经完全出了可视区域,就把它放入复用池,每次加载view的时候给view设置一下frame
上面讲了最基本的思路,下面让我们来实现看看。

https://github.com/redihd/PageListView
这个是我实现一个可复用的pageListView的代码,想看的可以拉下来看一下。
下面我会用我实现的代码来做简单的讲解。

pageView.h

因为要实现的view很简单,所以我们在.h文件中也没有太多的属性与方法,主要就是有个三个block来实现类似tableViewdatasourcedelegate。其中loadViewAtIndexBlock 需要两个传入参数,会有一个返回的view,这个block实现了类似- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath;这个方法。在接下来我们会细讲这个block的功能。
再来看.m文件里面的属性

pageview.m头

我们将一些不需要对外暴露的都放在了.m中,其中两个属性visibleListViewsItems,dequeueViewPool是实现能够复用viewpageView的关键。
visibleListViewsItems :这个可变字典用来存储可视区域的视图及其对应的index。
dequeueViewPool:这个可变set用来存储可复用的视图。
.m文件中大多数方法都是设置frame,位移等,我们这里不谈,主要介绍其中几个关键方法

loadDequeueViewAndVisibleViewsIfNeeded.png

loadDequeueViewAndVisibleViewsIfNeeded该方法主要是在scrollview的contentOffset.x变化时,计算应该要在可视视图字典中的视图,把旧的可视视图字典里面的视图移动到可重用视图池,然后将要新的展示的视图取出来,加入可视视图字典。

loadViewAtIndex

loadViewAtIndex该方法主要是从我们datasourceblock获取要展示的view,这个view默认是从复用池即visibleListViewsItems任意取一个view来当做我们将要展示的view,并将其与index加入visibleListViewsItems,如果block提供的view为空,再新建一个view。然后将原来在view要展示的位置的视图(如果还有的话)移除,并加入visibleListViewsItems

基本思路就是这样了

然后关于如何使用这个view

initPageView.png

totalPagesCountBlock 这个block设置有多少个view要展示
loadViewAtIndexBlock 这个block处理可重用的视图
pageViewClickBlock 这个block处理点击事件
个人比较喜欢用block,所以把delegate和datasource都用block来做了。

最后跑一下,可以看到,即使设置了60000个,但是cpu和memory都还是很小。


run

最后,其实我们现在要实现这种视图,用横向的collectionView来做就好了。但是,写一个这种对于个人理解一些东西的实现还是有帮助的。接下来可能会把这个写的更详细,功能再多一些。
另外再就是自己用uiview实现一个缺一部分功能的scrollView。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容