網(wǎng)站首頁 編程語言 正文
正文
在網(wǎng)上找了很多,沒有喜歡的方案。也參考了眾多設(shè)計(jì),做了一款自認(rèn)為比較簡潔、完美的方案:
大致思路:外層放置scrollview作為容器,容器內(nèi)上部分topView,下部分tableView。當(dāng)tableView滾動(dòng)時(shí),如果topView還在展示區(qū)域,就設(shè)置topView的y坐標(biāo),讓topView跟隨同步上移。
(注意:如果不設(shè)置tableView的headerView,tableView、和topView都會(huì)同時(shí)上移不是我想要的效果,所以設(shè)置tableView的headerView高度包括topView的高度,達(dá)到了完美的效果,具體實(shí)現(xiàn)看demo)
效果預(yù)覽:
NestScrollView.gif
核心代碼就是在父視圖、子試圖的滾動(dòng)判斷
//父視圖滾動(dòng)的回調(diào),用于橫向滾動(dòng)判斷
//父視圖滾動(dòng)的回調(diào),用于橫向滾動(dòng)判斷
- (void)scrollViewDidScroll:(UIScrollView *)scrollView{
CGFloat placeholderOffset = 0;
if (self.topView.selectedIndex == 0) {
if (self.firstTableView.contentOffset.y > CGRectGetHeight(self.topView.frame) - kItemheight) {
placeholderOffset = CGRectGetHeight(self.topView.frame) - kItemheight;
}else {
placeholderOffset = self.firstTableView.contentOffset.y;
}
[self.secondTableView setContentOffset:CGPointMake(0, placeholderOffset) animated:NO];
}else {
if (self.secondTableView.contentOffset.y > CGRectGetHeight(self.topView.frame) - kItemheight) {
placeholderOffset = CGRectGetHeight(self.topView.frame) - kItemheight;
}else {
placeholderOffset = self.secondTableView.contentOffset.y;
}
[self.firstTableView setContentOffset:CGPointMake(0, placeholderOffset) animated:NO];
}
}
//子視圖滾動(dòng)的回調(diào),用于豎直方向上滾動(dòng)判斷
//子視圖滾動(dòng)的回調(diào),用于豎直方向上滾動(dòng)判斷
- (void)updateTopViewFrame:(UIScrollView *)scrollView{
CGFloat placeHolderHeight = CGRectGetHeight(self.topView.frame) - self.topView.itemHeight;
CGFloat offsetY = scrollView.contentOffset.y;
CGFloat y = 0.0;
if (offsetY >= 0 && (offsetY <= placeHolderHeight)) {
y = -offsetY;
} else if (offsetY > placeHolderHeight) {
y = -placeHolderHeight;
} else if (offsetY < 0) {
y = -offsetY;
}
[self.topView mas_updateConstraints:^(MASConstraintMaker *make) {
make.top.offset(y + kNavBarHeight);
}];
}
githut demo下載地址:https://github.com/biyuhuaping/NestScrollView
原文鏈接:https://www.jianshu.com/p/10184963a187
相關(guān)推薦
- 2022-10-28 ReactDOM?隱藏特性詳解_React
- 2022-07-16 windows安全加固--關(guān)閉非必要端口
- 2022-03-22 C語言寫一個(gè)散列表_C 語言
- 2022-08-20 Python操作HDF5文件示例_python
- 2022-06-27 Python數(shù)據(jù)類型和常用操作_python
- 2022-03-04 element-ui table超過一行顯示...鼠標(biāo)滑過顯示全部
- 2022-03-28 c語言經(jīng)典習(xí)題之逆序字符串詳解_C 語言
- 2024-01-16 URLClassLoader詳解
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支