UIView

基本屬性

坐標(biāo)屬性

  1. frame:CGRect格式缎脾,定義其大小和在superView的坐標(biāo)位置
  2. bounds:CGRect格式熄诡,定義其大小和在自己坐標(biāo)系的位置
  3. center:CGPoint格式虱歪,定義其在superView的中心點


    frame&bounds.jpg

    demo

    UIView *view1 = [[UIView alloc] initWithFrame:CGRectMake(20, 20, 280, 250)];
    [view1 setBounds:CGRectMake(-20, -20, 280, 250)];
    view1.backgroundColor = [UIColor redColor];
    [self.view addSubview:view1];//添加到self.view
    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 addSubview:view2];//添加到view1上,[此時view1坐標(biāo)系左上角起點為(-20,-20)]
    NSLog(@"view2 frame:%@========view2 bounds:%@",NSStringFromCGRect(view2.frame),NSStringFromCGRect(view2.bounds));
結(jié)果

透明度屬性

  1. hidden:BOOL茉帅,默認(rèn)值是NO统扳;為YES時

    • 該view和其subViews都會從window中消失爷光,不接收任何輸入事件
    • 該view會從響應(yīng)鏈中移除灶芝,響應(yīng)鏈中的第二個有效的view會成為第一響應(yīng)者
  2. opaque:BOOL麦箍,默認(rèn)值是YES瓦哎;但是當(dāng)其設(shè)置為NO時砸喻,并沒有消失,是因為

    • GPU會對相重合的的部分進(jìn)行重新計算蒋譬,理想情況的公式R = S + D * ( 1 – Sa )割岛,其中S表示源顏色[上層],D表示目標(biāo)顏色[下層]犯助,Sa是S的opaque
    • 如果opaque為YES癣漆,則公式變?yōu)镽 = S,不需要任何計算
    • opaque其實是給繪圖的性能優(yōu)化開關(guān)
    • 注意:這個是和alpha有關(guān)的剂买,opaque為YES,alpha也必須為1.0

    An opaque view is expected to fill its bounds with entirely opaque content—that is, the content should have an alpha value of 1.0. If the view is opaque and either does not fill its bounds or contains wholly or partially transparent content, the results are unpredictable. You should always set the value of this property to NO if the view is fully or partially transparent.

  3. alpha:浮點值惠爽,取值范圍0~1.0癌蓖,表示從完全透明到完全不透明;默認(rèn)值是1婚肆;當(dāng)alpha設(shè)為0時

    • 和hidden類似租副,view和subviews都會消失,該view會從響應(yīng)鏈中被移除
    • 會有動畫效果较性,因為alpha是CALayer的隱式動畫

內(nèi)容屬性

  1. contentMode:枚舉類型用僧,決定內(nèi)容在view中如何展示的,比如圖像是等比拉伸赞咙,還是填滿view等等

transform

  1. transform在矩陣變換的層面上改變視圖的顯示效果责循,完成旋轉(zhuǎn)、形變人弓、平移等等操作沼死。在它被修改的同時着逐,視圖的frame也會被真實改變崔赌。其是CGAffineTransform類型,2D層面的變化耸别。還有個關(guān)于CALayer層面的3D操作:CATransform3D健芭。
  2. 其原點是view.center或者layer.anchorPoint;默認(rèn)值是CGAffineTransformIdentity矩陣。
  3. 常用的函數(shù)
// 用來連接兩個變換效果并返回秀姐。返回的t = t1 * t2
CGAffineTransformConcat(CGAffineTransform t1, CGAffineTransform t2)
// 矩陣初始值
CGAffineTransformIdentity
// 自定義矩陣變換
CGAffineTransformMake(CGFloat a, CGFloat b, CGFloat c, CGFloat d, CGFloat tx, CGFloat ty)
// 旋轉(zhuǎn)視圖慈迈,傳入?yún)?shù)為 角度 * (M_PI / 180);如:CGAffineTransformRotate(self.transform, angle)
CGAffineTransformMakeRotation(CGFloat angle)
CGAffineTransformRotate(CGAffineTransform t, CGFloat angle)
// 縮放視圖省有。如:CGAffineTransformScale(self.transform, sx, sy)
CGAffineTransformMakeScale(CGFloat sx, CGFloat sy)
CGAffineTransformScale(CGAffineTransform t, CGFloat sx, CGFloat sy)
// 平移視圖痒留。如:CGAffineTransformTranslate(self.transform, tx, ty)
CGAffineTransformMakeTranslation(CGFloat tx, CGFloat ty)
CGAffineTransformTranslate(CGAffineTransform t, CGFloat tx, CGFloat ty)
  - (void)viewDidLoad {
    [super viewDidLoad];
    
    UIView *redView = [[UIView alloc]initWithFrame:CGRectMake((kScreenWidth - VIEW_WIDTH)/2, 60, VIEW_WIDTH, VIEW_HEIGHT)];
    redView.backgroundColor = [UIColor redColor];

    CGPoint anchorPoint = redView.layer.anchorPoint;
    UIView *pointView = [[UIView alloc]initWithFrame:CGRectMake(anchorPoint.x*VIEW_WIDTH - POINT_W_H/2,anchorPoint.y*VIEW_HEIGHT -POINT_W_H/2 ,POINT_W_H ,POINT_W_H )];
    pointView.layer.cornerRadius = POINT_W_H/2;
    pointView.backgroundColor = [UIColor blackColor];
    pointView.clipsToBounds = YES;
    
    [redView addSubview:pointView];
    
    [self.view addSubview:redView];
    
//    [self performSelector:@selector(rotateView:) withObject:redView afterDelay:3];
//    [self performSelector:@selector(translateView:) withObject:redView afterDelay:3];
    [self performSelector:@selector(scaleView:) withObject:redView afterDelay:3];
}

- (void)rotateView:(UIView *)view
{
    view.transform = CGAffineTransformRotate(view.transform, M_PI/6);
    NSLog(@"view frame:%@========view bounds:%@",NSStringFromCGRect(view.frame),NSStringFromCGRect(view.bounds));
    NSLog(@"view layer posistion:%@========view layer anchorPoint:%@",NSStringFromCGPoint(view.layer.position),NSStringFromCGPoint(view.layer.anchorPoint));
    [self performSelector:@selector(rotateView:) withObject:view afterDelay:1];
}

- (void)translateView:(UIView *)view
{
    view.transform = CGAffineTransformTranslate(view.transform, VIEW_WIDTH/10, VIEW_HEIGHT/10);
    [self performSelector:@selector(translateView:) withObject:view afterDelay:1];
}

- (void)scaleView:(UIView *)view
{
    //縮小
    view.transform = CGAffineTransformScale(view.transform , 0.8, 0.8 );
    //放大
//    view.transform = CGAffineTransformScale(view.transform , 1.25, 1.25 );
    [self performSelector:@selector(scaleView:) withObject:view afterDelay:1];
}
//增加動畫過程展示,以rotate為例
- (void)rotateViewWithAnimation:(UIView *)view
{
    [UIView animateWithDuration: 3. animations: ^ {
        view.transform = CGAffineTransformRotate(view.transform, M_PI/6);
    }];
}

setNeedsDisplay、setNeedsLayout蠢沿、layoutIfNeeded伸头、layoutSubviews

  1. 布局/定位相關(guān)
  • setNeedsLayout:在receiver標(biāo)上一個需要被重新布局的標(biāo)記,在系統(tǒng)runloop的下一個周期自動調(diào)用layoutSubviews
  • layoutIfNeeded:會遍歷subviews鏈舷蟀,如果需要layout,立即調(diào)用layoutSubviews
  • layoutSubviews:核心函數(shù)恤磷,最終的目的就是調(diào)用該函數(shù),開發(fā)者不要直接調(diào)用該函數(shù)野宜,但可以重寫該函數(shù)扫步,來加入些自己的代碼。該函數(shù)只會進(jìn)行位置匈子,視圖大小的數(shù)字計算河胎,并不會引起屏幕的繪制。

在蘋果的官方文檔中強(qiáng)調(diào): You should override this method only if the autoresizing behaviors of the subviews do not offer the behavior you want.自動布局達(dá)不到想要效果時你才有必要重寫這個方法.可以直接設(shè)置subviews的尺寸;不要直接調(diào)用這個方法,因為不會有任何的作用.如果你需要強(qiáng)制layout刷新,調(diào)用setNeedsLayout來代替; 如果你想要立即刷新你的view,調(diào)用layoutIfNeeded.

  1. 顯示相關(guān)
  • setNeedsDisplay:在receiver標(biāo)上一個需要被重新繪圖的標(biāo)記虎敦,在下一個draw周期自動重繪
  • setNeedsDisplayInRect:不但設(shè)置了標(biāo)記游岳,而且詳細(xì)規(guī)定了需要刷新的區(qū)域搁吓。
  • drawRect:核心函數(shù),將重繪的結(jié)果顯示到屏幕上吭历。開發(fā)人員不可以直接調(diào)用該函數(shù)堕仔,只能重寫該函數(shù),額外做一些事晌区。
  1. 約束相關(guān)(Auto layout)
  • setNeedsUpdateCOnstraints:當(dāng)一個自定義view的某個屬性發(fā)生改變摩骨,并且可能影響到constraint時,需要調(diào)用此方法去標(biāo)記constraints需要在未來的某個點更新朗若,系統(tǒng)然后調(diào)用updateConstraints恼五。
  • updateConstraintsIfNeeded:如果需要更新約束,立即執(zhí)行
  • updateConstraints:自定義view應(yīng)該重寫此方法在其中建立constraints

layoutSubviews在以下情況下會被調(diào)用:

  1. init初始化不會觸發(fā)layoutSubviews
  2. addSubview會觸發(fā)layoutSubviews
  3. 設(shè)置view的Frame會觸發(fā)layoutSubviews哭懈,當(dāng)然前提是frame的值設(shè)置前后發(fā)生了變化
  4. 滾動一個UIScrollView會觸發(fā)layoutSubviews
  5. 旋轉(zhuǎn)Screen會觸發(fā)父UIView上的layoutSubviews事件
  6. 改變一個UIView大小的時候也會觸發(fā)父UIView上的layoutSubviews事件

drawRect在以下情況下會被調(diào)用:

  1. 如果在UIView初始化時沒有設(shè)置rect大小灾馒,將直接導(dǎo)致drawRect不被自動調(diào)用。drawRect調(diào)用是在Controller->loadView, Controller->viewDidLoad兩個方法之后掉用的.所以不用擔(dān)心在控制器中遣总,這些View的drawRect就開始畫了睬罗。這樣可以在控制器中設(shè)置一些值給View(如果這些View draw的時候需要用到某些變量值)。
  2. 該方法在調(diào)用sizeToFit后被調(diào)用旭斥,所以可以先調(diào)用sizeToFit計算出size容达。然后系統(tǒng)自動調(diào)用drawRect:方法。
  3. 通過設(shè)置contentMode屬性值為UIViewContentModeRedraw垂券。那么將在每次設(shè)置或更改frame的時候自動調(diào)用drawRect:花盐。
  4. 直接調(diào)用setNeedsDisplay或者setNeedsDisplayInRect: 觸發(fā)drawRect:,但是有個前提條件是rect不能為0菇爪。

參考

UIView 文檔
理解position和anchorPoint
iOS動畫-Transform和KeyFrame動畫
CGAffineTransform放射變換
內(nèi)存惡鬼drawRect - 談畫圖功能的內(nèi)存優(yōu)化

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末算芯,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子凳宙,更是在濱河造成了極大的恐慌熙揍,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,427評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件近速,死亡現(xiàn)場離奇詭異诈嘿,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)削葱,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評論 3 395
  • 文/潘曉璐 我一進(jìn)店門奖亚,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人析砸,你說我怎么就攤上這事昔字。” “怎么了?”我有些...
    開封第一講書人閱讀 165,747評論 0 356
  • 文/不壞的土叔 我叫張陵作郭,是天一觀的道長陨囊。 經(jīng)常有香客問我,道長夹攒,這世上最難降的妖魔是什么蜘醋? 我笑而不...
    開封第一講書人閱讀 58,939評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮咏尝,結(jié)果婚禮上压语,老公的妹妹穿的比我還像新娘。我一直安慰自己编检,他們只是感情好胎食,可當(dāng)我...
    茶點故事閱讀 67,955評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著允懂,像睡著了一般厕怜。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上粥航,一...
    開封第一講書人閱讀 51,737評論 1 305
  • 那天午绳,我揣著相機(jī)與錄音置侍,去河邊找鬼蜡坊。 笑死秕衙,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的勇吊。 我是一名探鬼主播汉规,決...
    沈念sama閱讀 40,448評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼婚陪!你這毒婦竟也來了近忙?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,352評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎攘残,沒想到半個月后歼郭,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,834評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,992評論 3 338
  • 正文 我和宋清朗相戀三年寄疏,在試婚紗的時候發(fā)現(xiàn)自己被綠了驳棱。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蹈胡。...
    茶點故事閱讀 40,133評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡荷并,死狀恐怖翩伪,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情轻姿,我是刑警寧澤,帶...
    沈念sama閱讀 35,815評論 5 346
  • 正文 年R本政府宣布桨吊,位于F島的核電站医窿,受9級特大地震影響卷要,放射性物質(zhì)發(fā)生泄漏渣聚。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,477評論 3 331
  • 文/蒙蒙 一奕枝、第九天 我趴在偏房一處隱蔽的房頂上張望瓶堕。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,022評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽余佃。三九已至,卻和暖如春跨算,著一層夾襖步出監(jiān)牢的瞬間步势,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,147評論 1 272
  • 我被黑心中介騙來泰國打工背犯, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留坏瘩,地道東北人。 一個月前我還...
    沈念sama閱讀 48,398評論 3 373
  • 正文 我出身青樓漠魏,卻偏偏與公主長得像倔矾,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子柱锹,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,077評論 2 355

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

  • 初識iOS APP開發(fā)#### 在iOS APP開發(fā)中, main函數(shù)仍是程序的入口和出口, 但main函數(shù)不需要...
    DeanYan閱讀 6,180評論 0 3
  • 一哪自、初始化方法 1、- initWithFrame: UIView *view = [[UIView alloc]...
    默默_David閱讀 2,518評論 1 3
  • // //UIView.h //UIKit // //Copyright (c) 2005-2015 Apple ...
    李某lkb閱讀 1,715評論 0 0
  • UIView(控件) 功能一:界面顯示1. 屏幕上顯示的所有UI元素都叫做控件禁熏,也有人叫做視圖壤巷、組件;按鈕(UIB...
    翻這個墻閱讀 635評論 0 0
  • 你看春天 你看細(xì)雨頑皮飄搖過遠(yuǎn)帆 煙花三月里路過了江南 湖面上波光閃 暖風(fēng)隔岸 你看夏天 你看江水流深樹蔭下聽蟬 ...
    R先森airy閱讀 739評論 0 4