網站首頁 編程語言 正文
本文實例為大家分享了iOS實現簡易的抽屜效果的具體代碼,供大家參考,具體內容如下
1.添加需要實現抽屜效果的三個視圖,這里需要注意主視圖需要放在最后添加
// 左邊視圖 ?... // 右邊視圖 ? ... // 主視圖 ? ? UIView *mainView=[[UIView alloc]initWithFrame:self.view.bounds]; ? ? mainView.backgroundColor=[UIColor greenColor]; ? ? _mainView=mainView; ? ? [self.view addSubview:mainView];
2.實現左滑顯示左邊視圖,右滑出現右邊視圖
添加平移手勢和點擊手勢,實現左右滑動的監聽和點擊復位的效果
// 添加平移手勢 ? ? UIPanGestureRecognizer *panGes=[[UIPanGestureRecognizer alloc]initWithTarget:self action:@selector(panGes:)]; ? ? [self.mainView addGestureRecognizer:panGes]; ? ? // 添加點擊返回手勢 ? ? UITapGestureRecognizer *tapGes=[[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(tap)]; ? ? [self.view addGestureRecognizer:tapGes];
在平移手勢調用的方法中,通過偏移量來確定mainView的frame,實現動畫效果
- 首先通過
translationInView:
方法獲取偏移量,通過偏移量的正負確定拖動的方向 - 當手指松開后需要根據mainView的x值確定其視圖是定位到原始位置還是其縮放的位置
- 要其視圖由當前點位移到目標位置,可以通過當前點到目標點的位移,然后調用
frameWithOffsetX:
方法獲得mainView的frame
#define targetR 300 #define targetL -300 - (void)panGes:(UIPanGestureRecognizer *)panGes { ? ? // 獲取偏移量 ? ? CGPoint tranP=[panGes translationInView:self.mainView]; ? ? // 獲得位移后的視圖 ? ? self.mainView.frame=[self frameWithOffsetX:tranP.x]; ? ? // 判斷拖動方向 ? ? if (self.mainView.frame.origin.x<0) {//向左 ? ? ? ? self.rightView.hidden=NO; ? ? }else if(self.mainView.frame.origin.x>0) ? ? {// 向右 ? ? ? ? self.rightView.hidden=YES; ? ? } ? ? // 當手指松開時,做自動定位 ? ? CGFloat target=0; ? ? if (panGes.state==UIGestureRecognizerStateEnded) { ? ? ? ? if (self.mainView.frame.origin.x>0.5*screenW) { ? ? ? ? ? ? target=targetR; ? ? ? ? }else if(CGRectGetMaxX(self.mainView.frame)<0.5*screenW) ? ? ? ? { ? ? ? ? ? ? target=targetL; ? ? ? ? } ? ? ? ? //offset為當前點到其目標點的位移 ? ? ? ? CGFloat offset=target-self.mainView.frame.origin.x; ? ? ? ? [UIView animateWithDuration:0.5 animations:^{ ? ? ? ? ? ? self.mainView.frame=[self frameWithOffsetX:offset]; ? ? ? ? }]; ? ? } ? ? // 復位 ? ? [panGes setTranslation:CGPointZero inView:self.mainView]; }
#define maxY 120 // 根據mainView在X軸方向位移確定mainView的尺寸 - (CGRect)frameWithOffsetX:(CGFloat)offsetX { ? ? CGRect frame=self.mainView.frame; ? ? frame.origin.x+=offsetX; ? ? frame.origin.y=fabs(frame.origin.x / screenW * maxY); ? ? frame.size.height=screenH - frame.origin.y * 2; ? ? return frame; }
3.如何讓其他文件也能實現抽屜效果
- 首先拖入文件,然后新建一個新的ViewController,讓其繼承自我們導入的文件
@interface ViewController :AZDrawerController
- 新建要實現抽屜效果的界面,添加其視圖至我們的mainView中,并且讓其控制器也成為界面控制器的子控件,讓控制器單獨的管理
// 當一個控制器的View添加到另一個控制器的View上的時候,那此時View所在的控制器也應該成為上一個控制器的子控制器. ? ? AZTableViewController *vc1=[[AZTableViewController alloc]init]; ? ? vc1.view.frame=self.mainView.bounds; ? ? [self.mainView addSubview:vc1.view]; ? ? [self addChildViewController:vc1];
原文鏈接:https://blog.csdn.net/azhang_coder/article/details/53428581
相關推薦
- 2022-06-17 Android?SearchView搜索控件使用方法詳解_Android
- 2022-08-03 Android開發手冊Chip監聽及ChipGroup監聽_Android
- 2022-06-21 .NET?Core?API之格式化輸出對象OutputFormatter_實用技巧
- 2022-11-25 詳解Python中的數據精度問題_python
- 2022-12-09 C++中使用cout以hex格式輸出方式_C 語言
- 2022-02-23 在項目中全局自動加載默認圖的技巧
- 2022-09-08 pytorch關于Tensor的數據類型說明_python
- 2022-08-30 啟動Activity但是不顯示界面
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支