CALaer形变和阴影

//  
//  CALayerTransformViewController.m
//  CALayerTransformController
//
//  Created by xiaoyao on 15/3/10.
//  Copyright (c) 2015年 lijien. All rights reserved.
//

#import "CALayerTransformViewController.h"

#define PHOTO_HEOGHT 150

@interface CALayerTransformViewController ()

@end

@implementation CALayerTransformViewController

- (void)viewDidLoad {
  [super viewDidLoad];
  
  [self calayerAndTransform];
}

- (void)calayerAndTransform {
  // 阴影图层
  CALayer *shadowLayer = [[CALayer alloc] init];
  shadowLayer.bounds = CGRectMake(0, 0, PHOTO_HEOGHT, PHOTO_HEOGHT);
  shadowLayer.position = CGPointMake(160, 200);
  shadowLayer.cornerRadius = PHOTO_HEOGHT / 2;
  shadowLayer.shadowColor = [UIColor grayColor].CGColor;
  shadowLayer.shadowOpacity = 1;
  shadowLayer.shadowOffset = CGSizeMake(2, 1);
  shadowLayer.borderWidth = 2;
  shadowLayer.borderColor = [UIColor whiteColor].CGColor;
  [self.view.layer addSublayer:shadowLayer];
  
  // 形变图层
  CALayer *layer = [[CALayer alloc] init];
  layer.bounds = shadowLayer.bounds;
  layer.position = shadowLayer.position;
  layer.backgroundColor = [UIColor redColor].CGColor;
  layer.cornerRadius = shadowLayer.cornerRadius;
  layer.masksToBounds = YES;
  layer.borderColor =  [UIColor whiteColor].CGColor;
  layer.borderWidth = shadowLayer.borderWidth;
  [self.view.layer addSublayer:layer];
  
  // 解决图片的倒立问题
  layer.transform = CATransform3DMakeRotation(M_PI, 1, 0, 0);
  layer.delegate = self;
  
  [layer setNeedsDisplay];
}

- (void)drawLayer:(CALayer *)layer inContext:(CGContextRef)ctx {
  UIImage *image = [UIImage imageNamed:@"photo.png"];
  CGContextDrawImage(ctx, CGRectMake(0, 0, PHOTO_HEOGHT, PHOTO_HEOGHT), image.CGImage);
}
@end

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值