gpt4 book ai didi

ios - 在 iOS 中使用 Objective C 为 UlLabel 框架周围的边框设置动画

转载 作者:行者123 更新时间:2023-11-29 00:17:06 24 4
gpt4 key购买 nike

我正在使用 Objective C 开发 iPhone 应用程序,我需要在其中为 UILabel 制作边框动画。

我使用 CABasicAnimation 尝试了以下代码:

CABasicAnimation* borderAnimation = [CABasicAnimation animationWithKeyPath:@"borderWidth"];
[borderAnimation setFromValue:[NSNumber numberWithFloat:4.0f]];
[borderAnimation setToValue:[NSNumber numberWithFloat:0.0f]];
[borderAnimation setRepeatCount:1.0];
[borderAnimation setAutoreverses:NO];
[borderAnimation setDuration:0.7f];
[focusScannerView.layer addAnimation:borderAnimation forKey:@"animateBorder"];

但边框动画效果不佳。有人知道我该怎么做吗?在此先感谢您。

最佳答案

#import "ViewController.h"

@interface ViewController ()
{
UIBezierPath *path;
CAShapeLayer *shapeLayer;
int lineNo;
}
@property (nonatomic, weak) IBOutlet UILabel *textLabel;

@end

@implementation ViewController

- (void)viewDidLoad {
[super viewDidLoad];
path = [UIBezierPath bezierPath];
shapeLayer = [CAShapeLayer layer];
shapeLayer.strokeColor = [[UIColor blueColor] CGColor];
shapeLayer.lineWidth = 3.0;
shapeLayer.fillColor = [[UIColor clearColor] CGColor];

[_textLabel addGestureRecognizer:[[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(startAnimation)]];

// Do any additional setup after loading the view, typically from a nib.
}

-(void)startAnimation{
lineNo = 0;
[self drawLine:lineNo];
}

-(void)drawLine:(int)line{
CGPoint startPoint;
CGPoint endPoint;
switch (line) {
case 0:
startPoint = CGPointMake(self.textLabel.frame.origin.x, self.textLabel.frame.origin.y);
endPoint = CGPointMake(CGRectGetMaxX(self.textLabel.frame), self.textLabel.frame.origin.y);
break;
case 1:
startPoint = CGPointMake(CGRectGetMaxX(self.textLabel.frame), self.textLabel.frame.origin.y);
endPoint = CGPointMake(CGRectGetMaxX(self.textLabel.frame), CGRectGetMaxY(self.textLabel.frame));
break;
case 2:
startPoint = CGPointMake(CGRectGetMaxX(self.textLabel.frame), CGRectGetMaxY(self.textLabel.frame));
endPoint = CGPointMake(self.textLabel.frame.origin.x, CGRectGetMaxY(self.textLabel.frame));
break;
case 3:
startPoint = CGPointMake(self.textLabel.frame.origin.x, CGRectGetMaxY(self.textLabel.frame));
endPoint = CGPointMake(self.textLabel.frame.origin.x, self.textLabel.frame.origin.y);
break;
default:
return;
}

[self animateStartPoint:startPoint andEndPoint:endPoint];

}

-(void)animateStartPoint:(CGPoint) startPoint andEndPoint:(CGPoint)endPoint{
[path moveToPoint:startPoint];
[path addLineToPoint:endPoint];
shapeLayer.path = [path CGPath];

CABasicAnimation *animation = [CABasicAnimation animationWithKeyPath:@"strokeEnd"];
animation.duration = 5;
animation.removedOnCompletion = NO;
animation.fromValue = @(0);
animation.toValue = @(1);
animation.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionLinear];
[shapeLayer addAnimation:animation forKey:@"drawLineAnimation"];

[self.view.layer addSublayer:shapeLayer];
lineNo++;
[self drawLine:lineNo];

}


- (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}


@end

关于ios - 在 iOS 中使用 Objective C 为 UlLabel 框架周围的边框设置动画,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45097656/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com