iOS開發-UI (七)view層次動畫 和 ImageView

来源:http://www.cnblogs.com/fcug/archive/2017/01/21/6337984.html
-Advertisement-
Play Games

知識點: 1.UIView的簡單動畫 2.UIView層次關係 3.UIImageView的使用 4.UIView 停靠模式 UIView的簡單動畫 1.UIView坐標系統 1)UIView相對於父視圖的坐標系統 2.UIView的frame,center,bounds關係 frame: 該vie ...


知識點:

1.UIView的簡單動畫

2.UIView層次關係

3.UIImageView的使用

4.UIView 停靠模式

 

=====================

UIView的簡單動畫

 

   1.UIView坐標系統

     1)UIView相對於父視圖的坐標系統

 

   2.UIView的frame,center,bounds關係

     frame:  該view在父view坐標系統中的位置和大小。(參照點是,父親的坐標系統)

     bounds: 該view在本地坐標系統中的位置和大小。(參照點是,本地坐標系統)

     center: 該view的中心點在父view坐標系統中的位置。(參照點是,父親的坐標系統)

 

   3.設置透明度

    @property(nonatomic)  CGFloat   alpha 

  view1.alpha = 0.2;

   4.UIView中的簡單動畫效果1

     1.開始動畫

       +(void)beginAnimations:(NSString *)animationID context:(void *)context;

     2.持續時間

       +(void)setAnimationDuration:(CFTimeInterval)dur;

     3.提交動畫(運行動畫)

       +(void)commitAnimations;

 

//開啟動畫

    [UIView beginAnimations:nil context:nil];

    //設置動畫持續時間

    [UIView setAnimationDuration:5.0];

  //提交動畫

[UIView commitAnimations];

 

  5. UIView中的簡單動畫效果2

+ (void)animateWithDuration:(NSTimeInterval)duration 

animations:(void (^)(void))animations 

completion:(void (^)(BOOL finished))completion 

                    

//開始動畫

    [UIView animateWithDuration:2.0 animations:^{

        //提交的動畫內容

        //改變view1的位置

        view1.center = CGPointMake(CGRectGetWidth(self.window.frame) - 50, CGRectGetHeight(self.window.frame) - 50);
        
        //改變綠色

        view1.backgroundColor = [UIColor greenColor];

    } completion:^(BOOL finished) {

        //上述動畫執行完畢之後,會回調此block當中的代碼塊
       //開啟動畫

        [UIView animateWithDuration:2.0 animations:^{

            //恢複原位

            view1.center = CGPointMake(50, 70);

            view1.backgroundColor = [UIColor orangeColor];

        }];

    }];

 

=====================

UIView層次關係

 

   1.如何在UIView上疊加新的UIView

     - (void)addSubview:(UIView *)view;

[self.window addSubview:view1];

 

   2.如何獲取UIView的父視圖

     @property(nonatomic,readonly) UIView  *superview;

//從一個子視圖當中獲取它的父視圖對象

    NSLog(@"sView3.superview = %p fView = %p",sView3.superview,fView);

 

   3.如何獲取UIView子視圖

     @property(nonatomic,readonly,copy) NSArray *subviews; //從父視圖當中獲取到它之上的所有子視圖

    for (UIView *tempView in fView.subviews)

 

   4.把一個子視圖移動到最前端

- (void)bringSubviewToFront:(UIView *)view;

//移動某個子視圖到最前端

    [fView bringSubviewToFront:sView1];

    //移動某個子視圖到最後端

    [fView sendSubviewToBack:sView2];

 

   5.交換子視圖的圖層

- (void)exchangeSubviewAtIndex:(NSInteger)index1 withSubviewAtIndex:(NSInteger)index2;

//交換連個視圖的圖層

    [fView exchangeSubviewAtIndex:0 withSubviewAtIndex:2];

 

   6.如何在特定位置插入一個視圖

     - (void)insertSubview:(UIView *)view atIndex:(NSInteger)index;

//插入視圖

    [fView insertSubview:sView4 atIndex:1];

   7.如何刪除一個視圖(該函數是給要刪除的視圖發送)

     - (void)removeFromSuperview;

ps:removeFromSuperview:將一個視圖從父視圖當中移除,同時會移除該視圖上的所有子視圖

//一次性刪除這個視圖上的所有子視圖

        [tempView removeFromSuperview];

 

   8.如何剪切一個視圖超出父視圖之外的部分

     @property(nonatomic)  BOOL   clipsToBounds; 

//剪裁超出父視圖的部分

    fView.clipsToBounds = YES;

 

   9.如何隱藏和顯示一個UIView

     @property(nonatomic,getter=isHidden) BOOL  hidden;

//隱藏一個視圖

    sView1.hidden = YES;

   10.檢測視圖之間的關係

     - (BOOL)isDescendantOfView:(UIView *)view;

 

//檢測一個視圖是否為另外一個視圖的子視圖

    if ([sView2 isDescendantOfView:fView]) {

        

        NSLog(@"sView2是fView的子視圖");

        

    }

=====================

UIImageView使用

   

1.如何重新設置圖片內容

  @property(nonatomic,retain) UIImage *image

2.如何解決圖片內容變形問題(該屬性由UIView繼承)

  @property(nonatomic) UIViewContentMode contentMode

UIViewContentModeScaleToFill             拉伸內容,會導致內容變形

UIViewContentModeScaleAspectFit    拉伸內容,內容比例不變

UIViewContentModeScaleAspectFill    拉伸內容,內容比例不變,但是有可能部分內容不能顯示

imageView.contentMode = UIViewContentModeScaleAspectFill;

 

=====================

簡單的手勢操作

 

   UITapGestureRecognizer             點擊

   UIPinchGestureRecognizer              二指往內或往外撥動,平時經常用到的縮放

   UIRotationGestureRecognizer        旋轉

   UISwipeGestureRecognizer           滑動,快速移動

   UIPanGestureRecognizer                 拖移,慢速移動

   UILongPressGestureRecognizer      長按

 

/*

     參數1:目標對象

     參數2:回調的方法

     */

    UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(myTap:)];

//雙擊觸發

    tap.numberOfTapsRequired = 2;

    

    //添加手勢到Window之上

    [self.window addGestureRecognizer:tap];

 

//快速滑動

    UISwipeGestureRecognizer *swi = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(myTap:)];

    /*

     typedef NS_OPTIONS(NSUInteger, UISwipeGestureRecognizerDirection) {

     UISwipeGestureRecognizerDirectionRight = 1 << 0,

     UISwipeGestureRecognizerDirectionLeft  = 1 << 1,

     UISwipeGestureRecognizerDirectionUp    = 1 << 2,

     UISwipeGestureRecognizerDirectionDown  = 1 << 3

     };

     */

    //設置支持的方向

    //水平和豎直方向能支持其中一種

    swi.direction =  UISwipeGestureRecognizerDirectionUp | UISwipeGestureRecognizerDirectionDown;

    

    [self.window addGestureRecognizer:swi];

 

//長按手勢

    //長按之後,滑動也會觸發,放手也會觸發一次

    UILongPressGestureRecognizer *longGes = [[UILongPressGestureRecognizer alloc] initWithTarget:self action:  @selector(myTap:)];

    //觸發事件需要的最短時間

    longGes.minimumPressDuration = 1;

    [self.window addGestureRecognizer:longGes];

    

    //關閉人機交互開關

    //self.window.userInteractionEnabled = NO;

    

    /*

     註意事項:

     1.每一個UIView都有一個屬性userInteractionEnabled,如果這個屬性值為NO,則無法觸發事件(包括手勢和btn的點擊事件)

     2.UILabel,UIImageView在實例化出來的時候,預設userInteractionEnabled的值為NO

     3.如果父視圖的userInteractionEnabled的值為NO,則子視圖也不可以響應事件

     4.如果視圖被隱藏,也不可以響應事件

     

     */

ps:當視圖hidden屬性設置為YES的時候,或者userInteractionEnabled=NO

的時候,就無法進行人機交互

 

 

=====================

UIView 停靠模式

 

   1.自動佈局:當父視圖變化時子視圖如何變化

1)先設置父視圖的autoresize屬性為YES

2)再設置子視圖的mask屬性

//設置停靠模式

    //父視圖設置autoresizesSubviews

    fView2.autoresizesSubviews = YES;

    //子視圖設置停靠的模式

    //UIViewAutoresizingFlexibleLeftMargin 子視圖到父視圖的右邊距距離固定

    //UIViewAutoresizingFlexibleWidth 寬度是可變的

    sView2.autoresizingMask = UIViewAutoresizingFlexibleWidth;

 

    @property(nonatomic) BOOL autoresizesSubviews;

 

    @property(nonatomic) UIViewAutoresizing autoresizingMask;

UIViewAutoresizingNone

就是不自動調整。

UIViewAutoresizingFlexibleLeftMargin 

自動調整與superView左邊的距離,保證與superView右邊的距離不變 UIViewAutoresizingFlexibleRightMargin

自動調整與superView的右邊距離,保證與superView左邊的距離不變。 UIViewAutoresizingFlexibleTopMargin 

自動調整與superView頂部的距離,保證與superView底部的距離不變。 UIViewAutoresizingFlexibleBottomMargin 

自動調整與superView底部的距離,保證與superView頂部的距離不變。 UIViewAutoresizingFlexibleWidth

自動調整自己的寬度,保證與superView左邊和右邊的距離不變。 UIViewAutoresizingFlexibleHeight

自動調整自己的高度,保證與superView頂部和底部的距離不變。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • html代碼 js代碼 上傳服務端代碼 "查看博客c 最齊全的上傳文件方法" 附近下載 "上傳文件js" ...
  • 我們經常會需要驗證字元串的格式,比如密碼長度範圍、電子郵件格式、固定電話號碼和手機號碼格式等,這個時候我們經常會需要用到正則表達式。但是正則表達式用起來性能會低一點,所以在需要驗證的時候能不使用正則表達式還是儘量不要使用正則表達式。下麵貼出來我寫的一個驗證類,裡面包含了一些常用的驗證。這些都是服務端 ...
  • https://github.com/jobbole/awesome-javascript-cn http://collect.w3ctrain.com ...
  • 預載入圖片是提高用戶體驗的一個很好方法。圖片預先載入到瀏覽器中,訪問者便可順利地在你的網站上衝浪,並享受到極快的載入速度。這對圖片畫廊及圖片占據很大比例的網站來說十分有利,它保證了圖片快速、無縫地發佈,也可幫助用戶在瀏覽你網站內容時獲得更好的用戶體驗。本文將分享三個不同的預載入技術,來增強網站的性能 ...
  • 1.簡介 function命令與函數名之間有一個星號*; 函數體內部使用yield語句,定義遍歷器的每個成員,即不同的內部狀態。 總結: 調用Generator函數,返回一個部署了Iterator介面的遍歷器對象,用來操作內部指針。 以後,每次調用遍歷器對象的next方法,就會返回一個有著value ...
  • css快速佈局必弄清的幾件事:塊級元素&內聯元素概念釐清、盒模型、定位元素顯示優先順序總結、居中對齊方法總結、樣式繼承等。 ...
  • 我們在安裝環境的時候安裝了NDK,可以在eclipse下直接生成so文件。NDK的壓縮包裡面自帶了一些sample工程,NDK的文件直接解壓到某個目錄下即可。 第一次生成so文件的時候,我們先使用NDK的sample下的hello-jni的例子。 1、啟動eclipse,通過Create proje ...
  • 之前忘了把這些整理出來,現在補充一下,應該放在前面學習的 知識點: 1.UI的初步認識 2.UIWindow 3.UIView 4.UIlabel UI的初步認識 1.什麼是UI(*) UI即User Interface(用戶界面)的簡稱。UI設計則是指對軟 件的人機交互、操作邏輯、界面美觀的整體設 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...