android webview 获取Geolocation
2015-06-16 15:18
423 查看
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
private WebViewwebView =
null;
private WebSettingswebSettings =
null;
private
void initWeb() {
webView = (WebView)this.findViewById(R.id.webView_load);
webView.getSettings().setJavaScriptEnabled(true);
loadURL(urlStr);
setClient();
webSettings =webView.getSettings();// 网页设置默认属性
webView.setInitialScale(39);// 适应竖屏
webView.setScrollBarStyle(View.SCROLLBARS_INSIDE_OVERLAY);//
去掉底部和右边的滚动条
// webSettings.setRenderPriority(RenderPriority.HIGH);// 提高渲染优先级
webSettings.setJavaScriptEnabled(true);//
设置是否可以交互Javascript
webSettings.setAllowFileAccess(true);// 启用或禁止WebView访问文件数据
webSettings.setLayoutAlgorithm(LayoutAlgorithm.SINGLE_COLUMN);// 设置显示模式
webSettings.setDefaultZoom(ZoomDensity.MEDIUM);//
适应屏幕
// webView.getSettings().setUseWideViewPort(true);// 是否任意比例缩放
webView.getSettings().setLoadWithOverviewMode(true);// 缩放至屏幕的大小
// webView.getSettings().setUseWideViewPort(true);// 是否任意比例缩放
webSettings.setBuiltInZoomControls(false);// 设置是否支持缩放
// webSettings.setSupportZoom(false);// 设置是否支持变焦,仅支持双击缩放
webSettings.setNeedInitialFocus(false);// 设置是否可以访问文件
// webSettings.setBlockNetworkImage(true);// 加载图片放在最后加载渲染
// webSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);//
// 设置缓存模式
webSettings.setCacheMode(webSettings.LOAD_NO_CACHE);//
不使用缓存
webView.addJavascriptInterface(new
Scan2(),"mMap");
// 这里的名称就是在页面window.fxl.testFunction()所取的别名
webView.addJavascriptInterface(new
Scan2(),"phone");
// 这里的名称就是在页面window.fxl.testFunction()所取的别名
//关键setGeolocationEnabled
webView.getSettings().setGeolocationEnabled(true);
}
private
void setClient() {
webView.setWebChromeClient(new WebChromeClient() {
@Override
public
void onGeolocationPermissionsShowPrompt(String origin,
android.webkit.GeolocationPermissions.Callback callback) {
callback.invoke(origin,
true, false);
super.onGeolocationPermissionsShowPrompt(origin, callback);
}
}
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
private WebViewwebView =
null;
private WebSettingswebSettings =
null;
private
void initWeb() {
webView = (WebView)this.findViewById(R.id.webView_load);
webView.getSettings().setJavaScriptEnabled(true);
loadURL(urlStr);
setClient();
webSettings =webView.getSettings();// 网页设置默认属性
webView.setInitialScale(39);// 适应竖屏
webView.setScrollBarStyle(View.SCROLLBARS_INSIDE_OVERLAY);//
去掉底部和右边的滚动条
// webSettings.setRenderPriority(RenderPriority.HIGH);// 提高渲染优先级
webSettings.setJavaScriptEnabled(true);//
设置是否可以交互Javascript
webSettings.setAllowFileAccess(true);// 启用或禁止WebView访问文件数据
webSettings.setLayoutAlgorithm(LayoutAlgorithm.SINGLE_COLUMN);// 设置显示模式
webSettings.setDefaultZoom(ZoomDensity.MEDIUM);//
适应屏幕
// webView.getSettings().setUseWideViewPort(true);// 是否任意比例缩放
webView.getSettings().setLoadWithOverviewMode(true);// 缩放至屏幕的大小
// webView.getSettings().setUseWideViewPort(true);// 是否任意比例缩放
webSettings.setBuiltInZoomControls(false);// 设置是否支持缩放
// webSettings.setSupportZoom(false);// 设置是否支持变焦,仅支持双击缩放
webSettings.setNeedInitialFocus(false);// 设置是否可以访问文件
// webSettings.setBlockNetworkImage(true);// 加载图片放在最后加载渲染
// webSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);//
// 设置缓存模式
webSettings.setCacheMode(webSettings.LOAD_NO_CACHE);//
不使用缓存
webView.addJavascriptInterface(new
Scan2(),"mMap");
// 这里的名称就是在页面window.fxl.testFunction()所取的别名
webView.addJavascriptInterface(new
Scan2(),"phone");
// 这里的名称就是在页面window.fxl.testFunction()所取的别名
//关键setGeolocationEnabled
webView.getSettings().setGeolocationEnabled(true);
}
private
void setClient() {
webView.setWebChromeClient(new WebChromeClient() {
@Override
public
void onGeolocationPermissionsShowPrompt(String origin,
android.webkit.GeolocationPermissions.Callback callback) {
callback.invoke(origin,
true, false);
super.onGeolocationPermissionsShowPrompt(origin, callback);
}
}
相关文章推荐
- Android中WebChromeClient和WebViewClient的区别浅析
- HTML5 Geolocation 定位服务 实例
- HTML5 地理位置定位(HTML5 Geolocation)
- php实现手机定位
- HTML5调用百度地图API进行地理定位实例
- Android中系统设置中的清除数据究竟会清除哪些数据
- Flex AIR应用GPS定位功能(Android和IOS)
- 基于HTML5的地理位置定位实验
- HTML5 地理位置定位(HTML5 Geolocation)原理及应用
- HTML5 Geolocation实用性小调查
- Android与WebView的同步和异步访问机制
- HTML5 Geolocation API 使用方法
- HTML5 地理位置定位(HTML5 Geolocation)
- HTML5 geolocation API 获得用户当前地理位置 推荐
- 使用jQuery、Yahoo API和HTML5的geolocation来开发一个天气预报web应用
- Android 关于WebView全方面的使用
- Android中WebViewClient与WebChromClient两个类的区别
- HTML5地理位置Geolocation以及百度地图应用
- Get Geolocation with Ionic 2
- Android使用WebView, WebChromeClient和WebViewClient加载网页