WKWebView加載3d模型占用內(nèi)存過大導(dǎo)致的白屏問題

用WKWebView加載3d模型發(fā)現(xiàn)在6P(6P畫質(zhì)好偶惠,3x煤蹭,屏幕大昼汗,但是內(nèi)存1G)上會白屏肴熏。但是別的機型沒有發(fā)現(xiàn)異常,白屏的主要原因是由于內(nèi)存占用太大顷窒。

WKWebView 是蘋果在 WWDC 2014 上推出的新一代 webView 組件蛙吏,用以替代 UIKit 中笨重難用源哩、內(nèi)存泄漏的 UIWebView。WKWebView 擁有60fps滾動刷新率鸦做、和 safari 相同的 JavaScript 引擎等優(yōu)勢励烦。所以我覺得它很厲害,于是加載模型的任務(wù)當(dāng)然是它了泼诱,不再使用UIWebView坛掠。但是就出現(xiàn)了問題。

1.WKWebView 白屏問題

WKWebView 自詡擁有更快的加載速度治筒,更低的內(nèi)存占用屉栓,但實際上 WKWebView 是一個多進(jìn)程組件,Network Loading 以及 UI Rendering 在其它進(jìn)程中執(zhí)行耸袜。初次適配 WKWebView 的時候友多,我們也驚訝于打開 WKWebView 后,App 進(jìn)程內(nèi)存消耗反而大幅下降堤框,但是仔細(xì)觀察會發(fā)現(xiàn)域滥,Other Process 的內(nèi)存占用會增加。在一些用 webGL 渲染的復(fù)雜頁面蜈抓,使用 WKWebView 總體的內(nèi)存占用(App Process Memory + Other Process Memory)不見得比 UIWebView 少很多启绰。

在 UIWebView 上當(dāng)內(nèi)存占用太大的時候,App Process 會 crash资昧;而在 WKWebView 上當(dāng)總體的內(nèi)存占用比較大的時候酬土,WebContent Process 會 crash,從而出現(xiàn)白屏現(xiàn)象格带。在 WKWebView 中加載下面的測試鏈接可以穩(wěn)定重現(xiàn)白屏現(xiàn)象:
http://people.mozilla.org/~rnewman/fennec/mem.html
這個時候 WKWebView.URL 會變?yōu)?nil, 簡單的 reload 刷新操作已經(jīng)失效撤缴,對于一些長駐的H5頁面影響比較大。

A叽唱、借助 WKNavigtionDelegate

iOS 9以后 WKNavigtionDelegate 新增了一個回調(diào)函數(shù):

- (void)webViewWebContentProcessDidTerminate:(WKWebView *)webView
當(dāng) WKWebView 總體內(nèi)存占用過大屈呕,頁面即將白屏的時候,系統(tǒng)會調(diào)用上面的回調(diào)函數(shù)棺亭,我們在該函數(shù)里執(zhí)行[webView reload](這個時候 webView.URL 取值尚不為 nil)解決白屏問題虎眨。在一些高內(nèi)存消耗的頁面可能會頻繁刷新當(dāng)前頁面,H5側(cè)也要做相應(yīng)的適配操作镶摘。

B嗽桩、檢測 webView.title 是否為空

并不是所有H5頁面白屏的時候都會調(diào)用上面的回調(diào)函數(shù),比如凄敢,最近遇到在一個高內(nèi)存消耗的H5頁面上 present 系統(tǒng)相機碌冶,拍照完畢后返回原來頁面的時候出現(xiàn)白屏現(xiàn)象(拍照過程消耗了大量內(nèi)存,導(dǎo)致內(nèi)存緊張涝缝,WebContent Process 被系統(tǒng)掛起)扑庞,但上面的回調(diào)函數(shù)并沒有被調(diào)用譬重。在WKWebView白屏的時候,另一種現(xiàn)象是 webView.titile 會被置空, 因此罐氨,可以在 viewWillAppear 的時候檢測 webView.title 是否為空來 reload 頁面臀规。
綜合以上兩種方法可以解決絕大多數(shù)的白屏問題。

2. 但是reload后重新加載栅隐,還是會出現(xiàn)白屏塔嬉。真是醉了。后來還得回到UIWebView上约啊,用UIWebView加載就沒事邑遏。驗證了這句話。

初次適配 WKWebView 的時候恰矩,我們也驚訝于打開 WKWebView 后记盒,App 進(jìn)程內(nèi)存消耗反而大幅下降,但是仔細(xì)觀察會發(fā)現(xiàn)外傅,Other Process 的內(nèi)存占用會增加纪吮。在一些用 webGL 渲染的復(fù)雜頁面,使用 WKWebView 總體的內(nèi)存占用(App Process Memory + Other Process Memory)不見得比 UIWebView 少很多萎胰。我們加載的正是模型啊碾盟,用的 webGL渲染,所以WKWebView還沒UIWebView好呢技竟。所以選擇它們的時候還得考慮下公司的需求嘍冰肴。

UIWebView沒有實時的進(jìn)度提示,所以我做了個假的模仿WKWebView榔组∥跷荆看著還行能用。

#import "BaseViewController.h"

@interface BaseUIWebViewController : BaseViewController

- (instancetype)initWithUrl:(NSString *)urlStr;

@property(nonatomic,strong)UIWebView *webView;

@property(nonatomic,copy)NSString *urlString;

@property(nonatomic,strong)UIProgressView *progressView;

@end
//
//  BaseUIWebViewController.m

//
//  Created by wyb on 2017/4/7.
//  Copyright ? 2017年 xxx. All rights reserved.
//

#import "BaseUIWebViewController.h"

@interface BaseUIWebViewController ()<UIWebViewDelegate>

@property(nonatomic,strong)NSTimer *timer;

@end

@implementation BaseUIWebViewController

- (instancetype)initWithUrl:(NSString *)urlStr{
    
    self = [super init];
    if (self) {
        
        self.urlString = urlStr;
        
    }
    return self;
}


- (void)viewDidLoad {
    [super viewDidLoad];
    
    self.webView = [[UIWebView alloc]initWithFrame:CGRectMake(0, 0, KScreenWidth, KScreenHeight-64)];
    self.webView.delegate = self;
    self.webView.opaque = NO;
    self.webView.backgroundColor = [UIColor clearColor];
    [self.view addSubview:self.webView];
    
    self.timer = [NSTimer scheduledTimerWithTimeInterval:0.02 target:self selector:@selector(progressChange) userInfo:nil repeats:YES];
    [self.timer setFireDate:[NSDate distantFuture]];
    
    self.progressView = [[UIProgressView alloc]initWithFrame:CGRectMake(0, 0, KScreenWidth, 2)];
    //進(jìn)度條的顏色
    self.progressView.trackTintColor = [UIColor blackColor];
    self.progressView.progressTintColor = KColorFromRGB(0x00c853);
    [self.view addSubview:self.progressView];
    
    if (self.urlString != nil) {
        NSURL *url = [NSURL URLWithString:self.urlString];
        NSURLRequest *request = [NSURLRequest requestWithURL:url];
        [self.webView loadRequest:request];
    }
   
    
    
}

- (void)dealloc
{
    [self.timer invalidate];
    self.timer = nil;
}

- (void)progressChange
{
    self.progressView.progress += 0.002;
    
    if (self.progressView.progress >0.8) {
        self.progressView.progress += 0.0001;
    }
    
    if (self.progressView.progress >=1.0) {
        
        [UIView animateWithDuration:0.25f animations:^{
            self.progressView.alpha = 0.0f;
            self.progressView.progress = 0.0f;
        }];
    }
   
}

- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType
{
    
    return YES;
}
- (void)webViewDidStartLoad:(UIWebView *)webView
{
    [self.timer setFireDate:[NSDate date]];
}
- (void)webViewDidFinishLoad:(UIWebView *)webView
{
    [self finishedLoad];
}
- (void)webView:(UIWebView *)webView didFailLoadWithError:(NSError *)error
{
    [self finishedLoad];
}

- (void)finishedLoad
{
    [self.timer invalidate];
    self.timer = nil;
    
    self.progressView.progress = 1.0;
    [UIView animateWithDuration:0.25f animations:^{
        self.progressView.alpha = 0.0f;
        self.progressView.progress = 0.0f;
    }];
    
}


@end

WKWebView還有很多坑騰訊Bugly總結(jié)了很多搓扯。

鏈接在這

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末检痰,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子锨推,更是在濱河造成了極大的恐慌铅歼,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,858評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件换可,死亡現(xiàn)場離奇詭異椎椰,居然都是意外死亡,警方通過查閱死者的電腦和手機沾鳄,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評論 3 395
  • 文/潘曉璐 我一進(jìn)店門俭识,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人洞渔,你說我怎么就攤上這事套媚。” “怎么了磁椒?”我有些...
    開封第一講書人閱讀 165,282評論 0 356
  • 文/不壞的土叔 我叫張陵堤瘤,是天一觀的道長。 經(jīng)常有香客問我浆熔,道長本辐,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,842評論 1 295
  • 正文 為了忘掉前任医增,我火速辦了婚禮慎皱,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘叶骨。我一直安慰自己茫多,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,857評論 6 392
  • 文/花漫 我一把揭開白布忽刽。 她就那樣靜靜地躺著天揖,像睡著了一般。 火紅的嫁衣襯著肌膚如雪跪帝。 梳的紋絲不亂的頭發(fā)上今膊,一...
    開封第一講書人閱讀 51,679評論 1 305
  • 那天,我揣著相機與錄音伞剑,去河邊找鬼斑唬。 笑死,一個胖子當(dāng)著我的面吹牛黎泣,可吹牛的內(nèi)容都是我干的恕刘。 我是一名探鬼主播,決...
    沈念sama閱讀 40,406評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼聘裁,長吁一口氣:“原來是場噩夢啊……” “哼雪营!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起衡便,我...
    開封第一講書人閱讀 39,311評論 0 276
  • 序言:老撾萬榮一對情侶失蹤献起,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后镣陕,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體谴餐,經(jīng)...
    沈念sama閱讀 45,767評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年呆抑,在試婚紗的時候發(fā)現(xiàn)自己被綠了岂嗓。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,090評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡鹊碍,死狀恐怖厌殉,靈堂內(nèi)的尸體忽然破棺而出食绿,到底是詐尸還是另有隱情,我是刑警寧澤公罕,帶...
    沈念sama閱讀 35,785評論 5 346
  • 正文 年R本政府宣布器紧,位于F島的核電站,受9級特大地震影響楼眷,放射性物質(zhì)發(fā)生泄漏铲汪。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,420評論 3 331
  • 文/蒙蒙 一罐柳、第九天 我趴在偏房一處隱蔽的房頂上張望掌腰。 院中可真熱鬧,春花似錦张吉、人聲如沸齿梁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽士飒。三九已至,卻和暖如春蔗崎,著一層夾襖步出監(jiān)牢的瞬間酵幕,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評論 1 271
  • 我被黑心中介騙來泰國打工缓苛, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留芳撒,地道東北人。 一個月前我還...
    沈念sama閱讀 48,298評論 3 372
  • 正文 我出身青樓未桥,卻偏偏與公主長得像笔刹,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子冬耿,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,033評論 2 355

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