(十九)原生js案例之h5地里位置信息与高德地图的初使用

news2024/9/23 2:37:36

h5 地里位置信息

1. 获取当前位置信息

在这里插入图片描述

window.onload = function () {
  const oBtn = document.querySelector("#btn");
  const oBox = document.querySelector("#box");

  oBtn.onclick = function () {
    window.navigator.geolocation.getCurrentPosition(
      function (position) {
        console.log("🚀 ~ position:", position);
        const { latitude, longitude } = position.coords;
        oBox.innerHTML += `${latitude} ${longitude}`;
      },
      function (error) {
        console.log("🚀 ~ error:", error);
      },
      {
        enableHighAccuracy: true,
        timeout: 5000,
      }
    );
  };
};
  • 失败编码

    • 0 未知错误,不包括下面的
    • 1 用户拒绝
    • 2 尝试获取用户信息,但失败了
    • 3 超时,设置了 timeout 参数
  • chrome 浏览器失败,edge 浏览器成功
    在这里插入图片描述

  • 数据收集,json 格式

    {
      "enableHighAccuracy": true, // 开启高精度,默认 false
      "timeout": 5000, // 超时时间,默认 infinity
      "maximumAge": 0 // 位置可以缓存时间,默认 0
    }
    

2. 获取当前位置信息

window.onload = function () {
  const oBtn = document.querySelector("#btn");
  const oBox = document.querySelector("#box");
  let timer = null;
  oBtn.onclick = function () {
    timer = window.navigator.geolocation.getCurrentPosition(
      function (position) {
        console.log("🚀 ~ position:", position);
        let str = "";
        for (const key in position.coords) {
          const value = position.coords[key];
          str += `${key}: ${value} <br/>`;
        }
        oBox.innerHTML = str;
      },
      function (error) {
        console.log("🚀 ~ error:", error);
        //移动端主要位置改变,这里就会一直报错
        //清除定时器
        window.navigator.geolocation.clearWatch(timer);
      },
      {
        enableHighAccuracy: true,
        timeout: 5000,
        frequence: 1000,
        maximumAge: 1000,
      }
    );
  };
};
  • h5 获取到地里位置信息后进行标注定位,配置使用高德地图

    • 封装高德地图,进行初始化
window._AMapSecurityConfig = {
  securityJsCode: "自己的key",
};

class AMapHelper {
  static async getMap() {
    if (window.AMap) {
      return window.AMap;
    }

    let AMap = null;

    const baseConfig = {
      key: window._AMapSecurityConfig.securityJsCode, //申请好的Web端开发者 Key,调用 load 时必填
      version: "2.0", //指定要加载的 JS API 的版本,缺省时默认为 1.4.15
    };

    try {
      AMap = await AMapLoader.load(baseConfig);
      console.log("高德地图初始化");
    } catch (error) {
      console.log(error);
    }

    return AMap;
  }
}
  • 拿到高德地图对象后,进行标记
window.onload = async function () {
  let timer = 0;
  await AMapHelper.getMap();
  let map = new AMap.Map("box", {
    resizeEnable: true,
  });
  getPos();
  function getPos() {
    timer = window.navigator.geolocation.getCurrentPosition(
      function (position) {
        console.log("🚀 ~ position:", position);
        //获取位置信息
        const { longitude, latitude } = position.coords;
        //创建标记
        const marker = new AMap.Marker({
          position: [longitude, latitude], //位置
        });
        map.add(marker); //添加到地图
      },
      function (error) {
        console.log("🚀 ~ error:", error);
        //移动端主要位置改变,这里就会一直报错
        //清除定时器
        window.navigator.geolocation.clearWatch(timer);
      },
      {
        enableHighAccuracy: true,
        timeout: 5000,
        frequence: 1000,
        maximumAge: 1000,
      }
    );
  }
};

案例,高德地图添加标记,事件,自定义标记 ICON

在这里插入图片描述

window.onload = async function () {
  let timer = 0;
  await AMapHelper.getMap();
  // console.log(window.AMap);
  let map = new AMap.Map("box", {
    resizeEnable: true,
  });
  const content = [
    "<div><b>高德软件有限公司</b>",
    "电话 : 010-84107000   邮编 : 100102",
    "地址 : 北京市望京阜通东大街方恒国际中心A座16层</div>",
  ];
  const icon = new AMap.Icon({
    size: new AMap.Size(25, 34), //图标尺寸
    image: "./img/site.png", //Icon 的图像
    imageOffset: new AMap.Pixel(-9, -3), //图像相对展示区域的偏移量,适于雪碧图等
    imageSize: new AMap.Size(135, 40), //根据所设置的大小拉伸或压缩图片
  });
  getPos();
  function getPos() {
    timer = window.navigator.geolocation.getCurrentPosition(
      function (position) {
        console.log("🚀 ~ position:", position);
        //获取位置信息
        const { longitude, latitude } = position.coords;
        //创建标记,自定义图片
        const marker = new AMap.Marker({
          position: new AMap.LngLat(longitude, latitude), //点标记的位置
          offset: new AMap.Pixel(-13, -30), //偏移量
          icon: icon, //添加 Icon 实例
          title: "高德科技",
          zooms: [2, 12], //点标记显示的层级范围,超过范围不显示
        });
        //添加窗体事件
        const infoWindow = new AMap.InfoWindow({
          //创建信息窗体
          isCustom: false, //使用自定义窗体
          // content: "<div id='info1'>这里可以显示自己的自定义描述内容</div>", //信息窗体的内容可以是任意html片段
          offset: new AMap.Pixel(16, -45),
          content,
          closeWhenClickMap: true,
        });
        //默认展示信息窗体
        infoWindow.open(map, [longitude, latitude]);
        const onMarkerClick = function (e) {
          // infoWindow.open(map, e.target.getPosition()); //点击打开信息窗体
          //e.target就是被点击的Marker
        };
        map.add(marker); //添加到地图
        marker.on("click", onMarkerClick); //绑定click事件
      },
      function (error) {
        console.log("🚀 ~ error:", error);
        //移动端主要位置改变,这里就会一直报错
        //清除定时器
        window.navigator.geolocation.clearWatch(timer);
      },
      {
        enableHighAccuracy: true,
        timeout: 5000,
        frequence: 1000,
        maximumAge: 1000,
      }
    );
  }
};

进阶之路: 高德地图2.0文档

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1944646.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

STM32嵌入式人工智能边缘计算应用教程

目录 引言环境准备边缘计算系统基础代码实现&#xff1a;实现嵌入式人工智能边缘计算系统 4.1 数据采集模块 4.2 数据处理与推理模块 4.3 通信与网络系统实现 4.4 用户界面与数据可视化应用场景&#xff1a;边缘计算与优化问题解决方案与优化收尾与总结 1. 引言 嵌入式人工智…

GD32相较于STM32的优劣势-完全总结

优势 1.更高的主频 GD32单片机的主频可以达到108MHz&#xff0c;‌而STM32的最大主频为72MHz&#xff0c;‌这意味着GD32在代码执行速度上具有优势&#xff0c;‌适合需要快速处理数据的场景 2.更低的内核电压 GD32的内核电压为1.2V&#xff0c;‌而STM32的内核电压为1.8V。…

SQL labs-SQL注入(三)

本文仅作为学习参考使用&#xff0c;本文作者对任何使用本文进行渗透攻击破坏不负任何责任。 引言&#xff1a; 盲注简述&#xff1a;是在没有回显得情况下采用的注入方式&#xff0c;分为布尔盲注和时间盲注。 布尔盲注&#xff1a;布尔仅有两种形式&#xff0c;ture&#…

golang语言 .go文件版本条件编译,xxx.go文件指定go的编译版本必须大于等于xxx才生效的方法, 同一个项目多个go版本文件共存方法

在go语言中&#xff0c;我们不关是可以在编译时指定版本&#xff0c; 在我们的xxx.go文件中也可以指定go的运行版本&#xff0c;即 忽略go.mod中的版本&#xff0c;而是当当前的go运行版本达到指定条件后才生效的xxx.go文件。 方法如下&#xff1a; 我们通过在xxx.go文件的头部…

【数据挖掘】词云分析

目录 1. 词云分析 2. Python 中的 WordCloud 库 1. 词云分析 词云&#xff08;Word Cloud&#xff09;是数据可视化的一种形式&#xff0c;主要用于展示文本数据中单词的频率和重要性。它具有以下几种主要用途和意义&#xff1a; 1. 文本分析 • 识别关键主题&#xff1a;通…

光伏模拟器应用

太阳能光伏 (PV) 模拟器是一种可编程电源&#xff0c;用于模拟太阳能电池板。模拟器具有快速瞬态响应&#xff0c;可响应负载条件的变化并保持电压-电流特性的输出。 用户可以根据系统规格定义太阳能电池板配置&#xff0c;并通过选择环境条件来选择适当的环境条件进行模拟。用…

Varjo XR-4系列现已获得达索3DEXPERIENCE平台官方支持

近日&#xff0c;全球领先的工业虚拟和混合现实解决方案提供商Varjo宣布&#xff0c;Varjo XR-4系列现已获得达索3DEXPERIENCE平台的本地支持。这种集成为工程师和设计师带来了先进的虚拟和混合现实功能&#xff0c;他们可以通过沉浸式技术创新并简化他们的3D工作流程。 在达索…

springcolud学习05Feign

Feign Feign是一个声明式的http客户端,我们知道,在不使用Feign之前,在微服务中,一个模块如果想要调用另一个模块中的某个功能,需要向其发起请求http请求,如果不使用Feign,我们就需要通过硬编码的形式去编写构建http请求 新建模型,建立一个和consumer一样的module,不…

数据结构经典测试题1

1. char a101; int sum200; a27;suma; printf("%d\n",sum); 上述代码运行结果是什么呢&#xff1f; A: 327 B: 99 C: 328 D: 72 答案为D。 char为有符号类型&#xff0c;占1个字节&#xff0c;也就是8位&#xff0c;其中最高位是符号位&#xff0c;取值范围为-…

面对海量网络请求,Tomcat线程池如何进行扩展?

面对海量网络请求&#xff0c;Tomcat线程池如何进行扩展&#xff1f; 上篇文章:深入浅出Tomcat网络通信的高并发处理机制说到Tomcat中EndPoint如何高效处理网络通信&#xff0c;其中离不开Tomcat线程池的大力支持 本篇文章就来聊聊Tomcat中的线程池与JUC下的线程池到底有何不…

80. 删除有序数组中的重复项 II【 力扣(LeetCode) 】

一、题目描述 给你一个有序数组 nums &#xff0c;请你 原地 删除重复出现的元素&#xff0c;使得出现次数超过两次的元素只出现两次 &#xff0c;返回删除后数组的新长度。 不要使用额外的数组空间&#xff0c;你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成…

谈一谈爬虫开发工程师

爬虫就只是抓数据的吗&#xff1f;并不是&#xff0c;爬虫工程师的工作不再仅仅是抓取数据&#xff0c;还需要处理其他各种复杂问题&#xff0c;今天我们就来聊聊爬虫开发工程师。 一、 爬虫开发工程师工作内容 爬虫开发工程师是负责编写和维护网络爬虫程序的专业人员。他们的…

计算机技术基础 (bat 批处理)Note4

计算机技术基础 &#xff08;bat 批处理&#xff09;Note4 本节主要讲解一些 bat 批处理文件中的一些特殊符号&#xff0c;包括 , %, > 和 >>, |, ^, & 和 && 和 ||, " ", ,, ;, ()。 回显屏蔽符 回显屏蔽符 : 这个字符在批处理中的意思是关…

Redis一致性与分布式锁

Redis一致性 何为redis一致性 即在项目中&#xff0c;redis缓存中的数据要与数据库当中的数据保持一致。 那么这里&#xff0c;就会有小伙伴要问了&#xff0c;redis缓存中的数据不就是从数据库当中查询出来的吗&#xff1f;怎么会不一致呢&#xff1f; 笔者在这里解答一下…

数字信号||离散系统的冲激响应和阶跃响应(3)

实验三 离散系统的冲激响应和阶跃响应 一、实验目的 (1)加深对离散线性移不变(LSI)系统基本理论的理解&#xff0c;明确差分方程与系统函数之间的关系。 (2)初步了解用MATLAB语言进行离散时间系统研究的基本方法。 (3)掌握求解离散时间系统冲激响应和阶跃响应程序的编写方…

Proxmox8基于PC物理机/服务器安装,初始化,挂载磁盘,安装虚拟机

目录 安装文件 开始安装Proxmox 选择启动菜单&#xff0c;F11 后进入启动菜单选择 按需选择是否关闭RAID 选择对应的U盘 进入安装界面 进入安装启动过程 选择系统盘 设置相关信息 设置IP和开启root远程登录 设置dns 设置网卡ip 设置 ssh 远程登录 开机合并local-l…

Java---String类

乐观学习&#xff0c;乐观生活&#xff0c;才能不断前进啊&#xff01;&#xff01;&#xff01; 我的主页&#xff1a;optimistic_chen 我的专栏&#xff1a;c语言 &#xff0c;Java 欢迎大家访问~ 创作不易&#xff0c;大佬们点赞鼓励下吧~ 前言 在C语言中已经涉及到字符串了…

四、GD32 MCU 常见外设介绍 (6) ADC 模块介绍

6.1.ADC 基础知识 12 位逐次逼近式模数转换器模块&#xff08;ADC&#xff09;&#xff0c;可以采样来自于外部输入通道、内部输入通道的模拟信号&#xff0c;采样转换后&#xff0c;转换结果可以按照最低有效位对齐或最高有效位对齐的方式保存在相应的数据寄存器中。 6.2.GD…

go语言Gin框架的学习路线(十)

目录 GORM的CRUD教程 查询 普通查询 定义 User 结构体 查询所有用户 查询第一个用户 总结 条件查询 内联条件 额外查询选项 高级查询 链式操作 Scopes 多个立即执行方法 GORM的CRUD教程 CRUD 是 "Create, Read, Update, Delete"&#xff08;创建、查询…

数字图像处理中的常用特殊矩阵及MATLAB应用

一、前言 Matlab的名称来源于“矩阵实验室&#xff08;Matrix Laboratory&#xff09;”&#xff0c;其对矩阵的操作具有先天性的优势&#xff08;特别是相对于C语言的数组来说&#xff09;。在数字图像处理中&#xff0c;为了提高编程效率&#xff0c;我们可以使用多种方式来创…