001-contents屬性

1、CALayer 有一個(gè)屬性叫做contents拓哺,這個(gè)屬性的類型被定義為id,意味著它可以是任何類型的對(duì)象脖母。在這種情況下士鸥,你可以給contents屬性賦任何值,你的app仍然能夠通過(guò)編譯谆级。但是烤礁,在實(shí)踐中,如果你給contents賦的不是CGImage肥照,那么你得到的圖層將是空白的脚仔。

2、通過(guò)一個(gè)實(shí)例給圖層的contents賦值一張圖片

//
//  ViewController.m
//  002-layerView
//
//  Created by freedom on 2016/12/15.
//  Copyright ? 2016年 Revan. All rights reserved.
//

#import "ViewController.h"
//#import <QuartzCore/QuartzCore.h>

@interface ViewController ()
/**
 *  layerView
 */
@property (nonatomic, strong) UIView *layerView;

/**
 *  blueLayer
 */
//@property (nonatomic, strong) CALayer *blueLayer;


@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // 背景顏色
    self.view.backgroundColor = [UIColor darkGrayColor];
    
    // 圖片
    UIImage *img = [UIImage imageNamed:@"img"];
    
    // View
    self.layerView = [[UIView alloc] initWithFrame:CGRectMake(100, 100, 200, 200)];
    self.layerView.backgroundColor = [UIColor whiteColor];
    // 給視圖的圖層設(shè)置圖片
    self.layerView.layer.contents = (__bridge id _Nullable)(img.CGImage);
    
    
    self.layerView.contentMode = UIViewContentModeScaleAspectFit;
    //設(shè)置視圖的模式
    self.layerView.layer.contentsGravity = kCAGravityCenter;
    
//    self.layerView.layer.contentsScale = img.scale;//[UIScreen mainScreen].scale;
    
    //圖層內(nèi)容放大
//    self.layerView.layer.contentsScale = 0.5;
    
    [self.view addSubview:self.layerView];
    
    //blueLayer
//    self.blueLayer = [CALayer layer];
//    self.blueLayer.frame = CGRectMake(50, 50, 100, 100);
//    self.blueLayer.backgroundColor = [UIColor blueColor].CGColor;
//    [self.layerView.layer addSublayer:self.blueLayer];
}


@end

3舆绎、屬性contentGravity

  • CALayer與 contentMode 對(duì)應(yīng)的屬性叫做 contentsGravity鲤脏,但是它是一個(gè)NSString類型,而不是像對(duì)應(yīng)的UIKit部分吕朵,那里面的值是枚舉猎醇。contentsGravity 可選的常量有一下一些:

  • kCAGravityCenter

  • kCAGravityTop

  • kCAGravityBottom

  • kCAGravityLeft

  • kCAGravityRight

  • kCAGravityTopLeft

  • kCAGravityTopRight

  • kCAGravityBottomLeft

  • kCAGravityBottomRight

  • kCAGravityResize

  • kCAGravityResizeAspect

  • kCAGravityResizeAspectFill

  • 和contentmode一樣,contentsGravity的目的是為了決定內(nèi)容在圖層的邊界中怎么對(duì)齊努溃,我們將使用kCAGravityResizeAspect,它的效果等同于UIViewContentModeScaleAspectFit硫嘶,同時(shí)它還能在圖層等比例拉伸以適應(yīng)圖層的邊界

//設(shè)置視圖圖層的模式
    self.layerView.layer.contentsGravity = kCAGravityCenter;

4、maskToBounds

  • 1茅坛、UIView有一個(gè)叫做 clipsToBounds 的屬性可以用來(lái)決定是否顯示超出邊界的內(nèi)容
  • 2音半、CALayer對(duì)應(yīng)的屬性叫做maskTobounds,把它設(shè)置為YES,就會(huì)切除超出部分

5贡蓖、contentsRect

  • 1、CALayer的contentsRect 屬性允許我們?cè)趫D層邊框里顯示寄宿圖的一個(gè)子域煌茬。這涉及到圖片是如何顯示和拉伸的斥铺,所以要比contentsGravity靈活多了
  • 2、和bounds坛善,frame不同晾蜘,contentsRect不是按點(diǎn)來(lái)計(jì)算的邻眷,它使用了單位坐標(biāo),單位坐標(biāo)指定在0~1之間剔交,是一個(gè)相對(duì)值(像素和點(diǎn)就是絕對(duì)值)肆饶,所以是相對(duì)與寄宿圖的尺寸的。
  • 3岖常、默認(rèn)的contentsRect 是{0, 0, 1, 1}驯镊,這意味著整個(gè)寄宿圖默認(rèn)都是可見的,如果我們指定一個(gè)小一點(diǎn)的矩形竭鞍,圖片就會(huì)別裁剪
QQ20161220-0@2x.png
  • 4板惑、給contentsRect設(shè)置一個(gè)負(fù)數(shù)的原點(diǎn) 或者是 設(shè)置尺寸大于{1,1}的尺寸也是可以的偎快,這種情況下冯乘,最外面的像素會(huì)被拉伸以填充剩下的區(qū)域
  • 5、contentsRect 在app中最有趣的地方在于一個(gè)叫做image sprites(圖片拼合)的用法
  • 6晒夹、典型地裆馒,圖片拼合后可以打包整合到一張大圖上一次性載入。相比多次載入不同的圖片丐怯,這樣做能夠帶來(lái)很多方面的好處:
  • 內(nèi)存使用
  • 載入時(shí)間
  • 渲染性能

contentsRect實(shí)例

原圖

QQ20161220-0@2x.png
#import "ViewController.h"
//#import <QuartzCore/QuartzCore.h>

@interface ViewController ()
/**
*  iglooView
*/
@property (nonatomic, strong) UIView *iglooView;
/**
 *  coneView
 */
@property (nonatomic, strong) UIView *coneView;

/**
 *  anchorView
 */
@property (nonatomic, strong) UIView *anchorView;

/**
 *  shipView
 */
@property (nonatomic, strong) UIView *shipView;


/**
 *  blueLayer
 */
@property (nonatomic, strong) CALayer *blueLayer;


@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // 背景顏色
    self.view.backgroundColor = [UIColor darkGrayColor];
    
    //iglooView
    self.iglooView = [[UIView alloc] initWithFrame:CGRectMake(10, 100, 100, 100)];
    self.iglooView.backgroundColor = [UIColor redColor];
    [self.view addSubview:self.iglooView];
    
    //coneView
    self.coneView = [[UIView alloc] initWithFrame:CGRectMake(120, 100, 100, 100)];
    self.coneView.backgroundColor = [UIColor blueColor];
    [self.view addSubview:self.coneView];
    
    //anchorView
    self.anchorView = [[UIView alloc] initWithFrame:CGRectMake(10, 210, 100, 100)];
    self.anchorView.backgroundColor = [UIColor orangeColor];
    [self.view addSubview:self.anchorView];
    
    //shipView
    self.shipView = [[UIView alloc] initWithFrame:CGRectMake(120, 210, 100, 100)];
    self.shipView.backgroundColor = [UIColor yellowColor];
    [self.view addSubview:self.shipView];
    
    
    // 圖片
    UIImage *img = [UIImage imageNamed:@"hc"];
    
    [self addSpriteImage:img withContentRect:CGRectMake(0, 0, 0.5, 0.5) toLayer:self.iglooView.layer];
    
    [self addSpriteImage:img withContentRect:CGRectMake(0.5, 0, 0.5, 0.5) toLayer:self.coneView.layer];
    
    [self addSpriteImage:img withContentRect:CGRectMake(0, 0.5, 0.5, 0.5) toLayer:self.anchorView.layer];
    
    [self addSpriteImage:img withContentRect:CGRectMake(0.5, 0.5, 0.5, 0.5) toLayer:self.shipView.layer];
    
}


// 拼合圖片的方法
- (void)addSpriteImage:(UIImage *) image withContentRect:(CGRect) rect toLayer:(CALayer *) layer {
    // 設(shè)置圖層contents
    layer.contents = (__bridge id _Nullable)(image.CGImage);
    // 設(shè)置圖片顯示模式
    layer.contentsGravity = kCAGravityResizeAspect;
    
    // set contentsRect
    layer.contentsRect = rect;
//    layer.contentsCenter = rect;
    
}

剪切后的圖片

QQ20161220-1@2x.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末领追,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子响逢,更是在濱河造成了極大的恐慌绒窑,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,907評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件舔亭,死亡現(xiàn)場(chǎng)離奇詭異些膨,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)钦铺,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門订雾,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人矛洞,你說(shuō)我怎么就攤上這事洼哎。” “怎么了沼本?”我有些...
    開封第一講書人閱讀 164,298評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵噩峦,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我抽兆,道長(zhǎng)识补,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,586評(píng)論 1 293
  • 正文 為了忘掉前任辫红,我火速辦了婚禮凭涂,結(jié)果婚禮上祝辣,老公的妹妹穿的比我還像新娘。我一直安慰自己切油,他們只是感情好蝙斜,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,633評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著澎胡,像睡著了一般孕荠。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上滤馍,一...
    開封第一講書人閱讀 51,488評(píng)論 1 302
  • 那天岛琼,我揣著相機(jī)與錄音,去河邊找鬼巢株。 笑死槐瑞,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的阁苞。 我是一名探鬼主播困檩,決...
    沈念sama閱讀 40,275評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼那槽!你這毒婦竟也來(lái)了悼沿?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,176評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤骚灸,失蹤者是張志新(化名)和其女友劉穎糟趾,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體甚牲,經(jīng)...
    沈念sama閱讀 45,619評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡义郑,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,819評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了丈钙。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片非驮。...
    茶點(diǎn)故事閱讀 39,932評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖雏赦,靈堂內(nèi)的尸體忽然破棺而出劫笙,到底是詐尸還是另有隱情,我是刑警寧澤星岗,帶...
    沈念sama閱讀 35,655評(píng)論 5 346
  • 正文 年R本政府宣布填大,位于F島的核電站,受9級(jí)特大地震影響伍茄,放射性物質(zhì)發(fā)生泄漏栋盹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,265評(píng)論 3 329
  • 文/蒙蒙 一敷矫、第九天 我趴在偏房一處隱蔽的房頂上張望例获。 院中可真熱鬧,春花似錦曹仗、人聲如沸榨汤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,871評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)收壕。三九已至,卻和暖如春轨蛤,著一層夾襖步出監(jiān)牢的瞬間蜜宪,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,994評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工祥山, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留圃验,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,095評(píng)論 3 370
  • 正文 我出身青樓缝呕,卻偏偏與公主長(zhǎng)得像澳窑,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子供常,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,884評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容