`
Aina_hk55HK
  • 浏览: 388201 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
文章分类
社区版块
存档分类
最新评论

Android WebView的使用

阅读更多
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
	android:orientation="vertical" android:layout_width="fill_parent"
	android:layout_height="fill_parent">
	<TextView android:layout_width="fill_parent"
		android:layout_height="wrap_content" android:text="@string/hello" />
	<EditText android:hint="请输入URL" android:id="@+id/EditText01"
		android:layout_width="fill_parent" android:layout_height="wrap_content"></EditText>
	<Button android:text="OK" android:id="@+id/Button01"
		android:layout_width="fill_parent" android:layout_height="wrap_content"></Button>
	<WebView android:id="@+id/WebView" android:layout_width="fill_parent"
		android:layout_height="wrap_content"></WebView>
</LinearLayout>



package com.Aina.Android;

import android.app.Activity;
import android.app.AlertDialog;
import android.app.AlertDialog.Builder;
import android.content.DialogInterface;
import android.os.Bundle;
import android.view.KeyEvent;
import android.view.LayoutInflater;
import android.view.View;
import android.view.Window;
import android.webkit.JsPromptResult;
import android.webkit.JsResult;
import android.webkit.URLUtil;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;

public class Test extends Activity {
    /** Called when the activity is first created. */
	private EditText et = null;
	private Button btn = null;
	private WebView wv = null;
	private WebSettings ws = null;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        et = (EditText) this.findViewById(R.id.EditText01);
        btn = (Button) this.findViewById(R.id.Button01);
        wv = (WebView) this.findViewById(R.id.WebView);
        ws = wv.getSettings();
        ws.setAllowFileAccess(true);//设置允许访问文件数据
        ws.setJavaScriptEnabled(true);//设置支持javascript脚本
        ws.setBuiltInZoomControls(true);//设置支持缩放
        wv.setWebViewClient(new WebViewClient(){
        	public boolean shouldOverrideUrlLoading(WebView view,String url){
        		//当有新连接时,使用当前的 WebView
        		view.loadUrl(url);
        		return true;
        	}
        });
        wv.setWebChromeClient(new WebChromeClient(){
        	public boolean onJsAlert(WebView view,String url,String message,final JsResult result){
        		//构建一个Builder来显示网页中的alert对话框
        		Builder builder = new Builder(Test.this);
        		builder.setTitle("提示对话框");
        		builder.setMessage(message);
        		builder.setPositiveButton(android.R.string.ok, new AlertDialog.OnClickListener(){

					@Override
					public void onClick(DialogInterface dialog, int which) {
						// TODO Auto-generated method stub
						result.confirm();
					}
        			
        		});
        		builder.setCancelable(false);
        		builder.create();
        		builder.show();
        		return true;
        	}
        	public boolean onJsConfirm(WebView view,String url,String message,final JsResult result){
        		Builder builder = new Builder(Test.this);
        		builder.setTitle("带选择的对话框");
        		builder.setMessage(message);
        		builder.setPositiveButton(android.R.string.ok, new AlertDialog.OnClickListener(){

					@Override
					public void onClick(DialogInterface dialog, int which) {
						// TODO Auto-generated method stub
						result.confirm();
					}
        			
        		});
        		builder.setNeutralButton(android.R.string.cancel, new AlertDialog.OnClickListener(){

					@Override
					public void onClick(DialogInterface dialog, int which) {
						// TODO Auto-generated method stub
						result.cancel();
					}
					
        		});
        		builder.setCancelable(false);
        		builder.create();
        		builder.show();
        		return true;
        	}
        	public boolean onJsPrompt(WebView view,String url,String message,String defaultValue,final JsPromptResult result){
        		LayoutInflater inflater = LayoutInflater.from(Test.this);
        		final View v = inflater.inflate(R.layout.prom_dialog, null);
        		//设置 TextView对应网页中的提示信息
        		((TextView)v.findViewById(R.id.TextView_PROM)).setText(message);
        		//设置EditText对应网页中的输入框
        		((EditText)v.findViewById(R.id.EditText_PROM)).setText(defaultValue);
        		Builder builder = new Builder(Test.this);
        		builder.setTitle("带输入的对话框 ");
        		builder.setView(v);
        		builder.setPositiveButton(android.R.string.ok, new AlertDialog.OnClickListener(){

					@Override
					public void onClick(DialogInterface dialog, int which) {
						// TODO Auto-generated method stub
						String value = ((EditText)v.findViewById(R.id.EditText_PROM)).getText().toString();
						result.confirm(value);
					}
        			
        		});
        		builder.setNegativeButton(android.R.string.cancel, new AlertDialog.OnClickListener(){

					@Override
					public void onClick(DialogInterface dialog, int which) {
						// TODO Auto-generated method stub
						result.cancel();
					}
        			
        		});
        		builder.setOnCancelListener(new DialogInterface.OnCancelListener(){

					@Override
					public void onCancel(DialogInterface dialog) {
						// TODO Auto-generated method stub
						result.cancel();
					}
        			
        		});
        		builder.create();
        		builder.show();
        		return true;
        	}
        	//设置网页加载的进度条
        	public void onProgressChanged(WebView view,int newProgress){
        		Test.this.getWindow().setFeatureInt(Window.FEATURE_PROGRESS, newProgress*100);
        		super.onProgressChanged(view, newProgress);
        	}
        	//设置应用程序的标题
        	public void onReceivedTitle(WebView view,String title){
        		Test.this.setTitle(title);
        		super.onReceivedTitle(view, title);
        	}
        });
        btn.setOnClickListener(new Button.OnClickListener(){

			@Override
			public void onClick(View v) {
				// TODO Auto-generated method stub
				String url = et.getText().toString();
				//判断输入的内容是不是网址
				if(URLUtil.isNetworkUrl(url)){
					wv.loadUrl(url);
				}else{
					et.setHint("输入的网址不合法,请重新输入");
//					et.setText("输入的网址不合法,请重新输入");
				}
			}
        	
        });
    }
	@Override
	public boolean onKeyDown(int keyCode, KeyEvent event) {
		if(keyCode==KeyEvent.KEYCODE_BACK && wv.canGoBack()){
			wv.goBack();//返回前一个页面
			return true;
		}
		return super.onKeyDown(keyCode, event);
	}
    
}


<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:gravity="center_horizontal"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    >
    <TextView 
	android:id="@+id/TextView_PROM"
    	android:layout_width="fill_parent"
	android:layout_height="wrap_content"/>
    <EditText 
	android:id="@+id/EditText_PROM"
	android:layout_width="fill_parent"
	android:layout_height="wrap_content"
	android:selectAllOnFocus="true"
	android:scrollHorizontally="true"/>
</LinearLayout>



<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
	package="com.Aina.Android" android:versionCode="1" android:versionName="1.0">
	<application android:icon="@drawable/icon" android:label="@string/app_name">
		<activity android:name=".Test" android:label="@string/app_name">
			<intent-filter>
				<action android:name="android.intent.action.MAIN" />
				<category android:name="android.intent.category.LAUNCHER" />
			</intent-filter>
		</activity>

	</application>
	<uses-permission android:name="android.permission.INTERNET" />

</manifest> 


<%@ page language="java" contentType="text/html; charset=GBK" pageEncoding="GBK"%>

<html>
  <head>
    <title>index.jsp</title>
<script type="text/JavaScript">   
function s(){
alert("Good Morning!");    
}
function d(){
confirm("Are you ok?")
}
function f(){
prompt("What’s your name?")
}
</script> 
  </head>
  
  <body>
  下面我们演示三种对话框
  <br/><br/>
  <input type="button" value="警告,提醒对话框" onclick="s()">
  <br/><br/>
  <input type="button" value="带选择的对话框" onclick="d()">
  <br/><br/>
  <input type="button" value="要求用户输入的对话框" onclick="f()">
  </body>
</html>

分享到:
评论
8 楼 卡菲牛奶 2012-05-08  
卡菲牛奶 写道
好像忘记写INTERNET权限喽!

哦,写在后面拉,没看见,哈哈
7 楼 卡菲牛奶 2012-05-08  
哦,写在后面啦,没看见,哈哈
6 楼 卡菲牛奶 2012-05-08  
好像忘记写INTERNET权限喽!
5 楼 hecal 2011-11-21  

good
4 楼 jxpath 2011-02-25  
提供的代码不完整啊

R.layout.prom_dialog
R.id.TextView_PROM
R.id.EditText_PROM
3 楼 jxpath 2011-02-25  
@Override
public void onClick(DialogInterface dialog, int which) {
result.confirm();
}
中的@Override需要去除,报错
2 楼 bojianpc 2010-12-14  
很好 很强大  讲的很详细
1 楼 zcbbupt 2010-10-25  
楼主要是能把代码的效果图发几张就更完美了!

相关推荐

    Android WebView 去除标题

    总的来说,去除Android WebView的标题可以通过调整布局、禁用内置工具栏和使用JavaScript操作网页内容等方式实现。同时,JavaScript交互为开发者提供了更多定制化网页体验的可能性。在实际项目中,应根据具体需求...

    Android webview使用方法总结

    Android WebView 使用方法总结 Android WebView 是一个非常强大的控件,允许开发者在 Android 应用程序中嵌入 Web 内容。下面是 Android WebView 使用方法总结的一些重要知识点: 一、WebViewClient 的使用 在 ...

    Android Webview视频播放器

    在Android平台上,Webview是一个非常重要的组件,它允许开发者在原生应用中嵌入网页内容。这个项目"Android Webview视频播放器"是利用Webview来实现HTML5视频播放功能的示例。以下是对这个项目的详细解读: 1. **...

    实例详解Android Webview拦截ajax请求

    Android Webview 拦截 Ajax 请求的详细讲解 Android Webview 提供了页面加载及资源请求的钩子,但是对于 H5 的 Ajax 请求并没有提供干涉的接口。这意味着我们不能在 Webview 中干涉 JavaScript 发起的 HTTP 请求,...

    Android webview调用摄像头扫描二维码

    1. Android Webview的使用与配置,包括加载本地HTML、启用JavaScript。 2. 自定义WebViewClient实现URL拦截,调用原生相机API。 3. 使用ZXing库进行二维码扫描,包括Intent接口的使用和AndroidManifest配置。 4. ...

    Android webview加载网页.zip

    这个“Android webview加载网页.zip”文件可能包含了一个示例项目或者教程,帮助开发者理解如何在Android应用中有效地使用WebView。 WebView的使用涉及到以下几个关键知识点: 1. **WebView组件引入**:在...

    Android Webview滑动监听

    在Android开发中,Webview是一个非常重要的组件,它允许开发者在原生应用中嵌入网页内容,实现网页与原生应用的交互。本篇将详细讲解如何在Android Webview中实现滑动监听以及图片的放大缩小功能。 首先,我们要...

    Android webview 内存泄露的解决方法

    Android webview 内存泄露的解决方法 最近在activity嵌套webview显示大量图文发现APP内存一直在涨,没法释放内存,查了很多资料,大概是webview的一个BUG,引用了activity导致内存泄漏,所以就尝试传递...

    android webview 版本69.0

    总的来说,这个“android webview 版本69.0”是AOSP的一个组件,基于Chromium,适合那些希望在没有Google服务的情况下使用WebView的应用开发者。开发者在使用时应考虑其更新策略和安全性,同时充分利用其提供的API来...

    android webview播放网页视频

    在Android开发中,Webview是一个非常重要的组件,它允许我们加载和展示网页内容。当涉及到在Webview中播放网页视频时,这个问题可能会变得稍微复杂,因为Android原生的Webview并不总是支持所有现代HTML5视频特性。...

    通过css注入实现android webview的夜间模式

    然后,在Android应用中,我们需要在Webview加载网页之前或之后,使用`evaluateJavascript()`方法注入这段CSS代码。以下是一个简单的示例: ```java String nightModeCss = "document.head.innerHTML += '&lt;style&gt;...

    Android WebView播放视频(包括全屏播放)

    在Android应用开发中,WebView是一个非常重要的组件,它允许开发者在应用程序内嵌入网页内容,实现类似浏览器的功能。本文将详细讲解如何在Android的WebView中播放视频,包括全屏播放的实现方法。以下是对该主题的...

    Android WebView 缓存详解

    Android WebView 缓存详解 一. 两种缓存类型: 页面缓存:加载一个网页时的html、JS、CSS等页面或者资源数据,这些缓存资源是由于浏览器 的行为而产生,开发者只能通过配置HTTP响应头影响浏览器的行为才能间接地...

    Android WebView H5调用拍照

    在Android应用开发中,WebView是一个非常重要的组件,它允许开发者在原生应用中展示网页内容。混合开发(Hybrid Development)结合了Web技术与原生应用的优势,使得开发者可以使用HTML5、CSS3和JavaScript来构建应用...

    Android WebView另类实现 自由复制进入选择文字模式

    在Android开发中,WebView是一个非常重要的组件,它允许我们在原生应用中展示网页内容,提供了一种混合式应用开发的解决方案。本篇文章将深入探讨如何在Android WebView中实现自由复制和选择文字的功能,这对于增强...

    动态设置android webview字体大小DEMO

    为了确保安全性,使用`addJavascriptInterface`时应启用`@JavascriptInterface`注解,这会禁用WebView中的跨域脚本,防止恶意JavaScript代码访问Android应用的内部数据。 在`WebViewTest1`这个项目中,应该包含了...

    Android WebView加载网页以及本地图片缓存问题

    在Android开发中,WebView是一个非常重要的组件,它允许我们在应用程序内部加载和显示网页内容,而无需离开应用。WebView不仅能够加载远程HTTP/HTTPS网址,还能处理本地HTML、CSS和JavaScript资源,极大地增强了应用...

    Android-AndroidWebView加载PDF文件实现

    Android WebView 加载 PDF 文件实现。其原理就是在 app 本地搭建一个 website ,然后利用 WebView 加载这个站点,站点去实现加载显示 PDF 的目的,站点其原理也是采用 js 框架去实现的。

Global site tag (gtag.js) - Google Analytics