IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> 移动端H5调用高德地图API获取定位ios端问题 -> 正文阅读

[移动开发]移动端H5调用高德地图API获取定位ios端问题

在移动端h5的开发中遇到了使用高德地图的API获取定位的问题。在安卓端没有问题,但在ios上不能正常弹出位置授权窗口。查阅文档并实际尝试后找到如下原因和解决方案。

问题

iOS 11 操作系统的一大特性是对 http 形式访问页面的限制变得非常严格(相比iOS 10 和 iOS 9)。而高德提供的JS API功能均支持http和https两种协议访问,在iOS 11操作系统上推荐使用https形式访问功能页面和接口。

解决方案

  • 先将高德地图的JS API的版本升级到1.4.1版本以上

  • 然后需要满足以下两点:

1、需要使用JS API的高精度定位功能,在iOS 11上,请通过https访问定位。

2、个人(或企业)网站在iOS 11系统下也调整成https形式对用户提供。

  • 引入remogeo.js ,建议放置在本地:http://a.amap.com/jsapi_demos/static/remogeo/remogeo.js

  • 核心代码

<script type="text/javascript" src="../../remogeo.js"></script>

 AMap.plugin('AMap.Geolocation', function () {
                    let geolocation = new AMap.Geolocation({
                        enableHighAccuracy: true, // 是否使用高精度定位,默认:true
                        timeout: 10000, // 超过10秒后停止定位,默认:无穷大
                        maximumAge: 0, // 定位结果缓存0毫秒,默认:0
                        convert: true, // 自动偏移坐标,偏移后的坐标为高德坐标,默认:true
                        showButton: true, // 显示定位按钮,默认:true
                        buttonPosition: 'LB', // 定位按钮停靠位置,默认:'LB',左下角
                        buttonOffset: new AMap.Pixel(10,
                            20), // 定位按钮与设置的停靠位置的偏移量,默认:Pixel(10, 20)
                        showMarker: true, // 定位成功后在定位到的位置显示点标记,默认:true
                        showCircle: true, // 定位成功后用圆圈表示定位精度范围,默认:true
                        panToLocation: true, // 定位成功后将定位到的位置作为地图中心点,默认:true
                        zoomToAccuracy: true // 定位成功后调整地图视野范围使定位位置及精度范围视野内可见,默认:false
                    });

                    //判断是否是ios系统,如果是,则调用远程定位方法
                    if (AMap.UA.ios) {
                        //使用远程定位,见 remogeo.js
                        var remoGeo = new RemoGeoLocation();
                        //替换方法
                        navigator.geolocation.getCurrentPosition = function () {
                            return remoGeo.getCurrentPosition.apply(remoGeo, arguments);
                        };
                        //替换方法
                        navigator.geolocation.watchPosition = function () {
                            return remoGeo.watchPosition.apply(remoGeo, arguments);
                        };
                    }
                    geolocation.getCurrentPosition();
                    AMap.event.addListener(geolocation, 'complete', onComplete); // 返回定位信息
                    AMap.event.addListener(geolocation, 'error', onError); // 返回定位出错信息
});


  function onComplete(obj) {
            var res = '经纬度:' + obj.position +
                '\n精度范围:' + obj.accuracy +
                '米\n定位结果的来源:' + obj.location_type +
                '\n状态信息:' + obj.info +
                '\n地址:' + obj.formattedAddress +
                '\n地址信息:' + JSON.stringify(obj.addressComponent, null, 4);
            xcoor = obj.position.lng;
            ycoor = obj.position.lat;
            
        }

        function onError(obj) {
            // 
        }

?

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2021-08-19 12:09:56  更:2021-08-19 12:10:54 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 9:53:06-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码