【问题标题】:How to close triangle path?如何关闭三角形路径?
【发布时间】:2016-02-11 15:12:46
【问题描述】:

我画了这个形状:

这是我的代码:

/* build path */
let bottomBezierPath = UIBezierPath()
//first thing draw bottom line
bottomBezierPath.moveToPoint(CGPointMake(0, TRIANGLE_EDGE))
bottomBezierPath.addLineToPoint(CGPointMake(bottomShapeLayer.frame.size.width,TRIANGLE_EDGE))

//now draw triangle
bottomBezierPath.moveToPoint(CGPointMake(bottomShapeLayer.frame.size.width,TRIANGLE_EDGE))
bottomBezierPath.addLineToPoint(CGPointMake(bottomShapeLayer.frame.size.width,0))
bottomBezierPath.moveToPoint(CGPointMake(bottomShapeLayer.frame.size.width,0))
bottomBezierPath.addLineToPoint(CGPointMake(bottomShapeLayer.frame.size.width - TRIANGLE_EDGE ,TRIANGLE_EDGE))

bottomShapeLayer.path = bottomBezierPath.CGPath
bottomShapeLayer.fillColor = UIColor.redColor().CGColor
bottomShapeLayer.strokeColor = UIColor.redColor().CGColor

但我需要用红色填充三角形,bottomShapeLayer.fillColor 应该这样做,对吧?

【问题讨论】:

  • 试试bottomShapelayer.background=uicolor().redcolor;
  • @KishoreKumar 谢谢你的评论,但它不起作用,它画了矩形

标签: ios uibezierpath cashapelayer


【解决方案1】:

您正在为三角形创建 2 个单独的线段。

每次使用moveToPoint(),你都在开始一个新的线段。因此,当CAShapeLayer来填充三角形时,它无法填充它,因为它是'不完整”。

解决这个问题真的很简单,您只需通过删除moveToPoint() 调用之一为您的三角形创建一条连续路径:

let bottomBezierPath = UIBezierPath()
//first thing draw bottom line
bottomBezierPath.moveToPoint(CGPointMake(0, TRIANGLE_EDGE))
bottomBezierPath.addLineToPoint(CGPointMake(bottomShapeLayer.frame.size.width,TRIANGLE_EDGE))

//now draw triangle
//bottomBezierPath.moveToPoint(CGPointMake(bottomShapeLayer.frame.size.width,TRIANGLE_EDGE)) // this line is redundant btw, as you're moving to the same point. I've left it in incase you want to start your triangle somewhere else.
bottomBezierPath.addLineToPoint(CGPointMake(bottomShapeLayer.frame.size.width,0))
bottomBezierPath.addLineToPoint(CGPointMake(bottomShapeLayer.frame.size.width - TRIANGLE_EDGE ,TRIANGLE_EDGE))

还值得注意的是,您在三角形的开头调用moveToPoint() 也是多余的,因为它正在移动到同一点。

现在你有一个完整的三角形,它应该被正确填充。

【讨论】:

    猜你喜欢
    • 2015-06-18
    • 1970-01-01
    • 1970-01-01
    • 2017-07-20
    • 2014-07-03
    • 1970-01-01
    • 2022-11-15
    • 2011-11-11
    • 2012-07-27
    相关资源
    最近更新 更多