亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS中一行代碼實現 UIView 鏤空效果

2019-10-21 18:39:16
字體:
來源:轉載
供稿:網友

iOS,代碼,UIView,鏤空

這是一種實現 UIView 鏤空效果的方案,可以快速實現任意形狀的鏤空、文字的鏤空、帶鏤空的毛玻璃效果等。本質上是 UIView 的 maskView 效果。

前言

首先來復習一下遮罩效果的實現。如果我們有一張圖片,又恰好有一個圓,當我們把圓設置為圖片的遮罩時,會得到這樣的結果。

iOS,代碼,UIView,鏤空

代碼實現看上去像是這樣:

view.maskView = maskView;

那么問題來了,如果我們希望得到下面的結果,該怎么做呢?這看起來像是圖層的相減,即原來的圖層減去遮罩的部分。

iOS,代碼,UIView,鏤空

可惜蘋果爸爸不夠貼心,沒有提供方便的接口調用。讓我們來看看可以怎么實現。

一、思路

我們的最終目標是,封裝出一個接口,調用方式類似于 maskView 屬性,可以很方便地對一個 UIView 做鏤空效果。

注:以下用 originView 指代需要上效果的 view ,用 maskView 指代充當遮罩的 view 。

目前看來,可以從兩個方向入手:

  1. 修改遮罩的繪制過程
  2. 修改 maskView 本身

方式一是指,在設置這個屬性的時候,對 originView 的視圖進行重新繪制,然后在繪制的時候,減掉 maskView的區域。

方式二是指,當拿到 maskView 的時候,先對 maskView 本身先進行處理,將遮罩范圍取反。然后再做遮罩效果,由于遮罩的區域已經相反,于是得到的結果也是相反的,就達到鏤空的目的。

看上去方式二比較靠譜,而且最后是調用 UIView 的 setMaskView: 來實現,還可以保留原來遮罩的一些特性。比如當修改 maskView 的 frame 的時候, originView 的遮罩位置也會相應改變。

二、實現

生成相反的遮罩圖可以分為三步。假設一開始拿到的 maskView 是下面這樣,讓我們來看下,轉換過程中遮罩圖每一步的變化。

iOS,代碼,UIView,鏤空

注:為了更直觀的效果,圖片中透明的部分用灰白相間格子來表示(以下相同)。

1、將 maskView 轉化為 UIImage

UIGraphicsBeginImageContextWithOptions(self.bounds.size, NO, [UIScreen mainScreen].scale);CGContextTranslateCTM(UIGraphicsGetCurrentContext(),           view.frame.origin.x,           view.frame.origin.y);[view.layer renderInContext:UIGraphicsGetCurrentContext()];UIImage *image = UIGraphicsGetImageFromCurrentImageContext();UIGraphicsEndImageContext();

這一步拿到了 maskView 對應的 image 圖像。此時遮罩圖的大小會被同步為 originView 的大小。

iOS,代碼,UIView,鏤空 2、將

UIImage 轉換為只有 alpha 通道的 CGContextRef

CGImageRef originalMaskImage = [image CGImage];float width = CGImageGetWidth(originalMaskImage);float height = CGImageGetHeight(originalMaskImage);  int strideLength = ROUND_UP(width * 1, 4);unsigned char * alphaData = calloc(strideLength * height, sizeof(unsigned char));CGContextRef alphaOnlyContext = CGBitmapContextCreate(alphaData,                           width,                           height,                           8,                           strideLength,                           NULL,                           kCGImageAlphaOnly);  CGContextDrawImage(alphaOnlyContext, CGRectMake(0, 0, width, height), originalMaskImage);

這時候的 alphaOnlyContext 對應的圖像是下面這樣,只保留了 alpha 通道。

iOS,代碼,UIView,鏤空 3、將

CGContextRef 中的 alpha 值進行遍歷轉換

for (int y = 0; y < height; y++) {  for (int x = 0; x < width; x++) {    unsigned char val = alphaData[y*strideLength + x];    val = 255 - val;    alphaData[y*strideLength + x] = val;  }}  CGImageRef alphaMaskImage = CGBitmapContextCreateImage(alphaOnlyContext);UIImage *result = [UIImage imageWithCGImage:alphaMaskImage];

轉換后,獲得的 result 圖像是:

iOS,代碼,UIView,鏤空

于是,我們就可以用 result 愉快地進行 mask 了。

三、使用

我們可以將上述的步驟,封裝為一個方法,用 category 來實現。

@interface UIView (MFSubtractMask)- (void)setSubtractMaskView:(UIView *)view;- (UIView *)subtractMaskView;@end

這樣調用起來就十分方便了,一行代碼搞定:

view.subtractMaskView = maskView;

四、局限性

1. subtractMaskView 不會自動刷新

我們知道,當 UIView 的 maskView 的內容動態修改時,會實時反映到 UIView 中。但在本項目中, subtractMaskView 屬性會生成一張全新的圖片來作為遮罩圖,因為不會根據 subtractMaskView 的內容實時來刷新視圖。如果需要更新,必須手動調用 setSubtractMaskView: 方法來重新生成遮罩圖。

2. setSubtractMaskView: 不宜被頻繁調用

setSubtractMaskView: 本質上是生成一個新的遮罩圖的過程,該過程涉及圖片像素的遍歷轉換,較為耗時,不宜頻繁調用。

綜上所述,這種方案適合只生成一次遮罩圖的場景。

 五、源碼

請到 GitHub 上查看完整代碼。

總結

以上所述是小編給大家介紹的iOS中一行代碼實現 UIView 鏤空效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VEVB武林網網站的支持!


注:相關教程知識閱讀請移步到IOS開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美在线亚洲在线| 国产激情视频一区| 国产精品av免费在线观看| 国产偷亚洲偷欧美偷精品| 亚洲精品自拍偷拍| 亚洲性生活视频在线观看| 欧美大学生性色视频| 久久亚洲一区二区三区四区五区高| 69视频在线免费观看| 一本久久综合亚洲鲁鲁| 日韩网站免费观看| 91啪国产在线| 日韩中文在线不卡| 欧美www视频在线观看| 日本精品在线视频| 国模叶桐国产精品一区| 国产精品露脸av在线| 欧美激情奇米色| 在线观看日韩专区| 国产精品久久久一区| 久久精品免费播放| 成人激情视频在线| 久久精品免费电影| 夜夜嗨av色一区二区不卡| 美女精品视频一区| 精品国产欧美一区二区三区成人| 亚洲欧美国内爽妇网| 伊人伊成久久人综合网小说| 中文字幕国产精品久久| 亚洲 日韩 国产第一| 国产精品自产拍高潮在线观看| 久久成人这里只有精品| 欧美激情高清视频| 国产精品免费久久久久影院| 98精品国产自产在线观看| 欧美在线观看网站| 综合网中文字幕| 亚洲国产91精品在线观看| 亚洲欧美国产精品专区久久| 精品国产户外野外| 日韩av手机在线观看| 一本色道久久综合亚洲精品小说| 欧美成人精品在线观看| 亚洲专区在线视频| 久久国产视频网站| 黄色精品在线看| 欧美性少妇18aaaa视频| 欧美理论在线观看| 国产91在线播放| 亚洲网站在线观看| 日韩电影在线观看永久视频免费网站| 日日噜噜噜夜夜爽亚洲精品| 欧美激情va永久在线播放| 亚洲韩国欧洲国产日产av| 久久人人爽人人爽人人片av高请| 国产精品女主播视频| 色先锋资源久久综合5566| 国产99久久精品一区二区| 久久夜精品va视频免费观看| 伊人成人开心激情综合网| 亚洲精品二三区| 久久久久久国产精品三级玉女聊斋| 另类视频在线观看| 国产精品视频大全| 色黄久久久久久| 欧美理论电影网| 日韩欧美中文在线| 91精品国产免费久久久久久| 中国china体内裑精亚洲片| 91久久精品国产91性色| 亚洲九九九在线观看| 国产精品h片在线播放| 俺去啦;欧美日韩| 国产精品久久久久久中文字| 国产欧美一区二区三区视频| 欧美性极品少妇精品网站| 国产suv精品一区二区三区88区| 日韩国产精品亚洲а∨天堂免| 96国产粉嫩美女| 亚洲一区二区三区xxx视频| 亚洲色图校园春色| 中文字幕亚洲情99在线| 精品国产精品自拍| 欧美日韩视频免费播放| 国产91色在线|| 欧美另类69精品久久久久9999| 日韩av影院在线观看| 成人激情在线播放| 久久久久久久电影一区| 日韩高清电影免费观看完整| 国产精品久久久久高潮| 狠狠做深爱婷婷久久综合一区| 欧美专区福利在线| 亚洲第一天堂av| 日韩精品日韩在线观看| 久久久久久久久久久免费精品| 日韩中文字幕视频在线观看| 欧美色图在线视频| 疯狂蹂躏欧美一区二区精品| 亚洲色图色老头| 亚洲欧美制服另类日韩| 激情av一区二区| 国产精品久久久久久一区二区| 一区二区亚洲欧洲国产日韩| 一本色道久久综合亚洲精品小说| 富二代精品短视频| 久久免费观看视频| 亚洲国产精品va在线看黑人| 91久久综合亚洲鲁鲁五月天| 日韩成人av网址| 韩国三级电影久久久久久| 日韩国产中文字幕| 日韩国产欧美精品在线| 成人黄色片在线| 久久在线免费视频| 欧美激情欧美狂野欧美精品| 日韩av第一页| 成人免费网站在线观看| 中文字幕日韩免费视频| 98精品国产高清在线xxxx天堂| 国产精品日日做人人爱| 久久综合五月天| 91欧美精品成人综合在线观看| 国产精品久久久久99| 亚洲片av在线| 亚洲情综合五月天| 麻豆国产精品va在线观看不卡| 日韩中文在线不卡| 深夜福利日韩在线看| 欧美日韩在线视频一区二区| 成人免费直播live| 亚洲色图在线观看| 成人精品一区二区三区电影免费| 欧美性xxxxxxx| 亚洲黄色免费三级| 91色视频在线观看| 国产精品aaaa| 欧美三级欧美成人高清www| 97精品国产97久久久久久春色| 欧美精品18videosex性欧美| 日韩在线欧美在线| 欧美日韩国产中文字幕| 国产精自产拍久久久久久蜜| 国产亚洲精品综合一区91| 欧美性xxxx极品hd满灌| 91精品国产高清| 色悠悠国产精品| 91在线中文字幕| 久久久久久一区二区三区| 国产精品香蕉av| 全亚洲最色的网站在线观看| 亚洲男人天堂2023| 久久久久国产精品免费网站| 57pao成人国产永久免费| 精品日韩中文字幕| 亚洲国产中文字幕在线观看| 91天堂在线视频| 欧美性猛交丰臀xxxxx网站| 国产亚洲一级高清| 国产精品一区专区欧美日韩| 欧美性少妇18aaaa视频| 日韩欧美在线观看视频| 成人福利免费观看| 国产视频亚洲视频|