iOS_不规则Cell的TableView相关设计

案例一:微信,按发送和接收分为左右,图片、文本、语音、红包、文件等等;

案例二:微博,图文混合。

相比微博,那显然是微信的cell来得更复杂,那我们拿类微信的案例来做一次设计。

一、Cell个数

假设消息类型只有文本、图片、语音、红包、文件这5种,加上系统消息(时间分割)一共6种类型。那么我们按照发送和接收分开来计算就是6*2=12种,也就是说我们最多能分为12个Cell。那么问题来了,我们到底需要多少个Cell,先了解下TableView的运行机制。一个TableView假设是单一的Cell复用,手机屏幕上同时最多可见5个cell,那么实际创建的是大于5个Cell的,不然是来不及复用的。那么我们假设这种情况下系统创建了10个(足够用了),那么假设我们设计了12种不同的Cell,理论上来讲系统可能会创建12*10=120个那么多(当然不是那么精确的)......说了那么多,其实没有人会去计较到底有多少个,我只关心的是卡不卡。在现在iPhone的迭代速度来看,支撑120个cell也不是什么问题,即使是在iPhone4上。那么我们来讨论下另一个极端,就是最少我们可以设计1个Cell承接所有消息类型,我相信只要花点时间和死掉几亿个脑细胞去做适配和hidden = YES/NO一定能搞定,并且有一点是毋庸执意的,这样的方式性能是最好的,但是累死了猿们。

上面废话可以简化到一句话:Cell类型越少,性能越好,设计开发维护越难。Cell类型越多,性能越差,设计开发维护越容易。

在开发IM过程中,这两个我都用过,前者是第一版IM,我真的把这么多业务压缩到一个Cell里面去了,最后维护得差点想死,我能活着,还要感谢公司让我开发了第二版,所以我乘机尝试了后者,12个Cell,分的清清楚楚,维护极其容易,甚至在同一个消息业务下,左右不对称(比如群消息中显示接收人的头像,隐藏自己发送的头像)都只需要随意改一个Cell就可以,突然觉得开发简直是一种享受。我们总是很尽职地为一切设想,然后现在的硬件水平已经不鸟我们在这方面付出的代价了(当然不是说性能不考虑,单指Cell这个事情),经过测试,我发现即使是12个Cell,在>=iPhone4的设备上跑得都很欢快。

总结:尽量压榨硬件换取开发成本,不提前优化性能,不过度优化性能,一切以真机运行为准,按需优化。花很大精力和时间,换来1秒到0.9秒的提升,那是傻子。

二、Cell排版

这个相信在Masonry库的协助下,都不是问题。

三、Cell高度

这个是整个设计中最难的部分,理解了其实很简单。由于Cell高度是动态计算的,并且是在Cell的内容排版之前就需要调用到,所以在此无法避免需要提前传入内容来做计算,这是无法避免的事情。

我的经验是:

1、在Cell中写公共方法来计算返回高度:

这样的好处是可以复用Cell中采用Masonry来排版的函数和UI。也就是说高度的计算核心方法,依旧是采用Masonry来排一遍全部的UI+根据传入内容来动态得到整个需要的高度。当然,简单的布局可以直接用设定好的常量来计算并返回,比如语音、图片等。

+(CGFloat)getHeightWithModel:(Model *)model;

2、缓存计算好的高度:

仅有第一步还是不够,因为Cell会被不断复用,也就是在来回滚动的过程中,你曾经计算好的Cell高度在被服用掉之后再次使用的时候依旧会重新计算,虽然硬件不是太介意你这么干,但是这是付出小代价获得大提升的地方。做法就是Array中的Model里增加一个cellHeight的属性,用于保存计算过的Cell高度,这样就可以避免重复计算。

四、动态的图片高度

我曾经也遇到过这样的问题,就是使用SDWebImage类库异步加载图片,这是一个很头疼的问题,第一版IM没有经验,做了这样的设计:

if (ImageIsExist)—>getImageSize

else —>[SDWebImage Download] and [show PlaceholderImage]

通俗点讲就是,在Cell高度计算时候判断本地缓存中是否已存在,存在则拿出来计算size并渲染;不存在就去下载,由于图片是异步下载+Cell不断被复用,所以Block回调并不能保证返回的和现在请求的是不是同一张图片,所以需要model来做防御。而且列表会跳动,因为默认图片是方的,接收到的图片尺寸不一,体验是很糟糕的。

后来第二版中参考微信做了优化,在拿到图片消息的时候,附带了图片的地址和图片缩略图的长宽,这样一来,我可以正常的使用这个长宽来渲染UIImageView,而图片异步下载完毕后仅仅需要更新下即可,免去计算之苦,所以说,设计的重要性对于开发来讲是多么重要。做开发到一定程度,大家水平都差不多,拼得就是设计了,也就是架构。

总结:

以上就是主题的思路,主要能理解设计,我相信任何场景和设计都难不倒开发。

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

推荐阅读更多精彩内容