CoreAnimation之錨點(diǎn)(anchorPoint)

解釋錨點(diǎn)最好的例子就是鐘表:

1.gif

三個(gè)重疊View 苍蔬,通過改變anchorPoint 改變他們的旋轉(zhuǎn)中心麦牺,說白了錨點(diǎn)就是旋轉(zhuǎn)的句柄惰蜜,把手昂拂。


    self.containView =[[UIView alloc]init];
    self.containView.frame = CGRectMake(200 , 200, 5, 200);
    self.containView.backgroundColor =[UIColor redColor];
    [self.view addSubview:self.containView];
    
    
    self.containViewOne =[[UIView alloc]init];
    self.containViewOne.frame = CGRectMake(200 , 200, 5, 200);
    self.containViewOne.backgroundColor =[UIColor blueColor];
    [self.view addSubview:self.containViewOne];

    
    self.containViewTwo =[[UIView alloc]init];
    self.containViewTwo.frame = CGRectMake(200 , 200, 5, 200);
    self.containViewTwo.backgroundColor =[UIColor greenColor];
    [self.view addSubview:self.containViewTwo];

    self.containView.layer.anchorPoint = CGPointMake(0.5f, 0.95f);
    self.containViewOne.layer.anchorPoint = CGPointMake(0.5f, 0.95f);
    self.containViewTwo.layer.anchorPoint = CGPointMake(0.5f, 0.95f);

    
    self.timer = [NSTimer scheduledTimerWithTimeInterval:1.0 target:self selector:@selector(tick) userInfo:nil repeats:YES];
        //set initial hand positions
    [self tick];

- (void)tick
{
    //convert time to hours, minutes and seconds
    NSCalendar *calendar = [[NSCalendar alloc] initWithCalendarIdentifier:NSGregorianCalendar];
    NSUInteger units = NSHourCalendarUnit | NSMinuteCalendarUnit | NSSecondCalendarUnit;
    NSDateComponents *components = [calendar components:units fromDate:[NSDate date]];
    CGFloat hoursAngle = (components.hour / 12.0) * M_PI * 2.0;
    //calculate hour hand angle //calculate minute hand angle
    CGFloat minsAngle = (components.minute / 60.0) * M_PI * 2.0;
    //calculate second hand angle
    CGFloat secsAngle = (components.second / 60.0) * M_PI * 2.0;
    //rotate hands
    self.containView.transform = CGAffineTransformMakeRotation(hoursAngle);
    self.containViewOne.transform = CGAffineTransformMakeRotation(minsAngle);
    self.containViewTwo.transform = CGAffineTransformMakeRotation(secsAngle);
    self.containView.layer.shouldRasterize = YES;
    self.containViewOne.layer.shouldRasterize = YES;
    self.containViewTwo.layer.shouldRasterize = YES;
}

postion

確切地說,position是layer中的anchorPoint點(diǎn)在superLayer中的位置坐標(biāo)抛猖。因此可以說,position點(diǎn)是相對(duì)suerLayer的口糕,anchorPoint點(diǎn)是相對(duì)layer的昌跌,兩者是相對(duì)不同的坐標(biāo)空間的一個(gè)重合點(diǎn)。
再來看看position的原始定義: The layer’sposition in its superlayer’s coordinate space。 中文可以理解成為position是layer相對(duì)superLayer坐標(biāo)空間的位置吓著,很顯然,這里的位置是根據(jù)anchorPoint來確定的.

**anchorPoint造烁、position搞动、frame
**

anchorPoint的默認(rèn)值為(0.5,0.5),也就是anchorPoint默認(rèn)在layer的中心點(diǎn)驮履。默認(rèn)情況下鱼辙,使用addSublayer函數(shù)添加layer時(shí),如果已知layer的frame值玫镐,根據(jù)上面的結(jié)論倒戏,那么position的值便可以用下面的公式計(jì)算:
position.x = frame.origin.x + 0.5 * bounds.size.width;
position.y = frame.origin.y + 0.5 * bounds.size.height恐似;

里面的0.5是因?yàn)閍nchorPoint取默認(rèn)值杜跷,更通用的公式應(yīng)該是下面的:

position.x = frame.origin.x + anchorPoint.x *bounds.size.width;
position.y = frame.origin.y + anchorPoint.y *bounds.size.height矫夷;

下面再來看另外兩個(gè)問題葛闷,如果單方面修改layer的position位置,會(huì)對(duì)anchorPoint有什么影響呢双藕?修改anchorPoint又如何影響position呢淑趾?

 self.containView =[[UIView alloc]init];
    self.containView.frame = CGRectMake(200 , 200,100, 200);
    self.containView.backgroundColor =[UIColor redColor];
    [self.view addSubview:self.containView];
    NSLog(@"%@",NSStringFromCGPoint(self.containView.layer.anchorPoint));
    
    self.containView.layer.position = CGPointMake(50, 50);
     NSLog(@"%@",NSStringFromCGPoint(self.containView.layer.anchorPoint));
03.png

根據(jù)代碼測(cè)試,兩者互不影響忧陪,受影響的只會(huì)是frame.origin扣泊,也就是layer坐標(biāo)原點(diǎn)相對(duì)superLayer會(huì)有所改變。換句話說嘶摊,frame.origin由position和anchorPoint共同決定延蟹,上面的公式可以變換成下面這樣的:
frame.origin.x = position.x - anchorPoint.x *bounds.size.width;
frame.origin.y = position.y - anchorPoint.y *bounds.size.height更卒;
這就解釋了為什么修改anchorPoint會(huì)移動(dòng)layer等孵,因?yàn)閜osition不受影響,只能是frame.origin做相應(yīng)的改變蹂空,因而會(huì)移動(dòng)layer俯萌。

因?yàn)?position點(diǎn)和anchorPoint點(diǎn)是獨(dú)立的果录,自己不會(huì)因?yàn)榱硗庖粋€(gè)的改變而發(fā)生變化
參考文章 (http://blog.sina.com.cn/s/blog_155083d9e0102wi0r.html)
這篇文章描述錨點(diǎn)描述的很清楚(http://www.reibang.com/p/7703e6fc6191)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市咐熙,隨后出現(xiàn)的幾起案子弱恒,更是在濱河造成了極大的恐慌,老刑警劉巖棋恼,帶你破解...
    沈念sama閱讀 216,843評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件返弹,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡爪飘,警方通過查閱死者的電腦和手機(jī)义起,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,538評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來师崎,“玉大人默终,你說我怎么就攤上這事±缯郑” “怎么了齐蔽?”我有些...
    開封第一講書人閱讀 163,187評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)床估。 經(jīng)常有香客問我含滴,道長(zhǎng),這世上最難降的妖魔是什么丐巫? 我笑而不...
    開封第一講書人閱讀 58,264評(píng)論 1 292
  • 正文 為了忘掉前任谈况,我火速辦了婚禮,結(jié)果婚禮上鞋吉,老公的妹妹穿的比我還像新娘鸦做。我一直安慰自己,他們只是感情好谓着,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,289評(píng)論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著坛掠,像睡著了一般赊锚。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上屉栓,一...
    開封第一講書人閱讀 51,231評(píng)論 1 299
  • 那天舷蒲,我揣著相機(jī)與錄音,去河邊找鬼友多。 笑死牲平,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的域滥。 我是一名探鬼主播纵柿,決...
    沈念sama閱讀 40,116評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼蜈抓,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了昂儒?” 一聲冷哼從身側(cè)響起沟使,我...
    開封第一講書人閱讀 38,945評(píng)論 0 275
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎渊跋,沒想到半個(gè)月后腊嗡,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,367評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡拾酝,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,581評(píng)論 2 333
  • 正文 我和宋清朗相戀三年燕少,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蒿囤。...
    茶點(diǎn)故事閱讀 39,754評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡客们,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蟋软,到底是詐尸還是另有隱情镶摘,我是刑警寧澤,帶...
    沈念sama閱讀 35,458評(píng)論 5 344
  • 正文 年R本政府宣布岳守,位于F島的核電站凄敢,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏湿痢。R本人自食惡果不足惜涝缝,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,068評(píng)論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望譬重。 院中可真熱鬧拒逮,春花似錦、人聲如沸臀规。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,692評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽塔嬉。三九已至玩徊,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間谨究,已是汗流浹背恩袱。 一陣腳步聲響...
    開封第一講書人閱讀 32,842評(píng)論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留胶哲,地道東北人畔塔。 一個(gè)月前我還...
    沈念sama閱讀 47,797評(píng)論 2 369
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親澈吨。 傳聞我的和親對(duì)象是個(gè)殘疾皇子把敢,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,654評(píng)論 2 354

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