全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

iOS中仿QQ侧滑菜单功能

UITabBarController做QQ侧滑菜单效果:

首先要了解UITabBarController的层级结构:

UITabBarController加载的其它UIViewController的View都是被添加在UITransitionView上(这是一个私有API),UITransitionView在self.view的0层,UITabBar在的第一层。

所以我的思路是这样的:

UITransitionView与UITabBar转移到一个新的View1上去,作为滑动的部分;

在View1与self.view之间再添加一个View2,作为菜单的容器;

给View1添加相应的手势响应;

代码:

#import <UIKit/UIKit.h>
@protocol SlideTab_VC_TCVDelegate <NSObject>
@optional
-(void)didOpenMenu:(UIView*)menu;
-(void)didCloseMenu:(UIView*)menu;
@end
@interface SlideTab_VC : UITabBarController
@property(strong, nonatomic)UIView *mMenuV;
@property(weak, nonatomic)id <SlideTab_VC_TCVDelegate> mDelegate;
-(void)openMenu;
-(void)closeMenu;
@end
#import "SlideTab_VC.h"
#define DEVICE_W [UIScreen mainScreen].bounds.size.width
@interface SlideTab_VC ()<UITabBarDelegate>{
 CGFloat _centerMaxX;
}
@property(strong, nonatomic)UIView *mTransitionView;
@property(strong, nonatomic)UITapGestureRecognizer *mTapGester;
@property(assign, nonatomic)BOOL mMenuIsOpen;
@property(strong, nonatomic)UITabBar *mTabBar;
@end
@implementation SlideTab_VC
- (void)viewDidLoad {
 [super viewDidLoad];
 // Do any additional setup after loading the view.
 self.view.backgroundColor = [UIColor purpleColor];
 _mMenuIsOpen = NO;
 _centerMaxX = DEVICE_W*3/2-80.0f;
 [self initMTransitionView];
 [self addGestureForMTransitionView];
}
#pragma mark 菜单懒加载
-(void)setMMenuV:(UIView *)mMenuV{
 if (mMenuV!=nil) {
  _mMenuV = mMenuV;
  [self.view insertSubview:_mMenuV atIndex:0];
 }
}
#pragma mark 打开菜单
-(void)openMenu{
 CGPoint center = self.mTransitionView.center;
 center.x = _centerMaxX;
 [UIView animateWithDuration:0.15f animations:^{
  self.mTransitionView.center = center;
  if (_mDelegate != nil&& [_mDelegate respondsToSelector:@selector(didOpenMenu:)]) {
  [_mDelegate didOpenMenu:_mMenuV];
 }
 }];
 [self mTransitionSubViewsEnable:NO];
}
#pragma mark 关闭菜单
-(void)closeMenu{
 CGPoint center = self.mTransitionView.center;
 center.x = DEVICE_W/2;
 [UIView animateWithDuration:0.15f animations:^{
  self.mTransitionView.center = center;
 } completion:^(BOOL finished) {
  [self mTransitionSubViewsEnable:YES];
  if (_mDelegate != nil&& [_mDelegate respondsToSelector:@selector(didCloseMenu:)]) {
  [_mDelegate didCloseMenu:_mMenuV];
 }
 }];
}
#pragma mark Transition用户交互使能
-(void)mTransitionSubViewsEnable:(BOOL)enable{
 for (UIView *tmp in self.mTransitionView.subviews) {
  tmp.userInteractionEnabled = enable;
 }
 if (enable) {
  [self.mTransitionView removeGestureRecognizer:_mTapGester];
 }else{
  [self.mTransitionView addGestureRecognizer:_mTapGester];
 }
}
#pragma mark 配置mTransitionView
-(void)initMTransitionView{
 for (UIView *tmp in self.view.subviews) {
  [tmp removeFromSuperview];
  [self.mTransitionView addSubview:tmp];
 }
 [self.view addSubview:self.mTransitionView];
}
#pragma mark 拖动手势动作
-(void)panAction:(UIPanGestureRecognizer*)pan{
 CGPoint location = [pan translationInView:pan.view.superview];
 CGPoint center = self.mTransitionView.center;
 if (pan.state==UIGestureRecognizerStateEnded) {
  if (center.x<_centerMaxX*0.5+DEVICE_W*0.25){
   [self closeMenu];
  }else{
   [self openMenu];
  }
 }else if(pan.state==UIGestureRecognizerStateChanged){
  if (location.x<0) {//向左滑
   center.x = center.x+location.x<=DEVICE_W/2? DEVICE_W/2 : center.x+location.x;
  }else{
   center.x = center.x+location.x>=_centerMaxX? _centerMaxX : center.x+location.x;
  }
  self.mTransitionView.center = center;
  [pan setTranslation:CGPointMake(0, 0) inView:pan.view.superview];
 }
}
#pragma mark 添加手势
-(void)addGestureForMTransitionView{
 UIPanGestureRecognizer *pan = [[UIPanGestureRecognizer alloc]initWithTarget:self action:@selector(panAction:)];
 [_mTransitionView addGestureRecognizer:pan];
 _mTapGester = [[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(tapAction)];
}
#pragma mark--懒加载
-(UIView *)mTransitionView{
 if (_mTransitionView==nil) {
  _mTransitionView = [[UIView alloc]initWithFrame:self.view.bounds];
 }
 return _mTransitionView;
}
-(void)tapAction{
 CGFloat x = _mTransitionView.center.x;
 if (x>=_centerMaxX) {
  [self closeMenu];
 }
}
@end

总结

以上所述是小编给大家介绍的iOS中仿QQ侧滑菜单功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# ios侧滑菜单  # iOS 纯代码写个侧滑栏功能  # Android仿iOS侧滑退出当前界面功能  # Android仿iOS实现侧滑返回功能(类似微信)  # IOS中Swift仿QQ最新版抽屉侧滑和弹框视图  # iOS中给UITableView的侧滑删除增加多个按钮的实现方法  # LRecyclerView侧滑iOS阻塞效果不完整的解决办法  # iOS实现侧滑栏效果  # iOS禁用侧滑返回手势要点解析  # 加载  # 小编  # 都是  # 在此  # 是这样  # 这是一个  # 给大家  # 拖动  # 要了  # 所述  # 给我留言  # 感谢大家  # 再添  # 第一层  # 疑问请  # 有任何  # 转移到  # optional  # mMenuV  # nonatomic 


相关文章: 制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?  c++怎么用jemalloc c++替换默认内存分配器【性能】  微课制作网站有哪些,微课网怎么进?  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  如何通过商城自助建站源码实现零基础高效建站?  建站之星×万网:智能建站系统+自助建站平台一键生成  公司网站建设制作费用,想建设一个属于自己的企业网站,该如何去做?  如何高效配置IIS服务器搭建网站?  如何选择域名并搭建高效网站?  如何在IIS7上新建站点并设置安全权限?  详解jQuery中基本的动画方法  如何在橙子建站中快速调整背景颜色?  如何选择香港主机高效搭建外贸独立站?  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】  建站之星安装需要哪些步骤及注意事项?  公司网站制作费用多少,为公司建立一个网站需要哪些费用?  建站之星如何助力企业快速打造五合一网站?  北京网站制作网页,网站升级改版需要多久?  高端企业智能建站程序:SEO优化与响应式模板定制开发  常州自助建站工具推荐:低成本搭建与模板选择技巧  如何在万网主机上快速搭建网站?  如何制作网站标识牌,动态网站如何制作(教程)?  网站制作大概多少钱一个,做一个平台网站大概多少钱?  如何通过山东自助建站平台快速注册域名?  如何快速重置建站主机并恢复默认配置?  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  湖州网站制作公司有哪些,浙江中蓝新能源公司官网?  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  在线教育网站制作平台,山西立德教育官网?  建站之星展会模板:智能建站与自助搭建高效解决方案  建站主机无法访问?如何排查域名与服务器问题  网站制作的方法有哪些,如何将自己制作的网站发布到网上?  如何通过VPS建站实现广告与增值服务盈利?  大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?  微信推文制作网站有哪些,怎么做微信推文,急?  C#如何在一个XML文件中查找并替换文本内容  制作网站的网址是什么,请问后缀为.com和.com.cn还有.cn的这三种网站是分别是什么类型的网站?  TestNG的testng.xml配置文件怎么写  如何零基础开发自助建站系统?完整教程解析  山东网站制作公司有哪些,山东大源集团官网?  如何处理“XML格式不正确”错误 常见XML well-formed问题解决方法  建站主机核心功能解析:服务器选择与网站搭建流程指南  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  怎么将XML数据可视化 D3.js加载XML  如何在IIS中新建站点并配置端口与IP地址?  c# await 一个已经完成的Task会发生什么  如何选购建站域名与空间?自助平台全解析  如何快速配置高效服务器建站软件? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。