圖層幾何學(xué)

UIView 有三個(gè)比較重要的布局屬性: frame晶渠、bounds蔫巩、center首昔。CALayer 對應(yīng)的分別叫做: frame、bounds阶祭、position

center/position 都代表了圖層相對于父圖層 anchorPoint 所在的位置

錨點(diǎn)

默認(rèn) anchorPoint 位于圖層的中點(diǎn)绷杜,所以圖層的將會(huì)以這個(gè)點(diǎn)為中點(diǎn)放置

anchorPonit 用單位坐標(biāo)來描述直秆。 左上角 {0, 0}, 右下角 {1, 1}, 默認(rèn) {0.5, 0.5}.也可以設(shè)置x鞭盟、y 坐標(biāo)小與0 或者 大于 1圾结,將它設(shè)置在圖層之外

備注: 當(dāng)改變了 anchorPoint, position 屬性是保持固定的。但是 frame 改變了

view.layer.anchorPoint = CGPointMake(0.5f, 0.9f)


坐標(biāo)系

常規(guī)來說齿诉,在ios上筝野,一個(gè)圖層的position 位于父圖層的左上角,但是在Mac OS上粤剧,通常是位于左下角歇竟。Core Animation 可以通過 geometryFlipped 屬性來適配這2種情況。它決定了一個(gè)圖層的坐標(biāo)是否相對于父圖層垂直翻轉(zhuǎn)俊扳,是一個(gè)Bool 類型途蒋。

在ios上,通過設(shè)置它為yes馋记,意味著它的子圖層將會(huì)被垂直翻轉(zhuǎn)号坡,也就是將會(huì)沿著底部排版而不是通常的頂部

Z坐標(biāo)軸

和UIView嚴(yán)格的二維坐標(biāo)系不同,CALayer存在于一個(gè)三維空間當(dāng)中梯醒。除了 position 和 anchorPoint 之外宽堆,還有 zPosition 和 anchorPointZ 兩個(gè)屬性。二者都是在 Z 軸上描述圖層位置的浮點(diǎn)類型

a.layer.zPosition = 1.0f ? ?(先add a,再 add b茸习。按理是 b覆蓋 a畜隶。設(shè)置 zPosition后,a 被提到上面号胚,覆蓋 b)


Hit Testing

CALayer 并不關(guān)心任何響應(yīng)鏈?zhǔn)录崖圆荒苤苯犹幚碛|摸事件或手勢。但是它有一系列的方法幫你處理事件: -containsPoint: ? ?和 ? -hitTest

-containsPoint: 接受一個(gè)在本圖層坐標(biāo)系下的 CGPoint猫胁,如果這個(gè)點(diǎn)在圖層 frame 范圍內(nèi)就返回 YES

-hitTest:方法統(tǒng)一接受一個(gè) CGPoint 類型參數(shù)箱亿,它返回圖層本身,或者包含這個(gè)坐標(biāo)點(diǎn)的葉子節(jié)點(diǎn)圖層

注意:當(dāng)調(diào)用圖層的 -hitTest: 方法時(shí)弃秆,測算的順序嚴(yán)格依賴于圖層樹中的圖層順序(和UIView處理事件類似)届惋。之前提到的 zPosition 屬性可以明顯改變屏幕上的圖層的順序,但是不能改變事件的傳遞順序菠赚。

當(dāng)使用視圖的時(shí)候脑豹,可以充分的利用 UIView 類接口暴露出來的 UIViewAutoresizingMask 和 NSLayoutConstraint API, 但如果想隨意控制CALayer 的布局,就要手工操作衡查。最簡單的方法就是使用 CALayerDelegate 如下函數(shù)

- (void)layoutSublayersOfLayer:(CALayer *)layer;

當(dāng)圖層的 bounds 發(fā)生改變瘩欺,或圖層的 -setNeedsLayout 方法被調(diào)用的時(shí)候,這個(gè)函數(shù)將會(huì)被執(zhí)行峡捡。這使得你可以手動(dòng)的重新擺放或重新調(diào)整子圖層的大小击碗。但是不能像 UIView 的 autoresizingMask 和 constraints 屬性做到自適應(yīng)屏幕旋轉(zhuǎn)筑悴。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市稍途,隨后出現(xiàn)的幾起案子阁吝,更是在濱河造成了極大的恐慌,老刑警劉巖械拍,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件突勇,死亡現(xiàn)場離奇詭異,居然都是意外死亡坷虑,警方通過查閱死者的電腦和手機(jī)甲馋,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來迄损,“玉大人定躏,你說我怎么就攤上這事∏鄣校” “怎么了痊远?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長氏捞。 經(jīng)常有香客問我碧聪,道長,這世上最難降的妖魔是什么液茎? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任逞姿,我火速辦了婚禮,結(jié)果婚禮上捆等,老公的妹妹穿的比我還像新娘滞造。我一直安慰自己,他們只是感情好栋烤,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布断部。 她就那樣靜靜地躺著,像睡著了一般班缎。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上她渴,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天达址,我揣著相機(jī)與錄音,去河邊找鬼趁耗。 笑死沉唠,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的苛败。 我是一名探鬼主播满葛,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼径簿,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了嘀韧?” 一聲冷哼從身側(cè)響起篇亭,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎锄贷,沒想到半個(gè)月后译蒂,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡谊却,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年柔昼,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片炎辨。...
    茶點(diǎn)故事閱讀 39,722評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡捕透,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出碴萧,到底是詐尸還是另有隱情乙嘀,我是刑警寧澤,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布勿决,位于F島的核電站乒躺,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏低缩。R本人自食惡果不足惜嘉冒,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望咆繁。 院中可真熱鬧讳推,春花似錦、人聲如沸玩般。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽坏为。三九已至究驴,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間匀伏,已是汗流浹背洒忧。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留够颠,地道東北人熙侍。 一個(gè)月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親蛉抓。 傳聞我的和親對象是個(gè)殘疾皇子庆尘,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,614評論 2 353

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