Android硬件加速以及WebView的onPause,onResume,OnDestroy

简介: MainActivity如下: package cn.testwebview;import java.util.Timer;import java.

MainActivity如下:

package cn.testwebview;
import java.util.Timer;
import java.util.TimerTask;
import android.os.Bundle;
import android.view.View;
import android.view.ViewConfiguration;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.webkit.WebSettings.PluginState;
import android.app.Activity;
import android.graphics.Bitmap;
/**
 * Demo描述:
 * 1 硬件加速的实现
 * 2 WebView的暂停/回复、销毁
 * 
 * 参考资料:
 * 1 http://stackoverflow.com/questions/5267639/how-to-safely-turn-webview-zooming-on-and-off-as-needed
 * 2 http://qianxuechao.blog.163.com/blog/static/91813499201292541451358/
 *   Thank you very much
 */
public class MainActivity extends Activity {
    private WebView mWebView;
    private boolean isOnPause = false;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		hardwareAccelerate();
		initWebView();
	}
	
	//硬件加速
	private void hardwareAccelerate(){
		if (this.getPhoneSDKInt() >= 14) {
			getWindow().setFlags(0x1000000, 0x1000000);
		}
	}
	
	//设置WebView
	private void initWebView() {
		mWebView = (WebView) findViewById(R.id.webView);
		mWebView.setVerticalScrollBarEnabled(false);
		mWebView.setHorizontalScrollBarEnabled(false);
		mWebView.getSettings().setSupportZoom(true);
		mWebView.getSettings().setBuiltInZoomControls(true);
		mWebView.getSettings().setJavaScriptEnabled(true);
		
		mWebView.getSettings().setDomStorageEnabled(true);
		mWebView.getSettings().setPluginsEnabled(true);
		mWebView.requestFocus();
		
		//以下两句和硬件加速有关
		mWebView.getSettings().setPluginState(PluginState.ON);
		mWebView.getSettings().setAllowFileAccess(true); 
		
		mWebView.getSettings().setUseWideViewPort(true);
		mWebView.getSettings().setLoadWithOverviewMode(true);
		mWebView.getSettings().setCacheMode(WebSettings.LOAD_NO_CACHE);
		
		mWebView.loadUrl("http://www.cdmetro.cn/");
		mWebView.setWebViewClient(new TestWebViewClient());
	}
    
	
	/**
	 * 当Activity执行onPause()时让WebView执行pause
	 */
	@Override
	protected void onPause() {
		super.onPause();
		try {
			if (mWebView != null) {
				mWebView.getClass().getMethod("onPause").invoke(mWebView, (Object[]) null);
				isOnPause = true;
			}

		} catch (Exception e) {
			e.printStackTrace();
		}
	}
	
	/**
	 * 当Activity执行onResume()时让WebView执行resume
	 */
	@Override
	protected void onResume() {
		super.onResume();
		try {
			if (isOnPause) {
				if (mWebView != null) {
					mWebView.getClass().getMethod("onResume").invoke(mWebView, (Object[]) null);
				}
				isOnPause = false;
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
	
	/**
	 * 该处的处理尤为重要:
	 * 应该在内置缩放控件消失以后,再执行mWebView.destroy()
	 * 否则报错WindowLeaked
	 */
	@Override
	protected void onDestroy() {
		super.onDestroy();
		if (mWebView != null) {
			mWebView.getSettings().setBuiltInZoomControls(true);
			mWebView.setVisibility(View.GONE);
			long delayTime = ViewConfiguration.getZoomControlsTimeout();
			new Timer().schedule(new TimerTask() {
				@Override
				public void run() {
					mWebView.destroy();
					mWebView = null;
				}
			}, delayTime);

		}
		isOnPause = false;
	}
	
	
	private class TestWebViewClient extends WebViewClient{
		@Override
		public void onPageStarted(WebView view, String url, Bitmap favicon) {
			super.onPageStarted(view, url, favicon);
		}
		@Override
		public boolean shouldOverrideUrlLoading(WebView view, String url) {
			view.loadUrl(url);
			return true;
		}
		@Override
		public void onPageFinished(WebView view, String url) {
			super.onPageFinished(view, url);
			
		}
		@Override
		public void onReceivedError(WebView view, int errorCode,String description, String failingUrl) {
			super.onReceivedError(view, errorCode, description, failingUrl);
		}
	}
	
    public int getPhoneSDKInt() {
		int version = 0;
		try {
			version = Integer.valueOf(android.os.Build.VERSION.SDK);
		} catch (NumberFormatException e) {
			e.printStackTrace();
		}
		return version;
	}
}


main.xml如下:

<RelativeLayout 
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
  >

    <WebView
        android:id="@+id/webView"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:text="@string/hello_world"
        android:layout_centerInParent="true"
    />

</RelativeLayout>

 

相关文章
|
API Android开发 数据安全/隐私保护
解决android webview 加载http url 失败 net::ERR_CLEARTEXT_NOT_PERMITTED 错误
解决android webview 加载http url 失败 net::ERR_CLEARTEXT_NOT_PERMITTED 错误
935 0
|
19天前
|
程序员 开发工具 Android开发
Android|WebView 禁止长按,限制非白名单域名的跳转层级
如何限制 WebView 仅域名白名单网址能随意跳转,并禁用长按选择文字。
28 2
|
5月前
|
安全 JavaScript 前端开发
kotlin开发安卓app,JetPack Compose框架,给webview新增一个按钮,点击刷新网页
在Kotlin中开发Android应用,使用Jetpack Compose框架时,可以通过添加一个按钮到TopAppBar来实现WebView页面的刷新功能。按钮位于右上角,点击后调用`webViewState?.reload()`来刷新网页内容。以下是代码摘要:
|
5月前
|
JavaScript 前端开发 Android开发
kotlin安卓在Jetpack Compose 框架下使用webview , 网页中的JavaScript代码如何与native交互
在Jetpack Compose中使用Kotlin创建Webview组件,设置JavaScript交互:`@Composable`函数`ComposableWebView`加载网页并启用JavaScript。通过`addJavascriptInterface`添加`WebAppInterface`类,允许JavaScript调用Android方法如播放音频。当页面加载完成时,执行`onWebViewReady`回调。
|
4月前
|
Web App开发 JavaScript 前端开发
Android端使用WebView注入一段js代码实现js调用android
Android端使用WebView注入一段js代码实现js调用android
105 0
|
5月前
|
Web App开发 移动开发 前端开发
52. 【Android教程】网页视图:WebView
52. 【Android教程】网页视图:WebView
88 1
|
5月前
|
安全 网络安全 API
kotlin安卓开发JetPack Compose 如何使用webview 打开网页时给webview注入cookie
在Jetpack Compose中使用WebView需借助AndroidView。要注入Cookie,首先在`build.gradle`添加WebView依赖,如`androidx.webkit:webkit:1.4.0`。接着创建自定义`ComposableWebView`,通过`CookieManager`设置接受第三方Cookie并注入Cookie字符串。最后在Compose界面使用这个自定义组件加载URL。注意Android 9及以上版本可能需要在网络安全配置中允许第三方Cookie。
|
6月前
|
XML Android开发 数据格式
安卓和webview交互
安卓和webview交互
59 0
|
6月前
|
XML Android开发 数据格式
安卓和webview交互
安卓和webview交互
101 1
|
小程序 Android开发 iOS开发
在钉钉小程序中安卓无法打开webview
在钉钉小程序中安卓无法打开webview
201 1