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

首頁 > 系統(tǒng) > iOS > 正文

iOS模仿QQ側(cè)邊欄的實(shí)現(xiàn)方法實(shí)例

2019-10-21 18:42:50
字體:
供稿:網(wǎng)友

前言

新版QQ在UI方面做了不少更新,其中一個比較炫酷的效果就是其側(cè)滑導(dǎo)航欄。雖然這種UI已經(jīng)是被模仿來模仿去爛掉牙了,雖然有統(tǒng)計說這種設(shè)計的用戶體驗并不好。但是我本人還是非常喜歡這種效果的,下面就來一起看看詳細(xì)的實(shí)現(xiàn)方法吧。

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

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

ios,qq側(cè)邊欄,仿qq側(cè)邊欄,側(cè)邊欄

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

代碼

 [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];   //添加點(diǎn)擊手勢 [self.mainVc.view addGestureRecognizer:self.tap];

關(guān)于手勢的處理,模擬一個側(cè)滑的臨界速度,姑且定位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];}

關(guān)于添加的手勢和系統(tǒng)的邊緣手勢沖突的問題,解決如下:

在子類化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;}

發(fā)現(xiàn)QQ的二級頁面添加了全屏手勢,所以也把UINavigationController+FDFullscreenPopGesture.h添加了進(jìn)去,發(fā)現(xiàn)原來沖突的手勢也不沖突了。

效果圖:

ios,qq側(cè)邊欄,仿qq側(cè)邊欄,側(cè)邊欄

demo地址:仿QQ側(cè)邊欄

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網(wǎng)的支持。


注:相關(guān)教程知識閱讀請移步到IOS開發(fā)頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 信阳市| 黄梅县| 南岸区| 台北市| 大英县| 溧水县| 基隆市| 江城| 东源县| 兴义市| 兴宁市| 丰顺县| 广丰县| 清丰县| 台安县| 彩票| 嘉荫县| 乌海市| 元朗区| 天祝| 门源| 灯塔市| 六安市| 长宁县| 太保市| 富锦市| 安达市| 大连市| 右玉县| 广昌县| 屏南县| 高州市| 报价| 大姚县| 思茅市| 晋城| 漳平市| 青阳县| 洛阳市| 德清县| 青浦区|