IOS 自定义button有效点击范围

那么如何自定义按钮点击的有效区域呢,其实很简单,只要重写一个函数即可:

 

- (BOOL)pointInside:(CGPoint)point withEvent:(UIEvent *)event

 

系统发生触摸事件的时候会从window到父控件到子控件一个个检测触摸点是否在其中,如果在其中,则返回YES,最后返回YES的子控件作为响应事件的控件。

 

我们只要重写这个方法,在其中判断,是否点击了我们想要的区域,是的话就返回YES,否则返回NO,这样就实现了自定义点击的有效区域了。注意,这边并没有改变按钮的形状,按钮还是矩形的按钮,只是改变了按钮中响应区域而已。

 

那么接下来的问题就是,怎么判断一个点是否在一个不是矩形的区域中呢,这边可以使用UIBezierPath的方法:

- (BOOL)containsPoint:(CGPoint)point;

 

我们可以先根据想要的形状绘制一条path,然后判断调用上面的方法去判断即可。

 

例如一个正方形的按钮,怎么才能让他在它圆形的范围点击才有反应,其他的地方没有反应呢?

技术分享

- (BOOL)pointInside:(CGPoint)point withEvent:(UIEvent *)event {
    //首先调用父类的方法确定点击的区域确实在按钮的区域中
    BOOL res = [super pointInside:point withEvent:event];
    if (res) {
        //绘制一个圆形path
        UIBezierPath *path = [UIBezierPath bezierPathWithOvalInRect:self.bounds];
        if ([path containsPoint:point]) {
            //如果在path区域内,返回YES
            returnYES;
        }
        returnNO;
    }
    returnNO;
}

 这样,点击按钮圆形的部分才会有效果,其他地方没有反应。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
iOS中,可以通过以下方式自定义NavigationBar: 1. 设置NavigationBar的背景色和透明度 ```swift // 设置NavigationBar的背景色 navigationController?.navigationBar.barTintColor = UIColor.red // 设置NavigationBar的透明度 navigationController?.navigationBar.isTranslucent = true ``` 2. 设置NavigationBar的标题和字体样式 ```swift // 设置NavigationBar的标题 navigationItem.title = "Custom Title" // 设置NavigationBar的字体样式 navigationController?.navigationBar.titleTextAttributes = [NSAttributedString.Key.font: UIFont.boldSystemFont(ofSize: 18), NSAttributedString.Key.foregroundColor: UIColor.white] ``` 3. 设置NavigationBar的返回按钮和图片 ```swift // 设置NavigationBar的返回按钮 let backButton = UIBarButtonItem(title: "", style: .plain, target: nil, action: nil) navigationItem.backBarButtonItem = backButton // 设置NavigationBar的返回图片 let backImage = UIImage(named: "back") navigationController?.navigationBar.backIndicatorImage = backImage navigationController?.navigationBar.backIndicatorTransitionMaskImage = backImage ``` 4. 隐藏NavigationBar ```swift // 隐藏NavigationBar navigationController?.navigationBar.isHidden = true ``` 5. 自定义NavigationBar的左右按钮 ```swift // 自定义NavigationBar的左按钮 let leftButton = UIBarButtonItem(title: "Left", style: .plain, target: self, action: #selector(leftButtonTapped)) navigationItem.leftBarButtonItem = leftButton // 自定义NavigationBar的右按钮 let rightButton = UIBarButtonItem(title: "Right", style: .plain, target: self, action: #selector(rightButtonTapped)) navigationItem.rightBarButtonItem = rightButton // 左按钮点击事件 @objc func leftButtonTapped() { // do something } // 右按钮点击事件 @objc func rightButtonTapped() { // do something } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值