图片倒影效果

52 篇文章 0 订阅
图片倒影效果
#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、付费专栏及课程。

余额充值