IOS視圖View 的frame與bounds的區別

    在學習IOS一段時間後,忽然對view 的frame和bounds這兩個屬性搞迷糊了,不知二者的區別了,只記得之前有學過,今天從新再複習一下,看來好記性不如爛筆頭,作個筆記,幫助本身記憶和快速複習。html

基本區別:

bounds是指這個view在它本身座標系的座標和大小,而frame指的是這個view在它superview的座標系的座標和大小
區別主要在座標系這一塊。

很明顯一個是本身爲原點的座標系,一個是以屏幕爲原點的座標系。絕對座標。。。相對座標。。。好比屏幕旋轉的時候就要以相對來重繪。 
frame 若是一個按鈕,是在表格裏,按鈕的frame 的座標也是相對的,並非相對屏幕,也就是說是相對座標,不是絕對座標

我也想知道任何一個uiview如何求得它在屏幕上的座標(參照文章)。iview

1、首先列一下公認的資料:函數

先看到下面的代碼你確定就明白了一些:
學習

-(CGRect)frame{
    return CGRectMake(self.frame.origin.x,self.frame.origin.y,self.frame.size.width,self.frame.size.height);
}
-(CGRect)bounds{
    return CGRectMake(0,0,self.frame.size.width,self.frame.size.height);
}

很明顯,bounds的原點是(0,0)點(就是view自己的座標系統,默認永遠都是0,0點,除非認爲setbounds),而frame的原點倒是任意的(相對於父視圖中的座標位置)。
ui


再來看張圖就明白了,spa

        frame: 該view在父view座標系統中的位置和大小。(參照點是,父座標系統)
        bounds:該view在本地座標系統中的位置和大小。(參照點是,本地座標系統,就至關於ViewB本身的座標系統,以0,0點爲起點)
        center:該view的中心點在父view座標系統中的位置和大小。(參照點是,父座標系統)
.net

我我的認爲,bounds稍微有點費解,稍不留神,想的多了,就會繞進去。每一個view都有一個本地座標系統。這個座標系統做用比較重要,好比觸 摸的回調函數中的UITouch裏面的>座標值都是參照這個本地座標系統的座標。固然bounds這個屬性也是參照這個本地座標系統來的。其實本地 座標系統的關鍵就是要知道的它的原點(0,0)在什麼位置(這個位置又是相對於上層的view的本地座標系統而言的,固然最上面的一層view就是 window它的本地座標系統原點就是屏幕的左上角了)。經過修改view的bounds屬性能夠修改本地座標系統的原點位置。
日誌


因此,我我的認爲,bounds影響到子view的位置和大小。code

2、demo演示:
orm

    UIView *view1 = [[UIView alloc] initWithFrame:CGRectMake(20, 20, 280, 250)];
    [view1 setBounds:CGRectMake(-20, -20, 280, 250)];
    view1.backgroundColor = [UIColor redColor];
    
    // 添加到self.view
    [self.view addSubview:view1];
    NSLog(@"view1 frame:%@====view1 bounds:%@",NSStringFromCGRect(view1.frame),NSStringFromCGRect(view1.bounds));
    
    UIView *view2 = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 100, 100)];
    view2.backgroundColor = [UIColor yellowColor];
    
    //添加到view1上,[此時view1座標系左上角起點爲(-20,-20)]
    [view1 addSubview:view2];
    NSLog(@"view2 frame:%@===view2 bounds:%@",NSStringFromCGRect(view2.frame),NSStringFromCGRect(view2.bounds));


(log輸出日誌代表,每一個新的view默認的bounds其實都是(0,0))


延伸閱讀: frame在項目中的相關應用示例:UIImage和代碼建立UIButton

相關文章
相關標籤/搜索