版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/ws_752958369/article/details/84762291
像QQ,微信那种长按消息然后弹出黑色的菜单栏,如下图所示:
使用方法也相对较为简单,使用步骤如下:
1、给目标视图添加长按点击事件
UILongPressGestureRecognizer *longPress = [[UILongPressGestureRecognizer alloc] initWithTarget:self action:@selector(longPress:)];
[cell addGestureRecognizer:longPress];
这里我是直接添加到tableViewCell上。
2、实现长按点击事件
- (void)longPress:(UIGestureRecognizer *)recognizer{
if (recognizer.state == UIGestureRecognizerStateBegan) {
[self becomeFirstResponder];//此方法没必须实现
UIView *superView = recognizer.view;
UIMenuController *menuController = [UIMenuController sharedMenuController];
UIMenuItem *menuItem0 = [[UIMenuItem alloc] initWithTitle:@"test0" action:@selector(test0)];
UIMenuItem *menuItem1 = [[UIMenuItem alloc] initWithTitle:@"test1" action:@selector(test1)];
UIMenuItem *menuItem2 = [[UIMenuItem alloc] initWithTitle:@"test2" action:@selector(test2)];
UIMenuItem *menuItem3 = [[UIMenuItem alloc] initWithTitle:@"test3" action:@selector(test3)];
[menuController setMenuItems:@[menuItem0,menuItem1,menuItem2,menuItem3]];
[menuController setTargetRect:superView.bounds inView:superView];
[menuController setMenuVisible:YES animated:YES];
NSLog(@"menuFrame:%@",NSStringFromCGRect(menuController.menuFrame));
}
}
这里有个注意事项,在设置tartgetRect的时候,不要去自定义frame,这样会导致奇怪的偏移显示或者完全不出现,最好就直接使用添加视图的bounds即可,这样写还有个好处是,系统会自动去调整黑色菜单栏的位置和箭头方向,避免被挡住(显示层级比导航栏靠前)。
3、设置在UIMenuController实现的功能文件里实现如下两个方法内容,表示能够响应事件:
-(BOOL)canBecomeFirstResponder{
return YES;
}
-(BOOL)canPerformAction:(SEL)action withSender:(id)sender
{
if (action == @selector(test0)||action == @selector(test1)||action == @selector(test2)||action == @selector(test3)) {
return YES;
}
return NO;
}
4.最后再实现各自菜单功能的响应方法内容即可
- (void)test0
{
NSLog(@"test0");
//在点击事件里面隐藏菜单栏,这里其实实不实现都可以,系统在点击会自动帮我们隐藏掉
//[[UIMenuController sharedMenuController] setMenuVisible:NO animated:YES];
}
- (void)test1
{
NSLog(@"test1");
}
- (void)test2
{
NSLog(@"test2");
}
- (void)test3
{
NSLog(@"test3");
}
到此,所有的准备事项已经弄好,开始写你们的业务代码了。。。