總體架構:javascript
InventionActivity:實現UI的實例化,基本的按鈕Activity之間跳轉java
GameActivity:實現UI的實例化,Webview的基本使用git
MyProgressDialog:UI進度對話框屬性類github
依賴庫類:web
SystemBarTintManager + Config = 實現兼容版本沉浸狀態欄瀏覽器
----------------------我是每天酷濤---------------------------緩存
Webview 運行加載 H5小遊戲架構
Webview基本屬性dom
WebSettings :ide
WebSettings setting = webView.getSettings();
setting.setUseWideViewPort(true); //將圖片調整至適合Webview大小
settings.setSupportZoom(true);//支持縮放
settings.setLoadWithOverviewMode(true);//縮放至屏幕大小
settings.setLoadsImagesAutomatically(true);//支持自動加載圖片
settings.setDomStorageEnabled(true); //開啓dom storage AOI功能
//進行緩存
settings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);//設置緩存模式
settings.setAppCacheEnabled(true);//加載緩存
String path = Environment.getExternalStorageDirectory().getAbsolutePath()+"/gamecache";
Log.d("GameActivity", path);
settings.setAppCachePath(path); //設計緩存路徑
//加載JS
settings.setJavaScriptEnabled(true);//支持js
webView.loadUrl(msString);//加載網頁
//禁止第三方瀏覽器打開
//覆蓋瀏覽器
webView.setWebViewClient(new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
webView.loadUrl(msString);
//返回值是true的時候控制去WebView打開,爲false調用系統瀏覽器或第三方瀏覽器
view.setWebChromeClient(new WebChromeClientProgress());
return true;
}
@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
myProgressDialog.show();
webView.setVisibility(View.GONE);
super.onPageStarted(view, url, favicon);
}
@Override
public void onPageFinished(WebView view, String url) {
if (myProgressDialog.isShowing()){
myProgressDialog.dismiss();
webView.setVisibility(View.VISIBLE);
}
}
@Override
public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {
super.onReceivedError(view, errorCode, description, failingUrl);
view.stopLoading();
view.clearView();
String data="遊戲暫時出錯了,正在修復喲。";
view.loadUrl("javascript:document.body.innerHTML=\"" + data + "\"");
}
});
}
private class WebChromeClientProgress extends WebChromeClient{
@Override
public void onProgressChanged(WebView view, int newProgress) {
myProgressDialog.setProgress(newProgress);
if(myProgressDialog !=null){
if(newProgress >= 100){
myProgressDialog.dismiss();
Log.d("GameActivity","100");
}
}
super.onProgressChanged(view, newProgress);
}
}
//返回上一個加載的網頁
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if (keyCode == KeyEvent.KEYCODE_BACK && webView.canGoBack()){
//返回鍵退回
webView.goBack();
return true;
}
return super.onKeyDown(keyCode, event);
}
//借用了網上h5小遊戲的資源
附上源碼地址:https://github.com/TIANTIANKUTAO/Invention_SimpleHeart