ios跳动效果

头部需引入:

#import <QuartzCore/QuartzCore.h>


- (void)viewDidLoad {
 
UIView *bgView = [[UIView alloc] initWithFrame:CGRectMake(10, 40, 300, 240)];
bgView.backgroundColor = [UIColor lightGrayColor];
bgView.tag = 150;
 
//需要跳动的图片
UIImageView *imgView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"BFlyCircle.png"]];
[bgView addSubview:imgView];
imgView.tag = 151;
imgView.center = CGPointMake(150, 120);
 
//Go
UIButton *button = [UIButton buttonWithType:UIButtonTypeRoundedRect];
[button setTitle:@"Go" forState:UIControlStateNormal];
button.frame = CGRectMake(10, 10, 80, 25);
[button addTarget:self action:@selector(go:) forControlEvents:UIControlEventTouchUpInside];
 
[self.view addSubview:bgView];
[self.view addSubview:button];
 
[bgView release];
[imgView release];
 
    [super viewDidLoad];
}
 

- (void) go:(id) sender{
UIView *img = [self.view viewWithTag:151];
[CATransaction begin];
[CATransaction setValue:[NSNumber numberWithFloat:4.0] forKey:kCATransactionAnimationDuration];
 
// scale it down
CABasicAnimation *shrinkAnimation = [CABasicAnimation animationWithKeyPath:@"transform.scale"];
shrinkAnimation.delegate = self;
shrinkAnimation.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseIn];
shrinkAnimation.toValue = [NSNumber numberWithFloat:0.0];
[[img layer] addAnimation:shrinkAnimation forKey:@"shrinkAnimation"];
 
// fade it out
CABasicAnimation *fadeAnimation = [CABasicAnimation animationWithKeyPath:@"opacity"];
fadeAnimation.toValue = [NSNumber numberWithFloat:0.0];
fadeAnimation.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseIn];
[[img layer] addAnimation:fadeAnimation forKey:@"fadeAnimation"];
 
// make it jump a couple of times
CAKeyframeAnimation *positionAnimation = [CAKeyframeAnimation animationWithKeyPath:@"position"];
CGMutablePathRef positionPath = (__typeof(CGPathCreateMutable()))[NSMakeCollectable(CGPathCreateMutable()) autorelease];
CGPathMoveToPoint(positionPath, NULL, [img layer].position.x, [img layer].position.y);
 
//落下3次
 
CGPathAddQuadCurveToPoint(positionPath, NULL, [img layer].position.x, -[img layer].position.y, [img layer].position.x, [img layer].position.y);
CGPathAddQuadCurveToPoint(positionPath, NULL, [img layer].position.x, -[img layer].position.y *1.5, [img layer].position.x, [img layer].position.y);
CGPathAddQuadCurveToPoint(positionPath, NULL, [img layer].position.x, -[img layer].position.y *1.25, [img layer].position.x, [img layer].position.y);

positionAnimation.path = positionPath;
positionAnimation.timingFunction = [CAMediaTimingFunctionfunctionWithName:kCAMediaTimingFunctionEaseIn];
[[img layer] addAnimation:positionAnimation forKey:@"positionAnimation"];
 
[CATransaction commit];
} 


闪烁的文字,多种闪烁效果 https://github.com/Zws-China/WSShiningLabel WSShiningLabel *label1 = [[WSShiningLabel alloc] init]; label1.frame = CGRectMake(50, 35, 200, 25); label1.text = @"当保护你的她"; label1.textColor = [UIColor grayColor]; label1.font = [UIFont systemFontOfSize:20]; [label1 startShimmer]; // 开启闪烁 [self.view addSubview:label1]; WSShiningLabel *label2 = [[WSShiningLabel alloc] init]; label2.frame = CGRectMake(50, 105, 200, 25); label2.text = @"变成要你保护的她"; label2.textColor = [UIColor grayColor]; label2.font = [UIFont systemFontOfSize:20]; label2.shimmerType = ST_RightToLeft; // 滚动方向 right to left label2.durationTime = 1; // 滚动时间 label2.shimmerColor = [UIColor orangeColor]; // 高亮颜色 [label2 startShimmer]; // 开启闪烁 [self.view addSubview:label2]; WSShiningLabel *label3 = [[WSShiningLabel alloc] init]; label3.frame = CGRectMake(50, 175, 200, 25); label3.text = @"当你远离了家"; label3.textColor = [UIColor grayColor]; label3.font = [UIFont systemFontOfSize:20]; label3.shimmerType = ST_AutoReverse; // 滚动方向 左右来回 label3.shimmerWidth = 20; // 高亮的宽度 label3.shimmerRadius = 20; // 阴影的宽度 label3.shimmerColor = [UIColor yellowColor]; // 高亮颜色 [label3 startShimmer]; // 开启闪烁 [self.view addSubview:label3]; WSShiningLabel *label4 = [[WSShiningLabel alloc] init]; label4.frame = CGRectMake(50, 245, 200, 25); label4.text = @"努力有了你爱的她"; label4.textColor = [UIColor grayColor]; label4.font = [UIFont systemFontOfSize:20]; label4.shimmerType = ST_ShimmerAll; // 闪烁 label4.durationTime = 0.8; label4.shimmerColor = [UIColor redColor]; [label4 startShimmer]; [self.view addSubview:label4];
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值