可拖动的Button

根据拖动手势实时位置实现可拖动的Button

直接上代码:

/// 可以随意拖动位置的按钮组件
class SGMoveButton: UIButton
{
    // MARK: - properties
    var parentView:UIView?;
    
    // MARK: - life cycle
    override init(frame:CGRect)
    {
        super.init(frame:frame);
        
        let recognizer:UIPanGestureRecognizer = UIPanGestureRecognizer(target: self, action: #selector(SGMoveButton.eventPanGestureRecognizerHandler(_:)));
        self.addGestureRecognizer(recognizer);
    }
    
    required init?(coder aDecoder:NSCoder)
    {
        super.init(coder:aDecoder);
    }
    
    deinit
    {

    }
    
    // MARK: - public methods
    
    // MARK: - event response
    internal func eventPanGestureRecognizerHandler(_ sender:UIPanGestureRecognizer)
    {
        if (sender.state == UIGestureRecognizerState.changed)
        {
            let currentPoint:CGPoint = sender.translation(in: self.parentView);// 获得pan手势相对于parentView移动的CGPoint
            self.center = CGPoint(x: self.center.x + currentPoint.x, y: self.center.y + currentPoint.y); // 按照上面相对移动的CGPoint改变button的CGPoint
            sender.setTranslation(CGPoint.zero, in: self.parentView); // 将pan手势相对于parentView的CGPoint置零
        }
    }
}

demo地址:

https://github.com/songhaisheng/SGMoveButton

简书博客地址

https://www.jianshu.com/u/3c7c13f3dc6b

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值