iOS中仿QQ侧滑菜单功能
发布时间 - 2026-01-11 02:25:43 点击率:次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
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Win11怎样安装网易有道词典_Win11安装词典教程【步骤】
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
如何在景安服务器上快速搭建个人网站?
html5如何设置样式_HTML5样式设置方法与CSS应用技巧【教程】
JS中对数组元素进行增删改移的方法总结
iOS验证手机号的正则表达式
如何在Windows环境下新建FTP站点并设置权限?
Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程
Laravel怎么实现微信登录_Laravel Socialite第三方登录集成
JavaScript常见的五种数组去重的方式
郑州企业网站制作公司,郑州招聘网站有哪些?
常州企业网站制作公司,全国继续教育网怎么登录?
php在windows下怎么调试_phpwindows环境调试操作说明【操作】
浅谈redis在项目中的应用
Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理
详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点
高性能网站服务器配置指南:安全稳定与高效建站核心方案
深圳网站制作培训,深圳哪些招聘网站比较好?
如何在阿里云服务器自主搭建网站?
js实现获取鼠标当前的位置
Laravel控制器是什么_Laravel MVC架构中Controller的作用与实践
如何用AWS免费套餐快速搭建高效网站?
Laravel N+1查询问题如何解决_Eloquent预加载(Eager Loading)优化数据库查询
jQuery中的100个技巧汇总
如何快速上传建站程序避免常见错误?
韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南
Laravel如何使用Livewire构建动态组件?(入门代码)
JS弹性运动实现方法分析
标题:Vue + Vuex + JWT 身份认证的正确实践与常见误区解析
JavaScript如何操作视频_媒体API怎么控制播放
Laravel Admin后台管理框架推荐_Laravel快速开发后台工具
Java解压缩zip - 解压缩多个文件或文件夹实例
如何自定义建站之星网站的导航菜单样式?
香港服务器选型指南:免备案配置与高效建站方案解析
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
原生JS实现图片轮播切换效果
韩国服务器如何优化跨境访问实现高效连接?
如何确保西部建站助手FTP传输的安全性?
如何在腾讯云服务器上快速搭建个人网站?
深圳网站制作平台,深圳市做网站好的公司有哪些?
极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
简历在线制作网站免费版,如何创建个人简历?
微信小程序 五星评分(包括半颗星评分)实例代码
Laravel如何处理表单验证?(Requests代码示例)
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
Laravel Octane如何提升性能_使用Laravel Octane加速你的应用
北京企业网站设计制作公司,北京铁路集团官方网站?
免费视频制作网站,更新又快又好的免费电影网站?
如何批量查询域名的建站时间记录?

