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.
}


你可能感兴趣的:(ios,import,layer)