HTML5培训第15节课堂笔记(HTML5+maps,geolocation)

2024-09-02 17:48

本文主要是介绍HTML5培训第15节课堂笔记(HTML5+maps,geolocation),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

HTML5培训第15节课堂笔记

1.地理信息定位:

window.οnlοad=function(){

        mui.plusReady(function(){

           plus.geolocation.getCurrentPosition(function(p){

               latitude=p.coords.latitude;

               longitude=p.coords.longitude;

               varaddress=p.addresses;

           },function(e){

               console.log(e.message);

           },{

               provider:"baidu"

              

           });

        });

 

 

//监听

           varwatchID=

           plus.geolocation.watchPosition(function(){},function(),{});

           plus.geolocation.clearWatch(watchID);

 

 

 

2.打开baidu地图进行导航

var src=new plus.maps.Point(latitude,longitude);

               vardst=new plus.maps.Point("31.0242342","109.242432432");

               plus.maps.openSysMap(dst,"都江堰xx地",src);

 

 

mui.openWindow({

                  url:"showMap.html",

                  id:"showMap.html",

                  extras:{lat:latitude,longi:longitude},

                  show:{

                      autoShow:false

                  }

               });

 

 

3.跨页面拿值:cur=plus.webview.currentWebview();

              latitude=cur.lati;

              longitude=cur.longi;

 

 

4.显示地图:window.οnlοad=function(){

           mui.plusReady(function(){

              cur=plus.webview.currentWebview();

              latitude=cur.lati;

              longitude=cur.longi;

              pcenter=newplus.maps.Point(longitude,latitude);

              map=newplus.maps.Map("mymap");

              map.centerAndZoom(pcenter,16);

             

              plus.nativeUI.closeWaiting();

              cur.show();

             

           })

       };

 

 

mymap指的是相应地图区域div的id值

 

标记点的作法:

function createMarker()

       {

           var marker=new plus.maps.Marker(pcenter);

           marker.setIcon("imgs/map.jpg");

           marker.setLabel("成都东软学院 C7");

           var bubble=newplus.maps.Bubble("我在 成都东软学院 C7附近<br/>电话:028-888888");

           marker.setBubble(bubble);

           map.addOverlay(marker);

          

       }

 

其他方法: map.showUserLocation(true);
map.getUserLocation(function(p){});
plus.maps.Circle(pcenter,0.5);

 



完整代码:

getPlus.html

 

<!DOCTYPE html>

<html>

<head>

    <metacharset="UTF-8">

    <metaname="viewport"content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no"/>

   <title></title>

    <style>

       .mui-content{

           margin:0 auto;

           text-align: center;

       }

       .mui-content button{

           width:70%;

           margin-top:80px;

       }

    </style>

    <scriptsrc="js/mui.min.js"></script>

    <linkhref="css/mui.min.css" rel="stylesheet"/>

    <scripttype="text/javascript" charset="UTF-8">

      mui.init();

    </script>

</head>

<body>

<header class="mui-bar mui-bar-nav">

    <aclass="mui-action-back mui-icon mui-icon-left-navmui-pull-left"></a>

    <h1 class="mui-title">标题</h1>

</header>

<div class="mui-content">

<button class="mui-btn-primary" id="butnOpenBaidu"/>打开百度</button>

<button class="mui-btn-primary" id="butnOpenInner"/>使用内置地图</button>

 

</div>

 

    <script>

    var latitude;//纬度

    var longitude;//经度

    window.οnlοad=function(){

       mui.plusReady(function(){

           plus.geolocation.getCurrentPosition(function(p){//成功回调函数

              latitude=p.coords.latitude;

              longitude=p.coords.longitude;

              varaddress=p.addresses;

           },function(e){//失败回调函数

              console.log(e.message);

           },{//参数配置

              provider:"bdidu"//百度

           });

           //监听

           varwatchID=plus.geolocation.watchPosition(function(){

             

           },

           function(){

             

           },

           {

             

           });

           //停止监听

           plus.geolocation.clearWatch(watchID);

          

       })

      

       document.getElementById("butnOpenBaidu").addEventListener("tap",function(){

           var src=newplus.maps.Point(longitude,latitude);//起点

           var dst=newplus.maps.Point("109.5555","31.5885");

          

           plus.maps.openSysMap(dst,"都江堰",src);//打开已经有的地图

       })

      

       document.getElementById("butnOpenInner").addEventListener("tap",function(){

           mui.openWindow({

              url:"showMap.html",

              id:"showMap.html",

              extras:{

               latitude:latitude,

                  longitude:longitude

              },

              show:{

                  autoShow:false

              }

              

           })

       },false);

      

      

    }

    </script>

</body>

</html>

 

 

 

showMap.html

<!DOCTYPE html>

<html>

<head>

    <metacharset="UTF-8">

    <metaname="viewport"content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no"/>

   <title></title>

    <scriptsrc="js/mui.min.js"></script>

    <linkhref="css/mui.min.css" rel="stylesheet"/>

    <style>

       #map{

           height:800px;

       }

    </style>

    <scripttype="text/javascript" charset="UTF-8">

      mui.init();

    </script>

</head>

<body>

    <!--使用内置地图-->

    <headerclass="mui-bar mui-bar-nav">

        <h1 class="mui-title">地图显示</h1>

    </header>

    <div class="mui-content">

       <!--装地图区域-->

       <divid="map">

          

       </div>

    </div>

</body>

<script>

var cur;

var latitude,longitude;

var pcenter;//中心点

var map;

    window.οnlοad=function(){

       mui.plusReady(function(){

           cur=plus.webview.currentWebview();

                 latitude=cur.latitude;

                  longitude=cur.longitude;

                  pcenter=newplus.maps.Point(longitude,latitude);

                  map=newplus.maps.Map("map");//地图控件

                  map.centerAndZoom(pcenter,16);//把地图定位到中心,以中心点作为缩放

                 createMarker();

                  plus.nativeUI.closeWaiting();//关闭进度条

                  //窗口显示

                  cur.show();

       })

    };

    functioncreateMarker(){

       var marker=newplus.maps.Marker(pcenter);

       marker.setIcon("images/map.jpg");//图标

       marker.setLabel("我在成都东软学院附近");

       //气泡

       var bubble=newplus.maps.Bubble("我在成都东软学院");//一点跳出提示文字支持html标识

       marker.setBubble(bubble);

       map.addOverlay(marker)//在地图上做一些特殊的东西

    }

    //map.showUserLocation(true);

    //map.getUserLocation(function(p){});//获得当前用户的位置

   

    //plus.maps.Circle(pcenter,0.5);

</script>

</html>

 

 

地图插件配置

Mainifest.json  sdk配置

 

获取key参考:

http://ask.dcloud.net.cn/article/29


 

这篇关于HTML5培训第15节课堂笔记(HTML5+maps,geolocation)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1130642

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo