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

首頁 > 系統(tǒng) > iOS > 正文

iOS中一行代碼實現(xiàn) UIView 鏤空效果

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

iOS,代碼,UIView,鏤空

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

前言

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

iOS,代碼,UIView,鏤空

代碼實現(xiàn)看上去像是這樣:

view.maskView = maskView;

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

iOS,代碼,UIView,鏤空

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

一、思路

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

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

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

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

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

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

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

二、實現(xiàn)

生成相反的遮罩圖可以分為三步。假設一開始拿到的 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 來實現(xiàn)。

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

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

view.subtractMaskView = maskView;

四、局限性

1. subtractMaskView 不會自動刷新

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

2. setSubtractMaskView: 不宜被頻繁調用

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

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

 五、源碼

請到 GitHub 上查看完整代碼。

總結

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


注:相關教程知識閱讀請移步到IOS開發(fā)頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
成看片vvv222| 亚洲爱情岛论坛永久| 最新av免费在线观看| 欧美啪啪小视频| 日韩精品视频免费看| 国语对白一区二区| 久久久久久av无码免费网站下载| 一区视频在线看| 在线观看午夜av| 国户精品久久久久久久久久久不卡| 日韩中文字幕在线不卡| 丰满的少妇愉情hd高清果冻传媒| 五月婷婷色综合| 色无极影院亚洲| 国产日产久久高清欧美一区| 国产区精品视频在线观看豆花| 熟年交尾五十路视频在线播放| 亚洲一级大片| 91玉足脚交嫩脚丫在线播放| 欧美日韩国产精品一区二区不卡中文| 成人爽a毛片免费啪啪红桃视频| 亚洲国产日韩欧美一区二区三区| 在线视频不卡一区二区三区| 毛片网站在线看| 中文字幕视频在线观看| 国产成人精品视频免费| 色吊一区二区三区| 97免费中文视频在线观看| 色三级在线观看| 国产精品免费不| 成人在线视频免费观看| 亚欧在线免费观看| 日韩精品免费一区| chinesegaysextube| 超碰超碰在线| 91久久国产综合久久蜜月精品| 屁屁影院国产第一页| 日韩中文字幕av在线| 国产午夜精品理论片a级探花| 欧美色xxxx| 黄色av网址在线免费观看| 日本三级中文字幕在线观看| 51成人做爰www免费看网站| 日韩av一区二区在线观看| 国产精品久久久久久久av大片| 成人3d精品动漫精品一二三| 久久久久久五月天久久久久久久久| 激情欧美日韩| 久久伊人免费视频| 国产永久免费观看| 亚洲精品四区| 国产精品69毛片高清亚洲| 久久久久久久久久久久久久久久av| 九一国产在线观看| 人妻 丝袜美腿 中文字幕| 原千岁中文字幕| 奇米4444一区二区三区| 美女看a上一区| 亚洲成a人片综合在线| 亚洲狼人国产精品| 精品人妻久久久久一区二区三区| 在线激情影院一区| 作爱视频免费观看视频在线播放激情网| 久久久9色精品国产一区二区三区| 亚洲第一二三四五区| 中文字幕一区二区三区四区免费看| 美日韩精品视频免费看| 岛国大片在线观看| 日本亚洲色大成网站www久久| 国产激情一区二区三区四区| 操你啦在线视频| 国产手机免费视频| 91看片淫黄大片一级在线观看| 1024手机在线观看你懂的| 日韩美女主播在线视频一区二区三区| 亚洲精品www久久久久久| 一本久道久久综合狠狠爱亚洲精品| 超碰在线图片| 欧美成人精品欧美一级| 中文字幕12页| 亚洲蜜桃视频| av影院在线播放| 日韩国产一区二区| 在线观看亚洲a| 国产精品露脸视频| 欧洲精品久久久| 亚洲欧美一区二区三区在线播放| 精品中文字幕在线播放| 成人午夜又粗又硬又大| 竹菊久久久久久久| 免费观看v片在线观看| 都市激情亚洲一区| 欧美午夜大胆人体| 西西444www无码大胆| av电影在线免费观看| 色综合视频一区二区三区44| 精品自拍视频在线观看| 韩国成人精品a∨在线观看| 欧美人成网站| 精品麻豆国产| 日韩亚洲国产中文字幕欧美| 欧美精品乱人伦久久久久久| 日日噜噜噜夜夜爽亚洲精品| 四虎影音在线| 欧美激情黄色片| 国产又黄又猛又粗又爽的视频| 激情视频免费网站| 成人午夜看片网址| 日韩三级在线观看| 久久精品在线| 福利网址在线观看| 国产在线一在线二| 亚洲国产精品久久久天堂| 国产私拍福利精品视频二区| 日韩av网站导航| 精品美女一区二区| 999久久久国产999久久久| 性欧美黑人xxxx| 欧美日韩电影一区| 精品小视频在线观看| 老司机一区二区三区| 91精品综合久久久久久久久久久| 国内精品伊人久久久久av影院| 宅男宅女性影片资源在线1| 欧美高清一级片| 日本一区二区三区在线免费观看| 久久露脸国语精品国产91| 亚洲无线码在线一区观看| 在线免费黄色av| 在线日韩欧美视频| 亚洲欧洲日本mm| 国产视频在线视频| 欧美激情第3页| 亚洲国产成人私人影院tom| 中文字幕一区二区不卡| 九九热最新视频//这里只有精品| 中国女人特级毛片| 99久久久无码国产精品性波多| 免费成人美女女| 性生交大片免费看女人按摩| 欧美xxxxxxxxx| 成人做爽爽免费视频| 国产精品一区久久久| gogo高清午夜人体在线| 国产精品视频第一页| 国产精品美女久久久久久| 日韩欧美视频在线播放| 国产成人综合精品三级| 欧美精品xxxxbbbb| 成人黄网大全在线观看| 91久久精品美女| 又粗又黑又大的吊av| 国产亚洲精品久久久久久无几年桃| 色偷偷777| 国产精品精品久久久| 一区二区三区在线免费观看视频| 国产黄色在线| 国产视频91在线| 日本精品久久电影| 国产精品一区二区久久精品| 亚洲图片在线观看| 猛男欧美办公室激情在线| 久久亚洲国产成人精品无码区| 日韩欧美第一区| 肉色丝袜一区二区| 国产视频1区2区| 女生裸体视频一区二区三区| 亚洲三区四区| 影音先锋男人每日资源站| 国产亚洲精品美女久久久久久久久久| 欧美高清hd| 国产精品69页| 精品中文一区| 欧美成人a交片免费看| 青青草成人免费在线视频| 春意影院普通入口| 欧美在线观看网址综合| 日韩精品视频在线观看免费| 小毛片在线观看| 中日韩美女免费视频网址在线观看| 亚洲成人黄色影院| 色综合五月天导航| 欧美成人精品一区二区男人小说| 精品99视频| 亚洲亚洲精品三区日韩精品在线视频| 欧美一区二区| 综合色天天鬼久久鬼色| 国产成人精品免费在线| 欧美一二三区在线观看| 在线视频国产福利| 玖玖爱这里只有精品| 朝桐光av在线一区二区三区| 国产精品污www一区二区三区| 国产亚洲精品久久久久久打不开| 精品国产鲁一鲁****| 久久久综合精品| 国产精品无码网站| 国产一区二区片| 亚洲尤物视频网| 久久精品五月婷婷| 超碰人人干人人| 久久久久99精品久久久久| 偷窥自拍欧美色图| 国产伦精品一区二区| 清纯唯美激情亚洲| 国产网址在线观看| 三级视频在线播放| 夜色激情一区二区| 国产91在线免费| www.在线视频.com| 情趣网站在线观看| 国产欧美成人xxx视频| 正在播放一区二区| 欧美日韩精品一区| youjizz国产精品| 国产欧美一区二区在线播放| 国产videos| 精品亚洲精品福利线在观看| 日韩一区二区福利| 911国产网站尤物在线观看| 在线播放一级片| 杨幂毛片午夜性生毛片| 亚洲日产国产精品| 久久久精品一品道一区| 理论不卡电影大全神| 欧美久久久久久| 视频一区国产视频| 精品人妻久久久久一区二区三区| 日韩一区二区三区在线播放| 亚洲欧美欧美一区二区三区| 欧美成人午夜免费视在线看片| 国产一区二区三区不卡视频网站| 日本一区二区三区中文字幕| 久久高清无码视频| 妓院一钑片免看黄大片| 久久er99热精品一区二区三区| 免费av在线网站| 色婷婷av777| 在线观看精品| 大香煮伊手机一区| 精品日韩av| 年下总裁被打光屁股sp| 被灌满精子的波多野结衣| japanese色国产在线看视频| 中文字幕免费在线看| 亚洲激情一区二区| 一区二区在线观看视频在线| 欧美日韩国产a| 伊人精品久久| 一二三不卡视频| 超碰在线图片| 最新91视频| 久久香蕉国产线看观看网| 激情欧美成人久久综合小说| 国产中文欧美日韩在线| 国产精品高潮呻吟久久av黑人| 福利一区在线观看| 亚洲福利视频专区| 性色av无码久久一区二区三区| 日韩欧美一级精品久久| 亚洲婷婷综合久久一本伊一区| 日韩欧美在线免费观看视频| 亚洲免费人成在线视频观看| 91国产精品成人| 三上悠亚av一区二区三区| 99国产精品一区| 国产欧美精品一区二区三区-老狼| 亚洲欧洲闷骚av少妇影院| 国产伊人久久| 精品视频vs精品视频| 中文字幕乱码一区二区免费| av在线电影免费观看| 日韩欧美伦理电影院| 久久久久久中文| 超碰在线97av| 国产视频精品免费| 成人短片线上看| 国产一二三区在线视频| 神马久久久久久| 亚洲天堂av高清| 国产精品丝袜一区| 亚洲黄色毛片| 国内视频自拍在线视频| 国产精品欧美日韩一区| 黄色网址网站在线观看| 欧美精品xxxxbbbb| 九色porny丨入口在线| 国产成人av电影在线| 久久免费精彩视频| 91亚洲一区二区| 日韩美女黄色片| 亚洲小说春色综合另类电影| 亚洲制服在线观看| 天堂社区 天堂综合网 天堂资源最新版| 日韩国产精品一区| 国产三级精品三级| 亚洲一区二区在线播放相泽| 欧美精品一区二区久久| 精东影业在线观看| 操一操视频一区| 久久福利影视| 久久久人成影片免费观看| 精品免费视频.| 在线成人免费av| 中文字幕一区三区久久女搜查官| 亚洲欧洲一二区| 国产精品久久777777| 国产精品一区视频网站| 欧美亚洲国产一区二区三区va| 国产亚洲精品久久久久动| 亚洲午夜精品久久久久久app| 青青草精品视频在线观看| 2018亚洲男人天堂| 99精品欧美一区二区三区小说| 欧美亚洲高清一区二区三区不卡| 日韩a一区二区| 91av在线免费| www.午夜| 一色屋成人免费精品网| 国产又粗又黄视频| 在线天堂中文www视软件| 国产原创欧美精品| 欧美国产一区二区| 亚洲а∨天堂久久精品喷水| 午夜免费播放观看在线视频| 日韩三级精品| 激情久久综合| 大白屁股一区二区视频|