前言

	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;

最新文章

  1. 白话贝叶斯理论及在足球比赛结果预测中的应用和C#实现
  2. Winform DataGridView控件添加行号
  3. php课程---随机数
  4. ArrayList代码示例
  5. C语言基础--循环 递归打印乘法表
  6. oracle 多级菜单查询 。start with connect by prior
  7. swift也开源了.
  8. sql server 之函数小技巧 && 整数类型为空是用空字符串替代实现
  9. UVa OJ 197 - Cube (立方体)
  10. 给OCR文字识别软件添加图像的方法
  11. What is the Xcopy Command?:
  12. javascript父窗口与子窗口通信
  13. 算法问题:最长滑道问题(非递归,C++)
  14. H5 调用本地相机并压缩上传(是从angular的ionic项目中截取的)
  15. Handsontable的前端分页与数据库分页
  16. 关于c++停止工作
  17. activiti节点跳转
  18. Vue-zTree
  19. 使用 spring封装的javamail linux服务器发送邮件失败解决
  20. vsCode 设置vue 保存自动格式化代码

热门文章

  1. 数据库实例: STOREBOOK > 表空间 > 编辑 表空间: TEMP
  2. 使用jquery操作iframe
  3. OpenCV学习(32) 求轮廓的包围盒
  4. W-GAN
  5. Android数据适配-ExpandableListView
  6. Typescript declaration: Merge a class and an interface
  7. Cognos启用第三方邮件服务代发功能
  8. Navicat安装激活
  9. 字段计算器VBS
  10. iOS键盘高度自适应(中英文输入)