WebView使用

原创 2015年11月18日 19:51:27

WebView

android 的一种控件,可以将html文件转换成webview显示到手机上

请求网络需要获得权限 <uses-permission android:name="android.permission.INTERNET" />


package com.scxh.android.ui.wedget;

import android.annotation.SuppressLint;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.webkit.JavascriptInterface;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.widget.Toast;

import com.scxh.android.frame.R;

@SuppressLint("JavascriptInterface")
public class MyWebView extends Activity {
	WebView mWebView;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.mywebactivity_layout);
		mWebView = (WebView) findViewById(R.id.my_web);

		mWebView.loadUrl("http://192.168.1.111:8080/marry.html");// 写好的html加载到webview上
		WebSettings setting = mWebView.getSettings();
		setting.setJavaScriptEnabled(true);// 设置script可用
		<span style="color:#cc33cc;"><strong>mWebView.addJavascriptInterface(new MyWebClick(), "htmlListener")</strong>;//htmlListener 交互类名,
</span>
	}

	/*
	 * 交互类,处理html中的监听事件
	 */
	public class MyWebClick {
		@JavascriptInterface//如果点击未响应,代码又没错,记得在方法上加上这句话
		public void playMusics() {//要做的事
			Log.v("WebClick", "playMusic....");
			Toast.makeText(MyWebView.this, "welcome~", Toast.LENGTH_SHORT)
					.show();
		}
	}
}


在html中 在需要响应的标间上通过onclick属性,写一个方法名,在

<script>

function 方法名{

window.交互类名.方法

}

</script>

下面是html 文件

<pre name="code" class="java"><html>
	<head>
	<meta http-equiv="content-type" content ="text/type charset=UTF-8"/>
	<link rel="stylesheet"  href="m.css" type="text/css"/>
	
	
		<script>
			function palymusic(){
				alert("你好,我是一张喇叭图片");/*在网页中点击弹出的对话框*/
					<span style="color:#cc33cc;"><strong>window.htmlListener.playMusics();/*window.交互类名.方法*/</strong></span>
				}
		</script>
	</head>

	<body bgcolor="#680011">
		<div align="center" width="320px" >
			<div class="top">
				<img class="bg" src="./img/index_top_bg.png"/>
				<img class="ring"  src="./img/index_microphone.png" onclick="palymusic()"/>
				<div class="text">
					<p>离我们结婚</p>
					<p class="text_below">还有<span class="text_num">36</span>天</p>
				</div>				
			</div>
			<div class="pic">
				<img width="150px" height="130px"  src="./img/index_yaoqinghan.png" />
				<img width="150px"  height="130px" src="./img/index_hunsha.png" />
				
				<img class ="pad" width="150px" height="100px"  src="./img/index_yaoyiyao.png" />
				<img  class ="pad" width="150px" height="100px" src="./img/index_zhufuqiang.png" />
			</div>
		
			<div class="foot">
				<a href="www.baidu.com">婚礼承办方:成都幸福公社婚庆公司<img src="./img/redRightarrow.png"/></a>
				
			</div>
		
		</div>
	</body>

</html>




缓存处理

package com.scxh.android1503.ui.webview;

import java.io.File;

import android.annotation.SuppressLint;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.Window;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.Toast;

import com.scxh.android1503.R;
import com.scxh.android1503.ui.adapter.gridview.GridViewActivity;
import com.scxh.android1503.util.Logs;
/**
 * 当我们加载Html时候,会在我们data/应用package下生成database与cache两个文件夹:
我们请求的Url记录是保存在webviewCache.db里,而url的内容是保存在webviewCache文件夹下.
WebView中存在着两种缓存:网页数据缓存(存储打开过的页面及资源)、H5缓存(即AppCache)。


一、网页缓存

1、缓存构成
/data/data/package_name/cache/
/data/data/package_name/database/webview.db
/data/data/package_name/database/webviewCache.db


 

综合可以得知 webview 会将我们浏览过的网页url已经网页文件(css、图片、js等)保存到数据库表中



缓存模式(5种)
LOAD_CACHE_ONLY:  不使用网络,只读取本地缓存数据
LOAD_DEFAULT:  根据cache-control决定是否从网络上取数据。
LOAD_CACHE_NORMAL: API level 17中已经废弃, 从API level 11开始作用同LOAD_DEFAULT模式
LOAD_NO_CACHE: 不使用缓存,只从网络获取数据.
LOAD_CACHE_ELSE_NETWORK,只要本地有,无论是否过期,或者no-cache,都使用缓存中的数据。
如:www.taobao.com的cache-control为no-cache,在模式LOAD_DEFAULT下,无论如何都会从网络上取数据,如果没有网络,就会出现错误页面;在LOAD_CACHE_ELSE_NETWORK模式下,无论是否有网络,只要本地有缓存,都使用缓存。本地没有缓存时才从网络上获取。
www.360.com.cn的cache-control为max-age=60,在两种模式下都使用本地缓存数据。


总结:根据以上两种模式,建议缓存策略为,判断是否有网络,有的话,使用LOAD_DEFAULT,无网络时,使用LOAD_CACHE_ELSE_NETWORK。
 *
 */
public class MyWebViewActivity extends Activity {
	private static final String APP_CACAHE_DIRNAME = "/webcache";
	private WebView mWebView;
	private String url = "http://192.168.1.156:8080/html/index.html";
//	private String url = "http://m.dianhua.cn/detail/31ccb426119d3c9eaa794df686c58636121d38bc?apikey=jFaWGVHdFVhekZYWTBWV1ZHSkZOVlJWY&app=com.yulore.yellowsdk_ios&uid=355136051337627";
	@SuppressLint("JavascriptInterface")
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		requestWindowFeature(Window.FEATURE_NO_TITLE);
		setContentView(R.layout.webview_main_layout);

		mWebView = (WebView) findViewById(R.id.my_webview);

		mWebView.loadUrl(url);

		/** 第一步设置JavaScript可用 */
		WebSettings setting = mWebView.getSettings();
		setting.setJavaScriptEnabled(true);
		setting.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK); // 设置 缓存模式
		/** 第三步 */
		mWebView.addJavascriptInterface(new WebViewJavaScript(),
				"musicServiceInterfaceName");
		
		/**使用加载URL在webView内部跳转*/
		mWebView.setWebViewClient(new WebViewClient() {

			@Override
			public boolean shouldOverrideUrlLoading(WebView webview, String url) {
				webview.loadUrl(url);

				return true;
			}
		});
	}

	/**
	 * 第二步 定义交互接类名"musicServiceInterfaceName"和方法
	 * 交互接类名"musicServiceInterfaceName"和方法名"playMusic"在html页面javaScript代码中引用 例如:
	 * window.musicServiceInterfaceName.playMusic
	 */
	class WebViewJavaScript {
		public void playMusic() {
			// 播放音乐
			Toast.makeText(MyWebViewActivity.this, "html代码调用原生应用代码方法",
					Toast.LENGTH_SHORT).show();
		}

		public void startGridViewHttp() {
			startActivity(new Intent(MyWebViewActivity.this,
					GridViewActivity.class));
		}
	}

	@Override
	protected void onDestroy() {
		super.onDestroy();
//		clearWebViewCache();
	}

	/**
	 * 清除WebView缓存
	 */
	public void clearWebViewCache() {

		// 清理Webview缓存数据库
		try {
			deleteDatabase("webview.db");
			deleteDatabase("webviewCache.db");
		} catch (Exception e) {
			e.printStackTrace();
		}

		// WebView 缓存文件
		File appCacheDir = new File(getFilesDir().getAbsolutePath()+ APP_CACAHE_DIRNAME);
		Logs.e("appCacheDir path=" + appCacheDir.getAbsolutePath());

		File webviewCacheDir = new File(getCacheDir().getAbsolutePath()+ "/webviewCache");
		Logs.e("webviewCacheDir path=" + webviewCacheDir.getAbsolutePath());

		// 删除webview 缓存目录
		if (webviewCacheDir.exists()) {
			deleteFile(webviewCacheDir);
		}
		// 删除webview 缓存 缓存目录
		if (appCacheDir.exists()) {
			deleteFile(appCacheDir);
		}
	}

	/**
	 * 递归删除 文件/文件夹
	 * 
	 * @param file
	 */
	public void deleteFile(File file) {

		Logs.i("delete file path=" + file.getAbsolutePath());

		if (file.exists()) {
			if (file.isFile()) {
				file.delete();
			} else if (file.isDirectory()) {
				File files[] = file.listFiles();
				for (int i = 0; i < files.length; i++) {
					deleteFile(files[i]);
				}
			}
			file.delete();
		} else {
			Logs.e("delete file no exists " + file.getAbsolutePath());
		}
	}
}





版权声明:本文为博主原创文章,未经博主允许不得转载。

Android开发使用WebView实战技巧

前段时间做项目的时候,在项目中用了WebView组件,遇到了一些问题,所以特地找来了一些资料,学习怎么解决,现在将学习的内容整理成一篇博客记录在这里,方便以后再次遇到时可以快速查看并且解决问题。我们知...
  • lee_tianya
  • lee_tianya
  • 2015年04月02日 09:58
  • 3725

安卓:WebView简单使用

如图: 注意:加网络访问权限 逻辑代码文件: package com.example.day19_webview; import android.app.Activity;...
  • my_worldlet
  • my_worldlet
  • 2015年09月23日 20:06
  • 767

WebView基本用法

本系列文章讨论WebView的各种用法以及使用技巧
  • AllenWells
  • AllenWells
  • 2016年07月29日 09:35
  • 16246

WebView的用法详解

1、布局 2、WebView加载网页
  • jiangtea
  • jiangtea
  • 2016年11月28日 22:17
  • 963

如何在webview中设置自定义字体

In your assets/fonts folder, place the desired OTF or TTF font (here MyFont.otf) Create a HTML file...
  • heiniu426
  • heiniu426
  • 2015年09月28日 15:46
  • 844

Android WebView 缓存机制和模式详解

当我们加载Html时候,会在我们data/应用package下生成database与cache两个文件夹: 我们请求的Url记录是保存在webviewCache.db里,而url的内容是保存在webv...
  • zhangcanyan
  • zhangcanyan
  • 2016年06月16日 02:10
  • 5549

Android的WebView完全使用手册(前篇)

笔者叨叨叨..最近状态总是不对,有心无力的晃着美好的时光,明知道自己很菜但是居然不知道从哪里开始让自己成长。前辈告诉我去研究动画,自定义view,那就慢慢来吧,以后会奉上我的学习心得的。 今天就把最...
  • qq_33923079
  • qq_33923079
  • 2016年11月21日 18:39
  • 628

Qt webview 使用

1.在.pro文件中添加 QT += webkitwidgets QT += network 这里.h和.cpp都是c++类  在.h文件中添加头文件 #include #i...
  • cbacq
  • cbacq
  • 2016年01月13日 17:33
  • 939

(iOS开发)webView的使用与注意事项

注意事项: 1、webView上面添加tap等手势的时候必须添加:(web view手势) //必须实现 否则无法触发webView的点击事件 - (BOOL)gestureRecognizer:(...
  • wf990051004
  • wf990051004
  • 2016年09月20日 14:17
  • 1066

WebView使用解析(一)之基本用法

WebView基本用法加载在线URLvoid loadUrl(String url)这个函数主要加载url所对应的网页地址,或者用于调用网页中的指定的JS方法(调用js方法的用法,后面会讲),但有一点...
  • huaxun66
  • huaxun66
  • 2017年06月13日 14:55
  • 1013
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:WebView使用
举报原因:
原因补充:

(最多只允许输入30个字)