对于新版支付宝首页的产品功能这里就不说什么了,一大堆人吐槽,我们只想要一个好好的支付工具,阿里硬是要融入社交...
今天这里不是来评论支付宝功能的,而是作为一个 iOS 开发人员在使用的过程中发现,首页这滑动好“怪异”啊~~
首先,右侧的滚动条的位置好怪!为什么在中间?只能说明一个问题,这个 tableview 是从这里开始的。
其次,既然 tableview 在中间开始,那上面那一片 view 是如何滚动的(从滚动条可以看出不是 tableviewheader )?而且和 tableview 做到无缝衔接。
再次,滑动 tableview 上面那块 view ,直接响应滑动。
通过上面种种奇怪的现象,于是我决定针对这个效果些一个 demo 来玩玩。
(最后闪的那几下请忽略, gif 图片没有做完美,并不是 demo 的 bug 。。。。)
因为是 demo 嘛,所以代码就尽量简单,处理就基本只放在一个 class 中,这样比较容易理解,大家就不要吐槽这一块了~~~
经过我反复实验,还是 UIScrollView + UITableView 的方式实现最靠谱,那问题来了,如何处理两个 ScrollView 的滑动冲突?
答案就是关掉一个滑动!当然就是关掉 tableview 的滑动,通过外层 scrollview 的 offset 来直接控制 tableview 的滑动,关键代码:
func scrollViewDidScroll(_ scrollView: UIScrollView) {
let y = scrollView.contentOffset.y
if (y <= 0) {
var newFrame = self.headerView.frame
newFrame.origin.y = y
self.headerView.frame = newFrame
newFrame = self.mainTableView.frame
newFrame.origin.y = y + topOffsetY
self.mainTableView.frame = newFrame
//偏移量给到 tableview , tableview 自己来滑动
self.mainTableView.setScrollViewContentOffSet(point: CGPoint(x: 0, y: y))
//功能区状态回归
newFrame = self.functionHeaderView.frame
newFrame.origin.y = 0
self.functionHeaderView.frame = newFrame
} else {
//处理功能区隐藏和视差
var newFrame = self.functionHeaderView.frame
newFrame.origin.y = y/2
self.functionHeaderView.frame = newFrame
}
//处理透明度
let alpha = (1 - y/functionHeaderViewHeight*2.5 ) > 0 ? (1 - y/functionHeaderViewHeight*2.5 ) : 0
functionHeaderView.alpha = alpha
if alpha > 0.5 {
let newAlpha = alpha*2 - 1
mainNavView.alpha = newAlpha
coverNavView.alpha = 0
} else {
let newAlpha = alpha*2
mainNavView.alpha = 0
coverNavView.alpha = 1 - newAlpha
}
}
这里的关键就是当想上滑动的时候,实际就是滑动最外层的 scrollview ,然而想下滑动到顶的时候仅仅只讲 offset 传递给 tableview 让其继续滚动。
tableview 嵌入方式借鉴了:
https://github.com/Zhanggaoyi92/Alipay-8.11-update-demo
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.