IOS实现图片倒影效果


#import <QuartzCore/QuartzCore.h>
- (void)viewDidLoad
{
[super viewDidLoad];


[[[self view] layer] setBackgroundColor:[[UIColor blackColor] CGColor]];

UIImage *balloon = [UIImage imageNamed:@"app3.png"];

//图片层

CALayer *topLayer = [[CALayer alloc] init];

[topLayer setBounds:CGRectMake(0.0f, 0.0f, 320-100.0, 240-100)];

[topLayer setPosition:CGPointMake(160.0f, 120.0f)];

[topLayer setContents:(id)[balloon CGImage]];

[[[self view] layer] addSublayer:topLayer];

//图片阴影层

CALayer *reflectionLayer = [[CALayer alloc] init];

[reflectionLayer setBounds:CGRectMake(0.0f, 0.0f, 320.0-100, 240.0-100)];

[reflectionLayer setPosition:CGPointMake(160.0f, 310.0f-100)];

[reflectionLayer setContents:[topLayer contents]];

[reflectionLayer setValue:[NSNumber numberWithFloat:180.0] forKeyPath:@"transform.rotation.x"];

//渐变层

CAGradientLayer *gradientLayer = [[CAGradientLayer alloc] init];

[gradientLayer setBounds:[reflectionLayer bounds]];

[gradientLayer setPosition:CGPointMake([reflectionLayer bounds].size.width/2, [reflectionLayer bounds].size.height/2)];

[gradientLayer setColors:[NSArray arrayWithObjects: (id)[[UIColor clearColor] CGColor],(id)[[UIColor blackColor] CGColor], nil]];

[gradientLayer setStartPoint:CGPointMake(0.5,0.35)];

[gradientLayer setEndPoint:CGPointMake(0.5,1.0)];

[reflectionLayer setMask:gradientLayer];

[[[self view] layer] addSublayer:reflectionLayer];
// Do any additional setup after loading the view, typically from a nib.
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值