国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > iOS > 正文

iOS模仿QQ側邊欄的實現方法實例

2020-07-26 02:34:13
字體:
來源:轉載
供稿:網友

前言

新版QQ在UI方面做了不少更新,其中一個比較炫酷的效果就是其側滑導航欄。雖然這種UI已經是被模仿來模仿去爛掉牙了,雖然有統計說這種設計的用戶體驗并不好。但是我本人還是非常喜歡這種效果的,下面就來一起看看詳細的實現方法吧。

分析:QQ側邊欄都用了哪些手勢,有哪些效果?

  • QQ的主頁是個UITabbarController,暫且稱為MainVc左側邊緣添加的手勢為邊緣手勢UIScreenEdgePanGestureRecognizer
  • 當邊緣手勢滑動到屏幕中間時判斷MainVc移動的距離超過屏幕中間,超過就顯示側邊欄,沒超過會自動歸位。
  • MainVc移動的時候會有一層黑色的遮罩,遮罩的透明度和MainVc移動的距離有關。
  • 當側邊欄出現的時候,此時MainVc添加的手勢更換為平移手勢UIPanGestureRecognizer。判斷MainVc移動的距離和第二步一樣。
  • 添加的手勢和系統的邊緣手勢沖突如何處理。
  • 當側邊欄隱藏的時候,給MainVc一個很大的速度,會立即顯示側邊欄。當側邊欄出現的時候,給側邊欄一個很大的速度,會立即顯示MainVc。

層級關系如上圖:MainVc 在側邊欄 上面,只需要添加手勢來控制側邊欄的顯示與隱藏即可。

代碼

 [self addChildViewController:self.leftVc]; [self addChildViewController:self.mainVc];   [self.mainVc didMoveToParentViewController:self];   [self.leftVc didMoveToParentViewController:self];//添加屏幕邊緣平移手勢 [self.mainVc.view addGestureRecognizer:self.pan1];   //添加平移手勢 [self.mainVc.view addGestureRecognizer:self.pan2];   //添加點擊手勢 [self.mainVc.view addGestureRecognizer:self.tap];

關于手勢的處理,模擬一個側滑的臨界速度,姑且定位1000.

#pragma mark---手勢處理-(void)screenGesture:(UIPanGestureRecognizer *)pan{ //移動的距離 CGPoint point = [pan translationInView:pan.view]; //移動的速度 CGPoint verPoint = [pan velocityInView:pan.view]; self.mainVc.view.lx_x += point.x; //邊界限定 if (self.mainVc.view.lx_x >= MAXLEFTSLIDEWIDTH) {  self.mainVc.view.lx_x = MAXLEFTSLIDEWIDTH; } if (self.mainVc.view.lx_x <= 0) {  self.mainVc.view.lx_x = 0; } //蒙版的陰影限定 self.maskView.alpha = self.mainVc.view.lx_x /MAXLEFTSLIDEWIDTH; if (pan.state == UIGestureRecognizerStateEnded) {  //判斷手勢  if (pan == self.pan1) {   if (verPoint.x > MAXSPEED) {     [self showLeftVc];   }else{    if (self.mainVc.view.lx_x >= Device_Width/2) {     [self showLeftVc];          }else{           [self hideLeftVc];     }   }  }else{   if (verPoint.x < - MAXSPEED) {         [self hideLeftVc];   }else{    if (self.mainVc.view.lx_x >= Device_Width/2) {          [self showLeftVc];          }else{           [self hideLeftVc];         }   }  }      }   [pan setTranslation:CGPointZero inView:pan.view];}

關于添加的手勢和系統的邊緣手勢沖突的問題,解決如下:

在子類化UINavigationController

- (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view. self.navigationBar.translucent = YES; self.navigationBar.barTintColor = LXMainColor; self.interactivePopGestureRecognizer.delegate = self;}#pragma mark--防止與添加到tabbar的手勢沖突---(BOOL)gestureRecognizerShouldBegin:(UIGestureRecognizer *)gestureRecognizer{ if (self.childViewControllers.count <= 1) {  return NO; } return YES;}

發現QQ的二級頁面添加了全屏手勢,所以也把UINavigationController+FDFullscreenPopGesture.h添加了進去,發現原來沖突的手勢也不沖突了。

效果圖:

demo地址:仿QQ側邊欄 (本地下載)

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 乐业县| 呼玛县| 金沙县| 衡南县| 阿巴嘎旗| 丰原市| 思南县| 惠州市| 平南县| 柘荣县| 滦南县| 涪陵区| 普兰店市| 凤阳县| 黄陵县| 连江县| 旅游| 苏尼特右旗| 平舆县| 尖扎县| 闵行区| 浠水县| 麻栗坡县| 无极县| 佳木斯市| 大兴区| 永泰县| 溧水县| 辛集市| 沐川县| 上犹县| 北宁市| 双柏县| 平阳县| 昭苏县| 达拉特旗| 邵阳县| 德格县| 德钦县| 项城市| 永兴县|