日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

UIViewContentMode 图文解说

發布時間:2023/12/13 综合教程 39 生活家
生活随笔 收集整理的這篇文章主要介紹了 UIViewContentMode 图文解说 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

在iOS應用開發中我們常常要對視圖的contentMode屬性進行設置,尤其在使用UIImageView視圖時設置這個屬性的概率很高。我們知道contentMode的類型是UIViewContentMode的枚舉,那么其每個值是什么含義,設置后會有什么效果呢?下面就來總結下。

UIViewContentModeLeft

如果將UIImageView對象的contentMode設置為UIViewContentModeLeft,其內部的圖片會按照原有的尺寸大小,以垂直居中,水平居左的方式顯示。見UIViewContentModeLeft模式效果(1)。如果圖片的尺寸大于UIImageView視圖的size,那么超出size的部分將會被裁減掉。如UIViewContentModeLeft模式效果(2)所示。

UIViewContentModeLeft模式效果(1) UIViewContentModeLeft模式效果(2)

至于其它模式,諸如UIViewContentModeRight、UIViewContentModeTop、UIViewContentModeCenter之類模式與UIViewContentModeLeft類似,只是對齊方式不同而已。我們可以看下UIViewContentModeCenter模式的顯示效果。

UIViewContentModeCenter模式效果(1) UIViewContentModeCenter模式效果(2)

由此我們可以得出這樣的結論:UIViewContentModeLeft、UIViewContentModeRight等這類帶有位置信息的模式,不會改變圖片的尺寸,或者更確切地說不會對圖片進行縮放處理,但有可能對圖片進行裁剪操作,這僅發生在圖片尺寸超出UIImageView視圖size的情況下。

說完了UIViewContentModeLeft,我們來看看UIViewContentModeScaleAspectFit、UIViewContentModeScaleAspectFill、UIViewContentModeScaleToFill三個比較難理解、容易混淆的模式。

UIViewContentModeScaleAspectFit

UIViewContentModeScaleAspectFit模式效果

在UIViewContentModeScaleAspectFit模式下,UIImageView視圖會將圖片進行等比例縮放,請注意是等比例縮放。縮放到圖片能夠在視圖size內完整顯示(水平垂直方向均居中),且圖片的寬度或者高度(至少一個)恰好與視圖的寬度或者高度相等。如果高度相等,則圖片左右兩邊會留下等寬的空白空間,如上面UIViewContentModeScaleAspectFit模式效果所示;如果寬度相等,則圖片的上下方會留下等高的空白空間;如果寬高都相等,則圖片恰好鋪滿整個視圖。UIViewContentModeScaleAspectFit模式使用等比例縮放,且不對圖片進行裁剪,顯示效果比較協調,因而是我們最為常用的一種模式。

UIViewContentModeScaleAspectFill

UIViewContentModeScaleAspectFill模式效果

UIViewContentModeScaleAspectFill模式也是對圖片進行等比例縮放,與UIViewContentModeScaleAspectFit模式不同的是,它將圖片縮放到正好鋪滿整個UIImageView視圖顯示,且圖片的寬度或者高度(至少一個)恰好與視圖的寬度或者高度相等。如果高度相等,則圖片左右會被裁剪掉等寬的內容;如果寬度相等,則圖片的上下會被裁剪掉等高的內容,如上面UIViewContentModeScaleAspectFill模式效果所示;如果寬高都相等,則圖片不會被裁剪。

UIViewContentModeScaleToFill

UIViewContentModeScaleToFill模式效果

相較于UIViewContentModeScaleAspectFit和UIViewContentModeScaleAspectFill,UIViewContentModeScaleToFill模式好理解多了。它是將圖片的寬高強行變成和UIImageView視圖的寬高相等來顯示,因此該變化無法保證是等比縮放。如果圖片的寬高比與視圖的寬高比相同,則是等比縮放,否則非等比縮放。這樣極易導致圖片變形,顯示不協調。盡管如此,UIViewContentModeScaleToFill仍是比較常用的一種模式,某些視圖(比如UIButton)的背景圖backgroundImage就是以該模式為默認的顯示模式。

UIViewContentModeRedraw

除了上述模式,UIViewContentMode還有一個枚舉值UIViewContentModeRedraw。UIViewContentModeRedraw模式比較特別,它不是用來說明如何展示圖片的,而是告訴視圖在每次設置或者更改frame的時候自動調用drawRect:方法。

弄清楚了這些模式的含義和作用,我們就可以在開發iOS應用的過程中更加得心應手地設置圖片了。

以上內容是本人結合開發經驗并參考了部分資料而撰寫的,如有不妥之處還請不吝賜教,愿大家能夠互相學習,共同進步。

轉自:http://46aae4d1e2371e4aa769798941cef698.devproxy.yunshipei.com/e20914053/article/details/49944281

總結

以上是生活随笔為你收集整理的UIViewContentMode 图文解说的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。