基本信息
源码名称:android 与 JS 交互 例子源码下载
源码大小:0.08M
文件格式:.rar
开发语言:Java
更新时间:2013-09-10
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 2 元×
微信扫码支付:2 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
package com.renren.js;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.os.Bundle;
import android.os.Handler;
import android.util.Log;
import android.webkit.JsPromptResult;
import android.webkit.JsResult;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.TextView;
public class PhoneTest extends Activity {
private static final String LOG_TAG = "WebViewDemo";
private WebView mWebView;
private TextView mReusultText ;
private Handler mHandler = new Handler();
@Override
public void onCreate(Bundle icicle) {
super.onCreate(icicle);
setContentView(R.layout.main);
//获得浏览器组件
//WebView就是一个简单的浏览器
//android浏览器源码存在于LINUX/android/package/apps/Browser中
//里面的所有操作都是围绕WebView来展开的
mWebView = (WebView) findViewById(R.id.webview);
mReusultText = (TextView) findViewById(R.id.resultText);
//WebSettings 几乎浏览器的所有设置都在该类中进行
WebSettings webSettings = mWebView.getSettings();
webSettings.setSavePassword(false);
webSettings.setSaveFormData(false);
webSettings.setJavaScriptEnabled(true);
webSettings.setAllowFileAccess(true); //设置允许访问文件数据
webSettings.setSupportZoom(false);
mWebView.setWebViewClient(new DemoWebViewClient());
mWebView.setWebChromeClient(new MyWebChromeClient());
/*
* DemoJavaScriptInterface类为js调用android服务器端提供接口
* android 作为DemoJavaScriptInterface类的客户端接口被js调用
* 调用的具体方法在DemoJavaScriptInterface中定义:
* 例如该实例中的clickOnAndroid
*/
mWebView.addJavascriptInterface(new DemoJavaScriptInterface(),"demo");
mWebView.loadUrl("file:///android_asset/index.html"); //对应当前project的asserts目录
//也可以写file:///sdcard/index.html
// mWebView.loadUrl("file:///android_asset/index2.html");
}
class DemoWebViewClient extends WebViewClient {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
}
final class DemoJavaScriptInterface {
DemoJavaScriptInterface() {
}
/**
* 该方法被浏览器端调用
*/
public void clickOnAndroid() {
mHandler.post(new Runnable() {
public void run() {
//调用js中的wave()方法
mWebView.loadUrl("javascript:wave()");
}
});
}
}
/**
* 继承WebChromeClient类
* 在这个类的3个方法中,分别使用Android的内置控件重写了Js中对应的对话框,就是说对js中的对话框做处理了,就是重写了。
*
*/
final class MyWebChromeClient extends WebChromeClient {
/**
* 处理alert弹出框
*/
@Override
public boolean onJsAlert(WebView view,String url,
String message,final JsResult result) {
Log.d(LOG_TAG,"onJsAlert:" message);
// mReusultText.setText("Alert:" message);
//对alert的简单封装
// new AlertDialog.Builder(PhoneTest.this)
// .setTitle("Alert")
// .setMessage(message)
// .setPositiveButton("OK",
// new DialogInterface.OnClickListener() {
// @Override
// public void onClick(DialogInterface arg0, int arg1) {
// // result.confirm();
// // MyWebView.this.finish();
//
// }
// })
// .setCancelable(true)
// .create()
// .show();
result.confirm(); //不加上面的代码也能出框,为嘛呢?
return true;
// return super.onJsConfirm(view,url,message, result);
}
/**
* 处理confirm弹出框
*/
@Override
public boolean onJsConfirm(WebView view, String url, String message,
JsResult result) {
Log.d(LOG_TAG, "onJsConfirm:" message);
mReusultText.setText("Confirm:" message);
//对confirm的简单封装
new AlertDialog.Builder(PhoneTest.this).
setTitle("Confirm")
.setMessage(message)
.setPositiveButton("OK",
new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface arg0, int arg1) {
}
})
.create()
.show();
result.confirm();
return true;
//如果采用下面的代码会另外再弹出个消息框,目前不知道原理
// 因为调用了父类的构造函数了。。。
//return super.onJsConfirm(view, url, message, result);
}
/**
* 处理prompt弹出框
*/
@Override
public boolean onJsPrompt(WebView view, String url, String message,
String defaultValue, JsPromptResult result) {
Log.d(LOG_TAG,"onJsPrompt:" message);
mReusultText.setText("Prompt input is :" message);
result.confirm();
return super.onJsPrompt(view, url, message, message, result);
}
}
}