前言
NS_CLASS_AVAILABLE_IOS(3_0) __TVOS_PROHIBITED @interface UIMenuController : NSObject
1、UIMenuController 简介
-
1、默认情况下,UITextFiled、UITextView、UIWebView 都有苹果自带的有 UIMenuController 功能。
-
2、UITextFiled 的弹出菜单效果系统自带的,如下图。
-
3、当然,系统只给某些控件提供的该功能,但是我们自己给可以给指定控件添加该功能效果,至于如何添加,我们先简单学习一下,如何使用系统提供的 UIMenuController 功能。
2、menuController 的创建
-
给 Label 添加 UIMenuController 功能步骤:
- 1、设置 UILabel 允许交互。
- 2、给 UILabel 添加手势。
- 3、在 UILabel 手势监听方法中,创建 UIMenuController -> menu。
- 4、设置 menu 位置,利用 UIMenuController 的对象方法
setTargetRect: inView:
方法来设置 menu 显示在在那个控件的那个位置。 - 5、显示 menu,
menu setMenuVisible: animation:
。 - 6、设置 menu 显示内容。
- 注意:
- 得通过第一响应者,来告诉 menu 它内部显示什么内容。如果显示中文标题,就需要手动设置 APP 支持中文。
- 实现:
- 6.1 让 label 成为第一响应者(注意:不一定第一响应者必须是控制器)。
- 6.2 设置 menu 显示 menuItem,告诉 menu 可以显示什么内容。
- 注意:
-
实现代码
@property (weak, nonatomic) IBOutlet UILabel *label; - (void)viewDidLoad { [super viewDidLoad]; // 允许 Label 交互 self.label.userInteractionEnabled = YES; // 给 Label 添加手势 [self.label addGestureRecognizer:[[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(labelClick)]]; } #pragma mark - 监听手势点击事件 - (void)labelClick { // 让 label 成为第一响应者 [self.label becomeFirstResponder]; // 创建菜单 UIMenuController *menu = [UIMenuController sharedMenuController]; // 设置菜单内容,自定义菜单项 menu.menuItems = @[ [[UIMenuItem alloc] initWithTitle:@"顶" action:@selector(ding:)], [[UIMenuItem alloc] initWithTitle:@"回复" action:@selector(reply:)], [[UIMenuItem alloc] initWithTitle:@"举报" action:@selector(warn:)] ]; // 设置菜单箭头的方向 menu.arrowDirection = UIMenuControllerArrowUp; // 菜单最终显示的位置 [menu setTargetRect:self.label.bounds inView:self.label]; // 显示菜单 [menu setMenuVisible:YES animated:YES]; } #pragma mark - UIMenuController 相关 // 让 Label 具备成为第一响应者的资格,UIResponder 方法 - (BOOL)canBecomeFirstResponder { return YES; } // 通过第一响应者的这个方法告诉 UIMenuController 可以显示什么内容,UIResponder 方法 - (BOOL)canPerformAction:(SEL)action withSender:(id)sender { if ((action == @selector(copy:) && self.label.text) || // 需要有文字才能支持复制,系统菜单项 (action == @selector(cut:) && self.label.text) || // 需要有文字才能支持剪切 action == @selector(paste:) || action == @selector(ding:) || // 自定义菜单项 action == @selector(reply:) || action == @selector(warn:)) { return YES; } return NO; } #pragma mark - 监听 MenuItem 的点击事件 - (void)cut:(UIMenuController *)menu { // 将 label 的文字存储到粘贴板 [UIPasteboard generalPasteboard].string = self.label.text; // 清空文字 self.label.text = nil; } - (void)copy:(UIMenuController *)menu { // 将 label 的文字存储到粘贴板 [UIPasteboard generalPasteboard].string = self.label.text; } - (void)paste:(UIMenuController *)menu { // 将粘贴板的文字赋值给 label self.label.text = [UIPasteboard generalPasteboard].string; } - (void)ding:(UIMenuController *)menu { NSLog(@"%s %@", __func__, menu); } - (void)reply:(UIMenuController *)menu { NSLog(@"%s %@", __func__, menu); } - (void)warn:(UIMenuController *)menu { NSLog(@"%s %@", __func__, menu); }
-
效果
3、menuController 的设置
-
系统通知
UIKIT_EXTERN NSNotificationName const UIMenuControllerWillShowMenuNotification; UIKIT_EXTERN NSNotificationName const UIMenuControllerDidShowMenuNotification; UIKIT_EXTERN NSNotificationName const UIMenuControllerWillHideMenuNotification; UIKIT_EXTERN NSNotificationName const UIMenuControllerDidHideMenuNotification; UIKIT_EXTERN NSNotificationName const UIMenuControllerMenuFrameDidChangeNotification;