Draw a line with UIBezierPath

前端 未结 4 1890
礼貌的吻别
礼貌的吻别 2020-12-08 04:22

First time using BezierPaths, wondering how this function is actually supposed to be implemented. Currently the bezier path moves within the frame of the image, as opposed t

相关标签:
4条回答
  • 2020-12-08 04:44

    Swift 3.1 Version of William Falcon's Answer + Improved

    This is just an updated version of already accepted answer, and I just added a little bit more to it.

    func drawLineFromPointToPoint(startX: Int, toEndingX endX: Int, startingY startY: Int, toEndingY endY: Int, ofColor lineColor: UIColor, widthOfLine lineWidth: CGFloat, inView view: UIView) {
    
        let path = UIBezierPath()
        path.move(to: CGPoint(x: startX, y: startY))
        path.addLine(to: CGPoint(x: endX, y: endY))
    
        let shapeLayer = CAShapeLayer()
        shapeLayer.path = path.cgPath
        shapeLayer.strokeColor = lineColor.cgColor
        shapeLayer.lineWidth = lineWidth
    
        view.layer.addSublayer(shapeLayer)
    
    }
    

    And of course the implementation would be

    drawLineFromPointToPoint(startX: Int, toEndingX: Int, startingY: Int, toEndingY: Int, ofColor: UIColor, widthOfLine: CGFloat, inView: UIView)
    

    What I changed from accepted answer

    I changed the vars to lets, and made it easier to input the start and end of both the x and the y. I also allow the user to change the width of the line.

    I chose for the values to be of type Int, but you can change those to be the other allowed options.

    0 讨论(0)
  • 2020-12-08 04:48

    Ended up doing it this way:

    func drawLineFromPoint(start : CGPoint, toPoint end:CGPoint, ofColor lineColor: UIColor, inView view:UIView) {
    
        //design the path
        var path = UIBezierPath()
        path.moveToPoint(start)
        path.addLineToPoint(end)
    
        //design path in layer
        var shapeLayer = CAShapeLayer()
        shapeLayer.path = path.CGPath
        shapeLayer.strokeColor = lineColor.CGColor
        shapeLayer.lineWidth = 1.0
    
        view.layer.addSublayer(shapeLayer)
    }
    
    0 讨论(0)
  • 2020-12-08 04:51

    Swift 4

    func drawLineFromPoint(start : CGPoint, toPoint end:CGPoint, ofColor lineColor: UIColor, inView view:UIView) {
    
        //design the path
        let path = UIBezierPath()
        path.move(to: start)
        path.addLine(to: end)
    
        //design path in layer
        let shapeLayer = CAShapeLayer()
        shapeLayer.path = path.cgPath
        shapeLayer.strokeColor = lineColor.cgColor
        shapeLayer.lineWidth = 1.0
    
        view.layer.addSublayer(shapeLayer)
    }
    
    0 讨论(0)
  • 2020-12-08 04:53

    To draw horizontal line on top:

    let path = UIBezierPath()
    path.moveToPoint(CGPoint(x: 0, y: 0))
    path.addLineToPoint(CGPoint(x: yourView.frame.width, y: 0))
    
    let shapeLayer = CAShapeLayer()
    shapeLayer.path = path.CGPath
    shapeLayer.strokeColor = UIColor.lightGrayColor().CGColor
    shapeLayer.lineWidth = 0.5
    
    yourView.layer.addSublayer(shapeLayer)
    

    To draw horizontal line on bottom:

    let path = UIBezierPath()
    path.moveToPoint(CGPoint(x: 0, y: yourView.frame.height))
    path.addLineToPoint(CGPoint(x: yourView.frame.width, y: yourView.frame.height))
    
    let shapeLayer = CAShapeLayer()
    shapeLayer.path = path.CGPath
    shapeLayer.strokeColor = UIColor.lightGrayColor().CGColor
    shapeLayer.lineWidth = 0.5
    
    yourView.layer.addSublayer(shapeLayer)
    
    0 讨论(0)
提交回复
热议问题