首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何修改UIBarButtonItem和UIButton的UIMenu

基础概念

UIBarButtonItemUIButton 是 iOS 开发中常用的 UI 组件。UIBarButtonItem 通常用于导航栏或工具栏,而 UIButton 则用于用户点击操作。UIMenu 是 iOS 13 及以上版本中引入的一个新特性,用于在长按按钮或视图时显示上下文菜单。

修改 UIMenu 的方法

1. 创建自定义菜单项

首先,你需要创建自定义的 UIMenuItem 对象,并设置其标题和动作。

代码语言:txt
复制
let customMenuItem = UIMenuItem(title: "Custom Action", action: #selector(customAction(_:)))

2. 设置 UIMenu

然后,你可以创建一个 UIMenu 对象,并将自定义菜单项添加到其中。

代码语言:txt
复制
let customMenu = UIMenu(title: "Custom Menu", children: [customMenuItem])

3. 将 UIMenu 应用到 UIButton 或 UIBarButtonItem

对于 UIButton,你需要设置其 menu 属性:

代码语言:txt
复制
button.menu = customMenu

对于 UIBarButtonItem,你需要将其包装在一个 UIContextMenuInteraction 中:

代码语言:txt
复制
let interaction = UIContextMenuInteraction(delegate: self)
view.addInteraction(interaction)

func contextMenuInteraction(_ interaction: UIContextMenuInteraction, configurationForMenuAtLocation location: CGPoint) -> UIContextMenuConfiguration? {
    return UIContextMenuConfiguration(identifier: nil, previewProvider: nil) { _ in
        return customMenu
    }
}

应用场景

  • 长按操作:在长按按钮或视图时显示自定义菜单,提供更多操作选项。
  • 上下文相关操作:根据用户当前的上下文显示不同的菜单项。

示例代码

以下是一个完整的示例,展示了如何为 UIButtonUIBarButtonItem 设置自定义菜单。

UIButton 示例

代码语言:txt
复制
import UIKit

class ViewController: UIViewController {
    override func viewDidLoad() {
        super.viewDidLoad()
        
        let button = UIButton(type: .system)
        button.setTitle("Long Press Me", for: .normal)
        button.frame = CGRect(x: 50, y: 100, width: 150, height: 50)
        button.addTarget(self, action: #selector(buttonTapped), for: .touchUpInside)
        view.addSubview(button)
        
        let customMenuItem = UIMenuItem(title: "Custom Action", action: #selector(customAction(_:)))
        let customMenu = UIMenu(title: "Custom Menu", children: [customMenuItem])
        button.menu = customMenu
    }
    
    @objc func buttonTapped() {
        print("Button tapped")
    }
    
    @objc func customAction(_ sender: UIMenuItem) {
        print("Custom action performed")
    }
}

UIBarButtonItem 示例

代码语言:txt
复制
import UIKit

class ViewController: UIViewController, UIContextMenuInteractionDelegate {
    override func viewDidLoad() {
        super.viewDidLoad()
        
        let barButtonItem = UIBarButtonItem(title: "Right Click Me", style: .plain, target: nil, action: nil)
        navigationItem.rightBarButtonItem = barButtonItem
        
        let interaction = UIContextMenuInteraction(delegate: self)
        view.addInteraction(interaction)
    }
    
    func contextMenuInteraction(_ interaction: UIContextMenuInteraction, configurationForMenuAtLocation location: CGPoint) -> UIContextMenuConfiguration? {
        let customMenuItem = UIMenuItem(title: "Custom Action", action: #selector(customAction(_:)))
        let customMenu = UIMenu(title: "Custom Menu", children: [customMenuItem])
        return UIContextMenuConfiguration(identifier: nil, previewProvider: nil) { _ in
            return customMenu
        }
    }
    
    @objc func customAction(_ sender: UIMenuItem) {
        print("Custom action performed")
    }
}

参考链接

通过以上方法,你可以轻松地为 UIBarButtonItemUIButton 设置自定义菜单,并根据需要添加或修改菜单项。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • iOS调整导航条BarButtonItem与titleView 间距

    前言 例子:调整BarButtonItem按钮titleView间距 1、原理:titleview起点位置尺寸依赖于leftBarButtonItemrightBarButtonItem位置...2、设置titleview之前,先初始化leftBarButtonItemrightBarButtonItem位置,然后根据leftBarButtonItemrightBarButtonItem位置来使...不能直接是UIButton, 因此解决方案只要对UIButton进行包装一层之后再作为CustomView I、调整BarButtonItem按钮titleView间距 与屏幕边界 或者与titleView...间距 ---- // 经过尝试,发现titleview起点位置尺寸依赖于leftBarButtonItemrightBarButtonItem位置。...UIButton进行包装一层即可 - (void)setupNavigationBar { // 设置导航条右侧按钮 UIButton *btn = [[UIButton alloc]

    2.1K20

    【iOS 开发】基本 UI 控件详解 (UIButton | UITextField | UITextView | UISwitch)

    ; 为不同状态 UIButton 设置样式 :  -- "setTittle : forState :" 方法 : UIButton 不同状态 设置不同标题; -- "setTittleColor...: forState :" 方法 : UIButton 不同状态设置不同标题颜色; -- "setTittleShadowColor : forState :" 方法 : UIButton 不同状态...设置 不同按钮中文本阴影设置颜色; -- "setBackgroundImage : forState :" 方法 : UIButton 不同状态设置不同背景图片; -- "setImage :...触摸背景关闭虚拟键盘 (1) 修改 Custom Class  修改背景类别 :  -- 修改原因 : 默认背景控件时 UIView, 该控件没有 IBAction 事件, 因此需要将背景控件设置为...将背景控件设置为 UIControl : 之前 UIView 不能响应点击事件, 在身份检查器 面板将 Custom Class 由 UIView 修改为 UIControl; -- 2.

    6.7K20

    iOS右滑返回实现【修订】

    ,统一允许激活 return YES; } II、QMUI导致右滑返回没有生效解决方法 先来看看QMUI如何实现实现右滑返回?...方法将手势返回强制加回来 2.3 动态添加方法 使用场景: 在消息发送消息转发时会用到动态添加方法 全局控制返回手势 下面的+addMethod方法有三个参数,第一个参数是要添加方法类,第二个参数是方法...使用class_getInstanceMethod()method_getImplementation()获取相应SEL。.../article/details/77675855 -(void) setuprightBtn{ UIButton *rightBtn = [UIButton buttonWithType...self.navigationItem.rightBarButtonItem.customView.hidden = YES; } see also iOS运行时API应用: 1、实现路由(接口控制app跳任意界面 ) 2、获取修改对象成员属性

    1.7K20

    UIButtonsetBackgroundImagesetImage方法选择

    https://blog.csdn.net/u010105969/article/details/52840728 在设置UIButton图片时候发现有两个方法setBackgroundImage... setImage,之前并没有发现两者有太大区别(使用setBackgroundImage后设置title没问题,使用setImage后设置title会被挡住),因为项目中使用带有图片按钮几乎没有文字...而哪些带有文字按钮也没有什么特殊图片,于是会不使用图片。所以本人一直使用setBackgroundImage。 可在使用这个方法时候有一个问题,按钮大小必须图片大小一样,不然图片会拉伸。...于是我每次都会将按钮大小设置成按钮要使用图片大小。可这样设置了之后,有些按钮上图片会比较小,这样点击区域就回比较小,从而给用户带来不是很好体验效果。...而在使用了setImage这个方法之后发现按钮上图片并不会发生拉伸,而是居中显示在按钮上,这正是我项目中所要效果。于是决定在今后项目中更多地去使用setImage方法。

    1.4K20

    iOS键盘、选取器上工具栏

    ”,一个“完成”,只有点击完成时才真正产生修改。...本文就根据实例来讲解怎么在键盘选取器上添加工具栏按钮。...上面我们是将一个tooBar作为inputAccessoryView,这就是另一种实现方式,不使用delegate,单独创建一个UIToolBar,直接设置上去,这个toolbar样式与功能键盘工具栏是不一样...数组,来存储三个UIBarButtonItem对象,注意,为什么是三个呢,界面上不是只有取消完成两个按钮吗?...下面两个方法分别是取消完成两个按钮响应方法,一个是直接收起选取器,一个是收起选取器之外还要设置输入框内容为所选择内容。 这样选取器工具栏按钮就完成了。

    1.5K10

    iOS开发之微信聊天工具栏封装

    聊天工具条还是比较复杂,其中包括发送表情,发送文字,发送图片,发送声音,拍照等等功能,下面给出发送录音,文字,表情代码,其他这几样类似。还是那句话百字不如一图,先来几张效果图吧。 ? ?...因为不管是工具条还是表情键盘都是用约束来控件大小,所以横屏也是没问题,在大屏手机上也是没问题。下面将会一步步讲解如何封装下面的聊天工具条。主要是对工具条封装,表情键盘在这就不做讲解了。...:UIBarButtonSystemItemFlexibleSpace target:nil action:nil]; 9 UIBarButtonItem * item3 = [[UIBarButtonItem...5.点击最左边按钮触发事件(切换文本输入框录音按钮),代码如下: 1 //切换声音按键和文字输入框 2 -(void)tapVoiceChangeButton:(UIButton *) sender...,至于在Controller中如何使用他来发送消息,如何定义聊天Cell,如何处理录音文件,聊天时气泡是如何实现等功能,在以后博客中会继续讲解,希望大家继续关注。

    2.5K80
    领券