iOS坐標(biāo)系轉(zhuǎn)換 convertRect

當(dāng)我們想找到一個(gè)視圖的子視圖相對(duì)于當(dāng)前控制器中的坐標(biāo)位置時(shí)奥额,用坐標(biāo)轉(zhuǎn)換就可以很方便的找到了瘫拣,如下圖所示:



如圖所示:從下到上依次是 self.view --> redView -->yellowView

redView的坐標(biāo):{{20, 20}, {335, 627}}滚澜,加在控制器的view上

yellowView的坐標(biāo):{{20, 20}, {295, 587}}仰挣,加在redView上

CGSize size = self.view.frame.size;

UIView *redView = [[UIView alloc] initWithFrame:CGRectMake(20, 20, size.width - 40, size.height - 40)];

redView.backgroundColor = [UIColor redColor];

[self.view addSubview:redView];

UIImageView *yellowView = [[UIImageView alloc] initWithFrame:CGRectMake(20, 20, redView.frame.size.width - 40, redView.frame.size.height - 40)];

yellowView.backgroundColor = [UIColor yellowColor];

[redView addSubview:yellowView];

NSLog(@"%@ --- %@", NSStringFromCGRect(redView.frame), NSStringFromCGRect(yellowView.frame));

//? ? 輸出{{20, 20}, {335, 627}} --- {{20, 20}, {295, 587}}


//把 yellowView.frame 從 redView 的坐標(biāo)系轉(zhuǎn)換到 self.view 的坐標(biāo)系

// 如果傳入的是 yellowView.frame舱沧,則要用 yellowView 的父視圖來(lái)調(diào)用溉愁,toView:傳入的參數(shù)是最終要轉(zhuǎn)換到的那個(gè)視圖屋摇。

//? ? CGRect rect = [redView convertRect:yellowView.frame toView:self.view];? ? // 這個(gè)和下面一句一樣

// 如果傳入的是 yellowView.bounds揩魂,則要用 yellowView 本身來(lái)調(diào)用,toView:傳入的參數(shù)是最終要轉(zhuǎn)換到的那個(gè)視圖炮温。

CGRect rect = [yellowView convertRect:yellowView.bounds toView:self.view]; // 這個(gè)和上面一句一樣

CGRect frame = [self.view convertRect:yellowView.frame fromView:redView];

NSLog(@"%@, %@", NSStringFromCGRect(rect), NSStringFromCGRect(frame));

//? ? 輸出{{40, 40}, {295, 587}}, {{40, 40}, {295, 587}}

//把 yellowView.frame.origin 從 redView 的坐標(biāo)系轉(zhuǎn)換到 self.view 的坐標(biāo)系

CGPoint point = [redView convertPoint:yellowView.frame.origin toView:self.view];

CGPoint point1 = [self.view convertPoint:yellowView.frame.origin fromView:redView];

NSLog(@"%@, %@", NSStringFromCGPoint(point), NSStringFromCGPoint(point1));

// 輸出{40, 40}, {40, 40}

?

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末火脉,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子柒啤,更是在濱河造成了極大的恐慌倦挂,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,627評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件担巩,死亡現(xiàn)場(chǎng)離奇詭異方援,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)涛癌,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,180評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門犯戏,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人拳话,你說(shuō)我怎么就攤上這事先匪。” “怎么了弃衍?”我有些...
    開(kāi)封第一講書(shū)人閱讀 169,346評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵呀非,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我镜盯,道長(zhǎng)岸裙,這世上最難降的妖魔是什么坦冠? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 60,097評(píng)論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮哥桥,結(jié)果婚禮上辙浑,老公的妹妹穿的比我還像新娘。我一直安慰自己拟糕,他們只是感情好判呕,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,100評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著送滞,像睡著了一般侠草。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上犁嗅,一...
    開(kāi)封第一講書(shū)人閱讀 52,696評(píng)論 1 312
  • 那天边涕,我揣著相機(jī)與錄音,去河邊找鬼褂微。 笑死功蜓,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的宠蚂。 我是一名探鬼主播式撼,決...
    沈念sama閱讀 41,165評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼求厕!你這毒婦竟也來(lái)了著隆?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 40,108評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤呀癣,失蹤者是張志新(化名)和其女友劉穎美浦,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體项栏,經(jīng)...
    沈念sama閱讀 46,646評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡浦辨,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,709評(píng)論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了忘嫉。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片荤牍。...
    茶點(diǎn)故事閱讀 40,861評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖庆冕,靈堂內(nèi)的尸體忽然破棺而出康吵,到底是詐尸還是另有隱情,我是刑警寧澤访递,帶...
    沈念sama閱讀 36,527評(píng)論 5 351
  • 正文 年R本政府宣布晦嵌,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏惭载。R本人自食惡果不足惜旱函,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,196評(píng)論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望描滔。 院中可真熱鬧棒妨,春花似錦、人聲如沸含长。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,698評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)拘泞。三九已至纷纫,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間陪腌,已是汗流浹背辱魁。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,804評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留诗鸭,地道東北人染簇。 一個(gè)月前我還...
    沈念sama閱讀 49,287評(píng)論 3 379
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像只泼,于是被迫代替她去往敵國(guó)和親剖笙。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,860評(píng)論 2 361

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

  • UIView(控件) 功能一:界面顯示1. 屏幕上顯示的所有UI元素都叫做控件请唱,也有人叫做視圖、組件过蹂;按鈕(UIB...
    翻這個(gè)墻閱讀 637評(píng)論 0 0
  • 1十绑、簡(jiǎn)單的兩個(gè)view放到控制器的view里,其中blueView是redView的子控件 2酷勺、拖線到控制器里本橙,打...
    XIAODAO閱讀 267評(píng)論 6 2
  • 一、首先來(lái)看看一下我們的需求 將yellowView(黃色view)所在的frame轉(zhuǎn)換為blueView(藍(lán)色v...
    hj的簡(jiǎn)書(shū)閱讀 2,300評(píng)論 0 3
  • 在iOS中隨處都可以看到絢麗的動(dòng)畫(huà)效果脆诉,實(shí)現(xiàn)這些動(dòng)畫(huà)的過(guò)程并不復(fù)雜甚亭,今天將帶大家一窺ios動(dòng)畫(huà)全貌。在這里你可以看...
    每天刷兩次牙閱讀 8,515評(píng)論 6 30
  • 在iOS實(shí)際開(kāi)發(fā)中常用的動(dòng)畫(huà)無(wú)非是以下四種:UIView動(dòng)畫(huà)击胜,核心動(dòng)畫(huà)亏狰,幀動(dòng)畫(huà),自定義轉(zhuǎn)場(chǎng)動(dòng)畫(huà)偶摔。 1.UIView...
    請(qǐng)叫我周小帥閱讀 3,112評(píng)論 1 23