标签:blog http color io os 使用 ar for strong
第四章:Visual Effects
Rounded Corners
例子4.1 cornerRadius
源码在这里下载:http://www.informit.com/title/9780133440751
- #import "ViewController.h"
- #import <QuartzCore/QuartzCore.h>
-
- @interface ViewController ()
-
- @property (nonatomic, weak) IBOutlet UIView *layerView1;
- @property (nonatomic, weak) IBOutlet UIView *layerView2;
-
- @end
-
- @implementation ViewController
-
- - (void)viewDidLoad
- {
- [super viewDidLoad];
-
-
- self.layerView1.layer.cornerRadius = 20.0f;
- self.layerView2.layer.cornerRadius = 20.0f;
-
-
- self.layerView2.layer.masksToBounds = YES;
- }
-
- @end
data:image/s3,"s3://crabby-images/ddf92/ddf925e383bb5674e203db584184726e3b242bea" alt="bubuko.com,布布扣"
稍微修改一下
- - (void)viewDidLoad
- {
- [super viewDidLoad];
-
-
- self.layerView1.layer.cornerRadius = 20.0f;
- self.layerView2.layer.cornerRadius = 20.0f;
-
- self.layerView1.clipsToBounds = YES;
-
-
- self.layerView2.layer.masksToBounds = YES;
- }
data:image/s3,"s3://crabby-images/afe9e/afe9edeaf6fdb0dfeed1c524d2166eb95200c5be" alt="bubuko.com,布布扣"
前面讲过了,UIView的clipsToBounds的函数等同于masksToBounds
Layer Borders
例子4.2 borderWidth
- @interface ViewController ()
-
- @property (nonatomic, weak) IBOutlet UIView *layerView1;
- @property (nonatomic, weak) IBOutlet UIView *layerView2;
-
- @end
-
- @implementation ViewController
-
- - (void)viewDidLoad
- {
- [super viewDidLoad];
-
-
- self.layerView1.layer.cornerRadius = 20.0f;
- self.layerView2.layer.cornerRadius = 20.0f;
-
-
- self.layerView1.layer.borderWidth = 5.0f;
- self.layerView2.layer.borderWidth = 5.0f;
-
-
- self.layerView2.layer.masksToBounds = YES;
- }
-
- @end
data:image/s3,"s3://crabby-images/4da78/4da78f042da72dcd48088fbebac23ee64da1040f" alt="bubuko.com,布布扣"
修改代码 borderColor
- - (void)viewDidLoad
- {
- [super viewDidLoad];
-
-
- self.layerView1.layer.cornerRadius = 20.0f;
- self.layerView2.layer.cornerRadius = 20.0f;
-
-
- self.layerView1.layer.borderWidth = 5.0f;
- self.layerView1.layer.borderColor = [UIColor brownColor].CGColor;
- self.layerView2.layer.borderWidth = 5.0f;
-
-
- self.layerView2.layer.masksToBounds = YES;
- }
data:image/s3,"s3://crabby-images/01149/01149c3a2548e4dd3e9879393b146c3e5356df01" alt="bubuko.com,布布扣"
再做个试验,修改代码
data:image/s3,"s3://crabby-images/a4653/a465375f84b07ec89c12f13cd94d6abfcca57e82" alt="bubuko.com,布布扣"
- - (void)viewDidLoad
- {
- [super viewDidLoad];
-
-
-
- self.layerView2.layer.cornerRadius = 20.0f;
-
-
- self.layerView1.layer.borderWidth = 5.0f;
- self.layerView1.layer.borderColor = [UIColor brownColor].CGColor;
- self.layerView2.layer.borderWidth = 5.0f;
-
-
- self.layerView2.layer.masksToBounds = YES;
- }
data:image/s3,"s3://crabby-images/5eeeb/5eeeb464f51e44bd8ed93b04450ace1ee22edc0a" alt="bubuko.com,布布扣"
没有看到红色
再修改
data:image/s3,"s3://crabby-images/fb15d/fb15d7a0472d83e530ca956cf85cdb5800547423" alt="bubuko.com,布布扣"
看结果
data:image/s3,"s3://crabby-images/e7bef/e7befc15f85da4de4d77c9692dce63e674db4e7d" alt="bubuko.com,布布扣"
验证borderWidth是往内部画的,和使用CGContextStrokeEllipseInRect画圆时的方式不同
Drop Shadows & Shadow Clipping
先修改例子2.2
- - (void)viewDidLoad
- {
- [super viewDidLoad];
-
-
- UIImage *image = [UIImage imageNamed:@"Snowman.png"];
-
- self.layerView.backgroundColor = [UIColor clearColor];
-
-
- self.layerView.layer.contents = (__bridge id)image.CGImage;
-
-
- self.layerView.layer.contentsGravity = kCAGravityCenter;
-
-
- self.layerView.layer.contentsScale = image.scale;
-
- self.layerView.layer.shadowOpacity = 0.3;
- self.layerView.layer.shadowOffset = CGSizeMake(10, 20);
-
-
-
- }
data:image/s3,"s3://crabby-images/f4243/f42432cee43ac820092d83cb691fcfc7eaafc92f" alt="bubuko.com,布布扣"
继续
- - (void)viewDidLoad
- {
- [super viewDidLoad];
-
-
- UIImage *image = [UIImage imageNamed:@"Snowman.png"];
-
-
-
-
- self.layerView.layer.contents = (__bridge id)image.CGImage;
-
-
- self.layerView.layer.contentsGravity = kCAGravityCenter;
-
-
- self.layerView.layer.contentsScale = image.scale;
-
- self.layerView.layer.shadowOpacity = 0.3;
- self.layerView.layer.shadowOffset = CGSizeMake(10, 20);
-
-
-
- }
data:image/s3,"s3://crabby-images/b835e/b835ee49051eafc87e8dc4a4965e4b574a8f9954" alt="bubuko.com,布布扣"
再改
- - (void)viewDidLoad
- {
- [super viewDidLoad];
-
-
- UIImage *image = [UIImage imageNamed:@"Snowman.png"];
-
- self.layerView.backgroundColor = [UIColor clearColor];
-
-
- self.layerView.layer.contents = (__bridge id)image.CGImage;
-
-
- self.layerView.layer.contentsGravity = kCAGravityCenter;
-
-
- self.layerView.layer.contentsScale = image.scale;
-
- self.layerView.layer.shadowOpacity = 0.3;
- self.layerView.layer.shadowOffset = CGSizeMake(10, 20);
-
-
- self.layerView.layer.masksToBounds = YES;
- }
data:image/s3,"s3://crabby-images/465d8/465d8feab432e4152a1b8c150eb0aaae53dbe6ae" alt="bubuko.com,布布扣"
再改
- - (void)viewDidLoad
- {
- [super viewDidLoad];
-
-
- UIImage *image = [UIImage imageNamed:@"Snowman.png"];
-
-
-
-
- self.layerView.layer.contents = (__bridge id)image.CGImage;
-
-
- self.layerView.layer.contentsGravity = kCAGravityCenter;
-
-
- self.layerView.layer.contentsScale = image.scale;
-
- self.layerView.layer.shadowOpacity = 0.3;
- self.layerView.layer.shadowOffset = CGSizeMake(10, 20);
-
-
- self.layerView.layer.masksToBounds = YES;
- }
data:image/s3,"s3://crabby-images/5ca13/5ca131d8d570b2d9ffaf4e6fad487945a480991c" alt="bubuko.com,布布扣"
shadow是根据layer实际显示的内容绘制的
再看看例子4.3去体会一下
源码在这里下载:http://www.informit.com/title/9780133440751
The shadowPath Property
例子4.4
- @interface ViewController ()
-
- @property (nonatomic, weak) IBOutlet UIView *layerView1;
- @property (nonatomic, weak) IBOutlet UIView *layerView2;
-
- @end
-
- @implementation ViewController
-
- - (void)viewDidLoad
- {
- [super viewDidLoad];
-
-
- self.layerView1.layer.shadowOpacity = 0.5f;
- self.layerView2.layer.shadowOpacity = 0.5f;
-
-
- CGMutablePathRef squarePath = CGPathCreateMutable();
- CGPathAddRect(squarePath, NULL, self.layerView1.bounds);
- self.layerView1.layer.shadowPath = squarePath;
- CGPathRelease(squarePath);
-
-
- CGMutablePathRef circlePath = CGPathCreateMutable();
- CGPathAddEllipseInRect(circlePath, NULL, self.layerView2.bounds);
- self.layerView2.layer.shadowPath = circlePath;
- CGPathRelease(circlePath);
- }
data:image/s3,"s3://crabby-images/69a9c/69a9c691f999ca666c7a8945dc767f3283cdbe13" alt="bubuko.com,布布扣"
Layer Masking
例子4.5
- @interface ViewController ()
-
- @property (nonatomic, weak) IBOutlet UIImageView *imageView;
-
- @end
-
- @implementation ViewController
-
- - (void)viewDidLoad
- {
- [super viewDidLoad];
-
-
- CALayer *maskLayer = [CALayer layer];
- maskLayer.frame = self.imageView.bounds;
- UIImage *maskImage = [UIImage imageNamed:@"Cone.png"];
- maskLayer.contents = (__bridge id)maskImage.CGImage;
-
-
- self.imageView.layer.mask = maskLayer;
- }
-
- @end
data:image/s3,"s3://crabby-images/cb7ad/cb7ad1ac726610ec55f6f52a0f3daaddd91525b7" alt="bubuko.com,布布扣"
data:image/s3,"s3://crabby-images/f28d7/f28d77ce623d89bfce3404b13e33be5d80674b99" alt="bubuko.com,布布扣"
Scaling Filters
minificationFilter和magnificationFilter属性
这两个属性主要是设置layer的‘contents’数据缩放拉伸时的描绘方式,minificationFilter用于缩小,magnificationFilter用于放大
默认值都是kCAFilterLinear即‘linear’
有3中设置:kCAFilterLinear,kCAFilterNearest,kCAFilterTrilinear
kCAFilterLinear:默认值,缩放平滑,但容易产生模糊效果
kCAFilterTrilinear:基本和kCAFilterLinear相同
kCAFilterNearest:速度快不会产生模糊,但会降低质量并像素化图像
例子4.6,放大图像,设置magnificationFilter
原图 data:image/s3,"s3://crabby-images/bedb0/bedb0d8b8635ae02105ff08aaecde91926b6c345" alt="bubuko.com,布布扣"
- @interface ViewController ()
-
- @property (nonatomic, strong) IBOutletCollection(UIView) NSArray *digitViews;
- @property (nonatomic, weak) NSTimer *timer;
-
- @end
-
- @implementation ViewController
-
- - (void)viewDidLoad
- {
- [super viewDidLoad];
-
-
- UIImage *digits = [UIImage imageNamed:@"Digits.png"];
-
-
- for (UIView *view in self.digitViews)
- {
-
- view.layer.contents = (__bridge id)digits.CGImage;
- view.layer.contentsRect = CGRectMake(0, 0, 0.1, 1.0);
- view.layer.contentsGravity = kCAGravityResizeAspect;
-
-
- view.layer.magnificationFilter = kCAFilterNearest;
- }
-
-
- self.timer = [NSTimer scheduledTimerWithTimeInterval:1.0
- target:self
- selector:@selector(tick)
- userInfo:nil
- repeats:YES];
-
- [self tick];
- }
-
- - (void)setDigit:(NSInteger)digit forView:(UIView *)view
- {
-
- view.layer.contentsRect = CGRectMake(digit * 0.1, 0, 0.1, 1.0);
- }
-
- - (void)tick
- {
-
- NSCalendar *calendar = [[NSCalendar alloc] initWithCalendarIdentifier:NSGregorianCalendar];
- NSUInteger units = NSHourCalendarUnit | NSMinuteCalendarUnit | NSSecondCalendarUnit;
- NSDateComponents *components = [calendar components:units fromDate:[NSDate date]];
-
-
- [self setDigit:components.hour / 10 forView:self.digitViews[0]];
- [self setDigit:components.hour % 10 forView:self.digitViews[1]];
-
-
- [self setDigit:components.minute / 10 forView:self.digitViews[2]];
- [self setDigit:components.minute % 10 forView:self.digitViews[3]];
-
-
- [self setDigit:components.second / 10 forView:self.digitViews[4]];
- [self setDigit:components.second % 10 forView:self.digitViews[5]];
- }
-
- @end
kCAFilterNearest的效果
data:image/s3,"s3://crabby-images/8feb5/8feb5d7a62c28cb8dcc9aa55b8df0568e5d9f273" alt="bubuko.com,布布扣"
注释掉
使用用默认kCAFilterLinear效果
data:image/s3,"s3://crabby-images/50b23/50b231cc07c0978410b41454dbdd3a4781642e88" alt="bubuko.com,布布扣"
明显模糊了
Group Opacity
先看例子4.7:
- @interface ViewController ()
-
- @property (nonatomic, weak) IBOutlet UIView *containerView;
-
- @end
-
- @implementation ViewController
-
- - (UIButton *)customButton
- {
-
- CGRect frame = CGRectMake(0, 0, 150, 50);
- UIButton *button = [[UIButton alloc] initWithFrame:frame];
- button.backgroundColor = [UIColor whiteColor];
- button.layer.cornerRadius = 10;
-
-
- frame = CGRectMake(20, 10, 110, 30);
- UILabel *label = [[UILabel alloc] initWithFrame:frame];
- label.text = @"Hello World";
-
- label.textAlignment = NSTextAlignmentCenter;
- [button addSubview:label];
-
- return button;
- }
-
- - (void)viewDidLoad
- {
- [super viewDidLoad];
-
-
- UIButton *button1 = [self customButton];
- button1.center = CGPointMake(50, 150);
- [self.containerView addSubview:button1];
-
-
- UIButton *button2 = [self customButton];
- button2.center = CGPointMake(250, 150);
- button2.alpha = 0.5;
- [self.containerView addSubview:button2];
-
-
-
-
- }
-
- @end
data:image/s3,"s3://crabby-images/e13ae/e13aea15e40f97e233f526b5dd7c1a8406b87beb" alt="bubuko.com,布布扣"
button的背景和其subView label的背景同为白色,
左边的button是不透明的,右边用同样方式创建的button透明度为50%,发现右边的label透明度不同于button
其实很容易发现原因,将button透明度设为50%后,button显示50%自己的颜色和其后面50%的颜色,label在
button上面,label也是50%显示择机的颜色,但后面有已经50%透明的button,还要再显示它的50%,即原
button的25%,重合后为75%,即出现上图效果。
有两种解决方法:
1.在工程的Info.plist文件中,添加UIViewGroupOpacity并设为YES
data:image/s3,"s3://crabby-images/7056f/7056fc95b8d26c359b3640cb433ef1abe969571d" alt="bubuko.com,布布扣"
2.设置layer属性shouldRasterize,设为YES可在设置opacity属性时将layer及其sublayer叠加为一张图像
修改代码,
- - (void)viewDidLoad
- {
- [super viewDidLoad];
-
-
- UIButton *button1 = [self customButton];
- button1.center = CGPointMake(50, 150);
- [self.containerView addSubview:button1];
-
-
- UIButton *button2 = [self customButton];
- button2.center = CGPointMake(250, 150);
- button2.alpha = 0.5;
- [self.containerView addSubview:button2];
-
-
- button2.layer.shouldRasterize = YES;
- button2.layer.rasterizationScale = [UIScreen mainScreen].scale;
- }
data:image/s3,"s3://crabby-images/6874f/6874fa3058af67025b08aff61dae2dd814817f36" alt="bubuko.com,布布扣"
IOS Core Animation Advanced Techniques的学习笔记(三)
标签:blog http color io os 使用 ar for strong
原文地址:http://www.cnblogs.com/lzlsky/p/4011817.html