ios – 如何对齐UIBezierPath圆圈破折号

前端之家收集整理的这篇文章主要介绍了ios – 如何对齐UIBezierPath圆圈破折号前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试使用UIBezierPath绘制一个指南针并在该线上添加破折号以标记其中的北,南,东,西方向和点.破折号似乎是偏移的(它们没有对齐),特别是在北方和南方方向,而我正在做的方式似乎在路径关闭添加了额外的破折号.
  1. let windCircleOrigin = CGPoint(x: self.center.x * 1.3,y: self.bounds.height / 2.0 - 10)
  2. let windCircleRadius = CGFloat(self.bounds.height * 0.3)
  3. let windCirclePath: UIBezierPath = UIBezierPath(arcCenter: windCircleOrigin,radius: windCircleRadius,startAngle: 0,endAngle: CGFloat(M_PI) * 2.0,clockwise: true)
  4. windCirclePath.lineWidth = 6
  5. let dashes: [CGFloat] = [windCirclePath.lineWidth * 0,windCirclePath.lineWidth * 3 ]
  6. windCirclePath.setLineDash(dashes,count: dashes.count,phase: 0.0)
  7. UIColor.whiteColor().setFill()
  8. UIColor.whiteColor().setStroke()
  9. windCirclePath.stroke()
  10. textView(self.windSpeedLabel! + " mph",x: windCircleOrigin.x - 20.0,y: windCircleOrigin.y - 8.0,color: UIColor.whiteColor(),width: 50.0,height: 20.0)
  11. textView("N",x: windCircleOrigin.x - 7.0,y: windCircleOrigin.y - 70.0,width: 20,height: 20)
  12. textView("S",y: windCircleOrigin.y + 50.0,height: 20)
  13. textView("W",x: windCircleOrigin.x - 70.0,height: 20)
  14. textView("E",x: windCircleOrigin.x + 60.0,height: 20)
  15.  
  16. func textView(text: String,x: CGFloat,y: CGFloat,color: UIColor,width: CGFloat,height: CGFloat) {
  17. let textView = UILabel(frame: CGRectMake(x,y,width,height))
  18. textView.textAlignment = NSTextAlignment.Left
  19. textView.textColor = color
  20. textView.backgroundColor = UIColor.clearColor()
  21. textView.font = UIFont(name: "HelveticaNeue-Light",size: 12.0)
  22. textView.text = text
  23. self.addSubview(textView)
  24. }@H_301_3@

解决方法

相反,我建议单独绘制每个刻度.然后你可以轻松控制他们的位置.

像这样的东西:

  1. let path = UIBezierPath()
  2. let innerRadius: CGFloat = 50
  3. let outerRadius: CGFloat = 60
  4. let numTicks = 24
  5.  
  6. for i in 0..<numTicks {
  7. let angle = CGFloat(i) * CGFloat(2*M_PI) / CGFloat(numTicks)
  8. let inner = CGPoint(x: innerRadius * cos(angle),y: innerRadius * sin(angle))
  9. let outer = CGPoint(x: outerRadius * cos(angle),y: outerRadius * sin(angle))
  10. path.moveToPoint(inner)
  11. path.addLineToPoint(outer)
  12. }@H_301_3@
  13. 然后,您可以使用所需的任何lineWidth(和lineCapStyle)来描述此路径.

猜你在找的iOS相关文章