android webview 获取Geolocation

    <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);  

        } 

}

Android WebView获取页面里的经纬度需要进行以下几个步骤: 1. 确认页面是否已经开启了定位功能,可以通过在浏览器中打开该页面并在地址栏输入"javascript:navigator.geolocation.getCurrentPosition(function(position){console.log(position)})"来检查; 2. 在Android Manifest文件中添加定位相关的权限: ``` <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> ``` 3. 在WebView中启用JavaScript: ``` WebSettings webSettings = webView.getSettings(); webSettings.setJavaScriptEnabled(true); ``` 4. 在WebViewClient的onPageFinished()方法中注入JavaScript代码,以获取页面中的经纬度信息: ``` webView.setWebViewClient(new WebViewClient() { @Override public void onPageFinished(WebView view, String url) { super.onPageFinished(view, url); view.loadUrl("javascript:window.android.onGeolocationUpdate(navigator.geolocation.getCurrentPosition(function(position){return position;}))"); } }); // 在WebView中注入JavaScript对象,用于接收页面中的经纬度信息 webView.addJavascriptInterface(new Object() { @JavascriptInterface public void onGeolocationUpdate(String position) { // 处理获取到的经纬度信息 } }, "android"); ``` 在上述代码中,注入的JavaScript代码将会调用一个名为"android.onGeolocationUpdate()"的JavaScript方法,并传递获取到的经纬度信息作为参数。在Java代码中,我们通过在WebView中注入一个名为"android"的JavaScript对象,并在该对象中定义一个名为"onGeolocationUpdate()"的方法,用于处理获取到的经纬度信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值