将渐变颜色应用于使用UIBezierPath创建的弧

Gra*_*nit 25 xcode uicolor ios uibezierpath

我想创建一个具有弧形的进度条.进度条的颜色必须根据值进行更改.

我使用创建了一个弧UIBezierPath bezierPathWithArcCenter.我使用了以下代码:

- (void)viewDidLoad
{
    [super viewDidLoad];

    int radius = 100;

    CAShapeLayer *arc = [CAShapeLayer layer];

    arc.path = [UIBezierPath bezierPathWithArcCenter:CGPointMake(100, 50) radius:radius startAngle:60.0 endAngle:0.0 clockwise:YES].CGPath;

    arc.position = CGPointMake(CGRectGetMidX(self.view.frame)-radius,
                                  CGRectGetMidY(self.view.frame)-radius);

    arc.fillColor = [UIColor clearColor].CGColor;
    arc.strokeColor = [UIColor purpleColor].CGColor;
    arc.lineWidth = 15;

    [self.view.layer addSublayer:arc];

    CABasicAnimation *drawAnimation = [CABasicAnimation animationWithKeyPath:@"strokeEnd"];
    drawAnimation.duration            = 5.0; // "animate over 10 seconds or so.."
    drawAnimation.repeatCount         = 1.0;  // Animate only once..
    drawAnimation.removedOnCompletion = NO;   // Remain stroked after the animation..
    drawAnimation.fromValue = [NSNumber numberWithFloat:0.0f];
    drawAnimation.toValue   = [NSNumber numberWithFloat:10.0f];
    drawAnimation.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseIn];
    [arc addAnimation:drawAnimation forKey:@"drawCircleAnimation"];

}
Run Code Online (Sandbox Code Playgroud)

结果如下:

在此输入图像描述

我的问题是:如果值<= 50%,如何对颜色应用渐变?我还创建了一个UIButton,它可以生成随机的CGFloat数字,以便与进度条连接起来.有谁知道如何解决这个问题?

渐变看起来像这样:

在此输入图像描述

任何帮助,将不胜感激!

非常感谢你.

格兰尼特

小智 38

您可以使用CAGradientLayer获取渐变效果,并使用CAShapeLayer作为蒙版.

例如:

- (void)viewDidLoad
{
    [super viewDidLoad];

    int radius = 100;

    CAShapeLayer *arc = [CAShapeLayer layer];    
    arc.path = [UIBezierPath bezierPathWithArcCenter:CGPointMake(100, 50) radius:radius startAngle:60.0 endAngle:0.0 clockwise:YES].CGPath;

    arc.position = CGPointMake(CGRectGetMidX(self.view.frame)-radius,
                               CGRectGetMidY(self.view.frame)-radius);

    arc.fillColor = [UIColor clearColor].CGColor;
    arc.strokeColor = [UIColor purpleColor].CGColor;
    arc.lineWidth = 15; 
    CABasicAnimation *drawAnimation = [CABasicAnimation animationWithKeyPath:@"strokeEnd"];
    drawAnimation.duration            = 5.0; // "animate over 10 seconds or so.."
    drawAnimation.repeatCount         = 1.0;  // Animate only once..
    drawAnimation.removedOnCompletion = NO;   // Remain stroked after the animation..
    drawAnimation.fromValue = [NSNumber numberWithFloat:0.0f];
    drawAnimation.toValue   = [NSNumber numberWithFloat:10.0f];
    drawAnimation.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseIn];
    [arc addAnimation:drawAnimation forKey:@"drawCircleAnimation"];

    CAGradientLayer *gradientLayer = [CAGradientLayer layer];
    gradientLayer.frame = self.view.frame;
    gradientLayer.colors = @[(__bridge id)[UIColor redColor].CGColor,(__bridge id)[UIColor blueColor].CGColor ];
    gradientLayer.startPoint = CGPointMake(0,0.5);
    gradientLayer.endPoint = CGPointMake(1,0.5);

    [self.view.layer addSublayer:gradientLayer];
     //Using arc as a mask instead of adding it as a sublayer.
     //[self.view.layer addSublayer:arc]; 
     gradientLayer.mask = arc;


}
Run Code Online (Sandbox Code Playgroud)

  • 这似乎不会沿着路径绘制**,而是看起来它会绘制一个水平渐变,这是由路径显示的.那有意义吗?如何"弯曲"水平渐变以跟随整圆? (30认同)
  • `drawAnimation.toValue = [NSNumber numberWithFloat:10.0f];`这意味着什么?为何选择10.0f? (2认同)

Joh*_*kex 5

在此输入图像描述

要沿笔画绘制渐变,请参阅此实现:/sf/answers/3056789431/

编辑:简而言之,创建一个自定义 UIView 类,通过以递增的角度在两种颜色之间迭代来添加径向渐变,例如 color1 = 1 度,colour2 = 2 度​​等,一直到 360。然后应用圆环蒙版对此。当您更改遮罩 CAShapeLayer 的描边结束值时,您还会旋转底层的径向渐变。因为它们一起移动,所以看起来笔划本身有一个渐变。