没有GPS也想定位,试试JavaScript轻应用的基站定位

简介: 本篇我们将基于HaaS 600Kit开发板,以及阿里云开发工具IoT-Studio来搭建一个简单的定位功能,说到设备定位,同学们可能都会想到GPS定位,其实除了像GPS这种卫星定位之外,我们身边的设备如:智能手机、智能手表、穿戴设备等能联网的设备都可以用来定位,通过连接运营商(电信、联通、移动)基站来定位的方式称之为基站定位,或者又称之为移动位置服务(LBS--Location Based Service)。

1、前言

本篇我们将基于HaaS 600Kit开发板,以及阿里云开发工具IoT-Studio来搭建一个简单的定位功能,说到设备定位,同学们可能都会想到GPS定位,其实除了像GPS这种卫星定位之外,我们身边的设备如:智能手机、智能手表、穿戴设备等能联网的设备都可以用来定位,通过连接运营商(电信、联通、移动)基站来定位的方式称之为基站定位,或者又称之为移动位置服务(LBS--Location Based Service)。


基站定位的原理是设备依靠跟运营商基站的连接信息来计算出设备相对基站的位置,而基站的位置是固定的,所以设备的位置也会相应的计算出来;

image.png

2、实战目标

使用HaaS600Kit开发板,不依赖于板载的GNSS模块,使用联网信息获取设备经纬度并在地图上展现出来。


目标拆分


获取设备联网信息

上报设备联网信息到物联网平台,获取设备经纬度

使用IoT-Studio添加地图组件,在地图上展示设备位置及其他信息


3、准备工作

硬件


HaaS600Kit开发套件

sim卡一张

软件


轻应用命令行工具

设备端JavaScript应用代码


4、实战操作

4.1、设备bringup

不熟悉HaaS600Kit开发套件的同学请阅读该文章HaaS600Kit

熟悉HaaS600Kit开发套件的同学请直接到step2


4.2、物联网平台创建产品及设备

登录阿里云物联网平台创建产品

image.png

  • 创建产品模型
  • image.png
  • image.png


此处需要添加两个功能,一个是自定义功能,用来接收设备上报的网络信息,一个是标准功能,用来放经纬度信息。

自定义功能:LocationInfo


image.png

输出参数 cdma bts nearbts数据类型都是text

标准功能:   GeoLocation

image.png

产品模型创建完成需要发布上线才能生效。

image.png

产品模型创建完成之后,需要添加设备,如下图所示

image.png

点击添加设备,device_name可以随便定义,不写的话系统随机生成。

image.png

设备创建成功,如下图所示

image.png

此时我们需要保存该设备的秘钥,留待后续使用

image.png

4.3、设备运行,获取位置

  • 将示例代码推送到设备端,需要将代码中的设备三元组替换成上一步中创建的设备三元组(productKey,deviceName,deviceSecret).
  • 设备运行,从云端查看设备属性,发现已获取到经纬度信息

image.png

4.4、IoT-Studio项目创建

  • 创建组态服务项目

image.png

image.png

image.png

image.png

找到地图组件后拖入工作区

image.png

image.png

因为我们没有创建过地图场景,所以选择场景中是空的,需要我们在二维数据可视化中创建场景。

 

4.5、地图场景创建

在创建场景的时候,我们的控制台会自动跳转到阿里云IoT空间数据可视化平台,如图所示

image.png

我们选择二维数据可视化,然后点击创建场景即可。

在创建场景的时候,这边非常友好的提供了两种数据来源,我们这边选择数据来源于物联网平台。

 image.png

image.png

创建完成之后,可以看到在地图上已经展示出了设备的具体位置,还可以基于设备的位置增加一个附加功能,例如:周界报警、地理围栏、历史轨迹、热力图等等,还可以选择地图主题跟3D模型。

image.png

此时在IoT-Studio场景中就出现了轻应用实战之基站定位,添加即可。

整体预览

image.png

5、总结

本实战涉及知识较多,涉及到设备到云端的全链路能力以及地图能力。

  • 获取设备联网信息
  • 将设备联网信息发送到物联网平台对应的物模型下面
  • 创建标准物模型地理位置
  • 在IoT-Studio创建地图场景

 

相关实践学习
钉钉群中如何接收IoT温控器数据告警通知
本实验主要介绍如何将温控器设备以MQTT协议接入IoT物联网平台,通过云产品流转到函数计算FC,调用钉钉群机器人API,实时推送温湿度消息到钉钉群。
阿里云AIoT物联网开发实战
本课程将由物联网专家带你熟悉阿里云AIoT物联网领域全套云产品,7天轻松搭建基于Arduino的端到端物联网场景应用。 开始学习前,请先开通下方两个云产品,让学习更流畅: IoT物联网平台:https://iot.console.aliyun.com/ LinkWAN物联网络管理平台:https://linkwan.console.aliyun.com/service-open
相关文章
|
1月前
|
开发框架 前端开发 JavaScript
使用JavaScript、jQuery和Bootstrap构建待办事项应用
使用JavaScript、jQuery和Bootstrap构建待办事项应用
13 0
|
1月前
|
自然语言处理 JavaScript 前端开发
探索JavaScript中的闭包:理解其原理与实际应用
探索JavaScript中的闭包:理解其原理与实际应用
19 0
|
1月前
|
JavaScript 前端开发 算法
js开发:请解释什么是虚拟DOM(virtual DOM),以及它在React中的应用。
虚拟DOM是React等前端框架的关键技术,它以轻量级JavaScript对象树形式抽象表示实际DOM。当状态改变,React不直接操作DOM,而是先构建新虚拟DOM树。通过高效diff算法比较新旧树,找到最小变更集,仅更新必要部分,提高DOM操作效率,降低性能损耗。虚拟DOM的抽象特性还支持跨平台应用,如React Native。总之,虚拟DOM优化了状态变化时的DOM更新,提升性能和用户体验。
23 0
|
9天前
|
开发框架 前端开发 JavaScript
采用C#.Net +JavaScript 开发的云LIS系统源码 二级医院应用案例有演示
技术架构:Asp.NET CORE 3.1 MVC + SQLserver + Redis等 开发语言:C# 6.0、JavaScript 前端框架:JQuery、EasyUI、Bootstrap 后端框架:MVC、SQLSugar等 数 据 库:SQLserver 2012
|
28天前
|
开发框架 JavaScript 前端开发
描述JavaScript事件循环机制,并举例说明在游戏循环更新中的应用。
JavaScript的事件循环机制是单线程处理异步操作的关键,由调用栈、事件队列和Web APIs构成。调用栈执行函数,遇到异步操作时交给Web APIs,完成后回调函数进入事件队列。当调用栈空时,事件循环取队列中的任务执行。在游戏开发中,事件循环驱动游戏循环更新,包括输入处理、逻辑更新和渲染。示例代码展示了如何模拟游戏循环,实际开发中常用框架提供更高级别的抽象。
12 1
|
1月前
|
JSON JavaScript 前端开发
JS逆向快速定位关键点之9大通用hook脚本
JS逆向快速定位关键点之9大通用hook脚本
|
1月前
|
JavaScript 前端开发
HTML JS 应用
HTML JS 应用
19 3
|
1月前
|
JavaScript 前端开发 算法
Vue.js的单向数据流:让你的应用更清晰、更可控
Vue.js的单向数据流:让你的应用更清晰、更可控
|
1月前
|
JavaScript 前端开发 API
Vue.js 深度解析:nextTick 原理与应用
Vue.js 深度解析:nextTick 原理与应用
|
1月前
|
Web App开发 JavaScript 前端开发
深入浅出:Node.js 在后端开发中的应用与实践
【2月更文挑战第13天】本文旨在探讨Node.js这一流行的后端技术如何在现代Web开发中被应用以及它背后的核心优势。通过深入分析Node.js的非阻塞I/O模型、事件驱动机制和单线程特性,我们将揭示其在处理高并发场景下的高效性能。同时,结合实际开发案例,本文将展示如何利用Node.js构建高性能、可扩展的后端服务,以及在实际项目中遇到的挑战和解决方案。此外,我们还将讨论Node.js生态系统中的重要工具和库,如Express.js、Koa.js等,它们如何帮助开发者快速搭建和部署应用。通过本文的探讨,读者将获得对Node.js在后端开发中应用的深入理解,以及如何有效利用这一技术来提升开发效率