#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.
}
IOS实现图片倒影效果
最新推荐文章于 2021-05-13 06:44:49 发布