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


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值