實(shí)用小技巧(九):類頭條模糊背景的實(shí)現(xiàn)

版本記錄

版本號(hào) 時(shí)間
V1.0 2017.06.26

前言

在app中污尉,類似頭條的視頻播放,在播放列表里面坦袍,會(huì)有背景是處理成模糊效果的,這中效果給人很新奇的感覺等太。這一篇捂齐,就仿照實(shí)現(xiàn)頭條的模糊效果。感興趣的可以看看我寫的其他小技巧
1. 實(shí)用小技巧(一):UIScrollView中上下左右滾動(dòng)方向的判斷

2. 實(shí)用小技巧(二):屏幕橫豎屏的判斷和相關(guān)邏輯
3.實(shí)用小技巧(三):點(diǎn)擊手勢(shì)屏蔽子視圖的響應(yīng)
4.實(shí)用小技巧(四):動(dòng)態(tài)的增刪標(biāo)簽視圖
5.實(shí)用小技巧(五):通過相冊(cè)或者相機(jī)更改圖標(biāo)
6.實(shí)用小技巧(六):打印ios里所有字體
7. 實(shí)用小技巧(七):UITableViewCell自適應(yīng)行高的計(jì)算
8. 實(shí)用小技巧(八):數(shù)字余額顯示的分隔

實(shí)現(xiàn)目標(biāo)

類似頭條的視頻缩抡,會(huì)有很多模糊的效果奠宜,我截了兩張圖包颁,大約就是這個(gè)效果。

實(shí)例1
示例2

大家可以看見熊貓和吾六一兩邊的都是模糊的效果压真。下面我就實(shí)現(xiàn)一個(gè)這種效果娩嚼。

實(shí)現(xiàn)過程

下面還是直接看代碼,寫一個(gè)UIImageView的分類滴肿。

#import <Foundation/Foundation.h>

@interface UIImageView (ZBUntil)

- (void)sd_setGaussFuzzyImageWithURL:(nullable NSURL *)url placeholderImage:(nullable UIImage *)placeholder;

@end
#import "UIImageView+ZBUntil.h"

@implementation UIImageView (ZBUntil)

- (void)sd_setGaussFuzzyImageWithURL:(nullable NSURL *)url placeholderImage:(nullable UIImage *)placeholder 
{  
    self.contentMode = UIViewContentModeScaleToFill;
    
    NSArray *subViewsArr = self.subviews;
    [subViewsArr enumerateObjectsUsingBlock:^(UIView *obj, NSUInteger idx, BOOL * _Nonnull stop) {
        if (obj.tag == 100) {
            [obj removeFromSuperview];
        }
    }];
    
    UIImageView *gaosiView = [[UIImageView alloc] init];
    gaosiView.tag = 100;
    gaosiView.contentMode = UIViewContentModeScaleAspectFit;
    [self addSubview:gaosiView];
    [gaosiView mas_remakeConstraints:^(MASConstraintMaker *make) {
        make.left.right.top.bottom.mas_equalTo(self);
    }];
    gaosiView.image = [UIImage boxblurImage:placeholder withBlurNumber:0.5f];
    [self sd_setImageWithURL:url placeholderImage:placeholder options:0 progress:nil completed:^(UIImage * _Nullable image, NSError * _Nullable error, SDImageCacheType cacheType, NSURL * _Nullable imageURL) {
        if (image) {
            self.image = [UIImage boxblurImage:image withBlurNumber:0.5f];
            gaosiView.image = image;
        }
    }];
}

@end

+  (UIImage *)boxblurImage:(UIImage *)image withBlurNumber:(CGFloat)blu;
+(UIImage *)boxblurImage:(UIImage *)image withBlurNumber:(CGFloat)blur
{
    if (!image) {
        return nil;
    }
    if (blur < 0.f || blur > 1.f) {
        blur = 0.5f;
    }
    int boxSize = (int)(blur * 40);
    boxSize = boxSize - (boxSize % 2) + 1;
    CGImageRef img = image.CGImage;
    vImage_Buffer inBuffer, outBuffer;
    vImage_Error error;
    void *pixelBuffer;
    //從CGImage中獲取數(shù)據(jù)
    CGDataProviderRef inProvider = CGImageGetDataProvider(img);
    CFDataRef inBitmapData = CGDataProviderCopyData(inProvider);
    //設(shè)置從CGImage獲取對(duì)象的屬性
    inBuffer.width = CGImageGetWidth(img);
    inBuffer.height = CGImageGetHeight(img);
    inBuffer.rowBytes = CGImageGetBytesPerRow(img);
    inBuffer.data = (void*)CFDataGetBytePtr(inBitmapData);
    pixelBuffer = malloc(CGImageGetBytesPerRow(img) * CGImageGetHeight(img));
    if(pixelBuffer == NULL)
        NSLog(@"No pixelbuffer");
    outBuffer.data = pixelBuffer;
    outBuffer.width = CGImageGetWidth(img);
    outBuffer.height = CGImageGetHeight(img);
    outBuffer.rowBytes = CGImageGetBytesPerRow(img);
    error = vImageBoxConvolve_ARGB8888(&inBuffer, &outBuffer, NULL, 0, 0, boxSize, boxSize, NULL, kvImageEdgeExtend);
    if (error) {
        NSLog(@"error from convolution %ld", error);
    }
    CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB();
    CGContextRef ctx = CGBitmapContextCreate( outBuffer.data, outBuffer.width, outBuffer.height, 8, outBuffer.rowBytes, colorSpace, kCGImageAlphaNoneSkipLast);
    CGImageRef imageRef = CGBitmapContextCreateImage (ctx);
    UIImage *returnImage = [UIImage imageWithCGImage:imageRef];
    //clean up CGContextRelease(ctx);
    CGColorSpaceRelease(colorSpace);
    free(pixelBuffer);
    CFRelease(inBitmapData);
    CGColorSpaceRelease(colorSpace);
    CGImageRelease(imageRef);
    return returnImage;
}

這里有幾句代碼我一開始的時(shí)候并沒有加岳悟。

    NSArray *subViewsArr = self.subviews;
    [subViewsArr enumerateObjectsUsingBlock:^(UIView *obj, NSUInteger idx, BOOL * _Nonnull stop) {
        if (obj.tag == 100) {
            [obj removeFromSuperview];
        }
    }];

但是,如果不加泼差,就會(huì)發(fā)現(xiàn)有些對(duì)象釋放不掉贵少,運(yùn)行出來的視圖查看層次也是很多疊在一起的。效果如下:

效果1
效果2

下面我們查看圖層堆缘。

效果1圖層
效果2圖層

大家可以看到效果1中有間隙漏出來了滔灶,效果2中圖像根本不對(duì),上一個(gè)cell的圖像漏出來了吼肥,說明上一個(gè)圖像并沒有釋放录平。加上我剛才寫的那幾行代碼就可以了,就可以釋放和正常顯示了缀皱。

實(shí)現(xiàn)效果

下面我們看一下最終的實(shí)現(xiàn)效果斗这。

效果1
效果2
效果3

后記

這個(gè)效果挺有意思,就是一個(gè)高斯模糊唆鸡,希望大家感興趣的留言討論涝影,謝謝大家。

風(fēng)景真美
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末争占,一起剝皮案震驚了整個(gè)濱河市燃逻,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌臂痕,老刑警劉巖伯襟,帶你破解...
    沈念sama閱讀 218,941評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異握童,居然都是意外死亡姆怪,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門澡绩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來稽揭,“玉大人,你說我怎么就攤上這事肥卡∠疲” “怎么了?”我有些...
    開封第一講書人閱讀 165,345評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵步鉴,是天一觀的道長揪胃。 經(jīng)常有香客問我璃哟,道長,這世上最難降的妖魔是什么喊递? 我笑而不...
    開封第一講書人閱讀 58,851評(píng)論 1 295
  • 正文 為了忘掉前任随闪,我火速辦了婚禮,結(jié)果婚禮上骚勘,老公的妹妹穿的比我還像新娘铐伴。我一直安慰自己,他們只是感情好调鲸,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,868評(píng)論 6 392
  • 文/花漫 我一把揭開白布盛杰。 她就那樣靜靜地躺著,像睡著了一般藐石。 火紅的嫁衣襯著肌膚如雪即供。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,688評(píng)論 1 305
  • 那天于微,我揣著相機(jī)與錄音逗嫡,去河邊找鬼。 笑死株依,一個(gè)胖子當(dāng)著我的面吹牛驱证,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播恋腕,決...
    沈念sama閱讀 40,414評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼抹锄,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼!你這毒婦竟也來了荠藤?” 一聲冷哼從身側(cè)響起伙单,我...
    開封第一講書人閱讀 39,319評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎哈肖,沒想到半個(gè)月后吻育,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,775評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡淤井,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年布疼,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片币狠。...
    茶點(diǎn)故事閱讀 40,096評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡游两,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出漩绵,到底是詐尸還是另有隱情贱案,我是刑警寧澤,帶...
    沈念sama閱讀 35,789評(píng)論 5 346
  • 正文 年R本政府宣布渐行,位于F島的核電站轰坊,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏祟印。R本人自食惡果不足惜肴沫,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,437評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蕴忆。 院中可真熱鬧颤芬,春花似錦、人聲如沸套鹅。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽卓鹿。三九已至菱魔,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間吟孙,已是汗流浹背澜倦。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評(píng)論 1 271
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留杰妓,地道東北人藻治。 一個(gè)月前我還...
    沈念sama閱讀 48,308評(píng)論 3 372
  • 正文 我出身青樓,卻偏偏與公主長得像巷挥,于是被迫代替她去往敵國和親桩卵。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,037評(píng)論 2 355

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

  • 一 倍宾、思想動(dòng)員緊跟進(jìn) 1雏节、向外橫向拓展。以某某班凿宾、某某校為參照矾屯,看看他們是怎么做的,向他們看齊初厚,向他們學(xué)習(xí)...
    06acbd34ae17閱讀 1,399評(píng)論 0 0
  • 千里相隨件蚕,生死相依,不離不棄产禾,永生不朽排作。大被同眠,小飯同桌亚情,義薄云天妄痪,誓死追隨。桃園三義楞件,吾備承天衫生,吾云蓋世裳瘪,吾飛...
    孫武芮雯閱讀 280評(píng)論 2 4
  • 一、Core ML簡介 1罪针、Core ML框架iOS11推出了Core ML框架彭羹,極大地降低了開發(fā)者在iphone...
    SwordDevil閱讀 740評(píng)論 0 1
  • 又來繼續(xù)寫今天的流水賬啦派殷。昨天因?yàn)榘l(fā)版本,所以今天又基本只上半天班~早上11點(diǎn)多到的公司墓阀。然后今天又可惡的下雨了毡惜。...
    丶Saikaka閱讀 164評(píng)論 0 0