我有一个CAShapeLayer,其中包含一个“孔”和一个透明的周围环境(see screenshot)。我想为该圆的半径变化设置动画(我想使其变大或变小)。有任何想法吗 ?
这是我的图层:
CAShapeLayer *fillLayer = [self getCircleLayerWithRadius:self.view.frame.size.width/2];
getCirleWithRadius函数:
-(CAShapeLayer *)getCircleLayerWithRadius:(NSInteger)radius {
UIBezierPath *path = [UIBezierPath bezierPathWithRoundedRect:self.view.frame cornerRadius:0];
UIBezierPath *circlePath = [self getCirclePathWithRadius:radius];
[path appendPath:circlePath];
path.usesEvenOddFillRule = YES;
CAShapeLayer *fillLayer = [CAShapeLayer layer];
fillLayer.path = path.CGPath;
fillLayer.fillRule = kCAFillRuleEvenOdd;
fillLayer.fillColor = [UIColor grayColor].CGColor;
fillLayer.opacity = 0.5;
return fillLayer; }
getCircleWithRadius:
- (UIBezierPath *)getCirclePathWithRadius:(NSInteger)radius {
CGRect rect = self.view.frame;
UIBezierPath *circlePath;
circlePath = [UIBezierPath bezierPathWithArcCenter:(CGPoint){rect.size.width/2, rect.size.height/2} radius:radius startAngle:0 endAngle:M_PI*2 clockwise:YES];
return circlePath;}
最佳答案
尝试通过@"path"
键使用“CABasicAnimation”。
以下是配置动画的示例:
CABasicAnimation *animation = [CABasicAnimation animationWithKeyPath:@"path"];
animation.duration = [CATransaction animationDuration];
animation.timingFunction = [CATransaction animationTimingFunction];
animation.fromValue = (id)oldPath;
animation.toValue = (id)path;
[fillLayer addAnimation:animation forKey:@"pathAnimation"];
关于ios - 如何为CAShapleLayer的路径变化设置动画?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/39744700/