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
相关文章:
网站制作与设计教程,如何制作一个企业网站,建设网站的基本步骤有哪些?
如何快速生成橙子建站落地页链接?
武清网站制作公司,天津武清个人营业执照注销查询系统网站?
如何在阿里云ECS服务器部署织梦CMS网站?
网站制作多少钱一个,建一个论坛网站大约需要多少钱?
新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?
建站之星安全性能如何?防护体系能否抵御黑客入侵?
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
模具网站制作流程,如何找模具客户?
厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?
建站主机数据库如何配置才能提升网站性能?
子杰智能建站系统|零代码开发与AI生成SEO优化指南
如何在阿里云服务器自主搭建网站?
开封网站制作公司,网络用语开封是什么意思?
宿州网站制作公司兴策,安徽省低保查询网站?
如何通过.red域名打造高辨识度品牌网站?
清除minerd进程的简单方法
如何通过西部数码建站助手快速创建专业网站?
如何确认建站备案号应放置的具体位置?
一键网站制作软件,义乌购一件代发流程?
电商平台网站制作流程,电商网站如何制作?
佛山企业网站制作公司有哪些,沟通100网上服务官网?
建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析
广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?
高防服务器租用指南:配置选择与快速部署攻略
如何快速生成凡客建站的专业级图册?
潮流网站制作头像软件下载,适合母子的网名有哪些?
,网页ppt怎么弄成自己的ppt?
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
如何在宝塔面板中创建新站点?
武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?
如何在沈阳梯子盘古建站优化SEO排名与功能模块?
网站企业制作流程,用什么语言做企业网站比较好?
小自动建站系统:AI智能生成+拖拽模板,多端适配一键搭建
如何通过IIS搭建网站并配置访问权限?
建站之星×万网:智能建站系统+自助建站平台一键生成
大连网站设计制作招聘信息,大连投诉网站有哪些?
如何在香港免费服务器上快速搭建网站?
建站之星代理商如何保障技术支持与售后服务?
如何通过宝塔面板实现本地网站访问?
义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?
建站为何优先选择香港服务器?
如何通过PHP快速构建高效问答网站功能?
外贸公司网站制作,外贸网站建设一般有哪些步骤?
如何选择高效响应式自助建站源码系统?
建站之星后台密码遗忘如何找回?
建站之星好吗?新手能否轻松上手建站?
如何快速配置高效服务器建站软件?
建站之星安装需要哪些步骤及注意事项?
如何确保西部建站助手FTP传输的安全性?
*请认真填写需求信息,我们会在24小时内与您取得联系。