惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

博客园 - Franky
N
Netflix TechBlog - Medium
Google Online Security Blog
Google Online Security Blog
月光博客
月光博客
量子位
酷 壳 – CoolShell
酷 壳 – CoolShell
V
V2EX
腾讯CDC
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
博客园 - 聂微东
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
M
MIT News - Artificial intelligence
Vercel News
Vercel News
The GitHub Blog
The GitHub Blog
Hugging Face - Blog
Hugging Face - Blog
博客园 - 【当耐特】
Apple Machine Learning Research
Apple Machine Learning Research
aimingoo的专栏
aimingoo的专栏
博客园 - 三生石上(FineUI控件)
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
MongoDB | Blog
MongoDB | Blog
H
Help Net Security
The Cloudflare Blog
Blog — PlanetScale
Blog — PlanetScale
F
Full Disclosure
G
Google Developers Blog
罗磊的独立博客
Jina AI
Jina AI
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
Y
Y Combinator Blog
H
Hackread – Cybersecurity News, Data Breaches, AI and More
J
Java Code Geeks
A
About on SuperTechFans
IT之家
IT之家
大猫的无限游戏
大猫的无限游戏
S
SegmentFault 最新的问题
有赞技术团队
有赞技术团队
GbyAI
GbyAI
雷峰网
雷峰网
T
The Blog of Author Tim Ferriss
The Register - Security
The Register - Security
U
Unit 42
D
Docker
Martin Fowler
Martin Fowler
L
LINUX DO - 热门话题
NISL@THU
NISL@THU
阮一峰的网络日志
阮一峰的网络日志
C
Cybersecurity and Infrastructure Security Agency CISA
博客园_首页
Google DeepMind News
Google DeepMind News

Fooleap's Blog

渴望理想 | Fooleap's Blog 19 年底一些事 | Fooleap's Blog 藉秋风,跑起来 | Fooleap's Blog 一个人去跑步 | Fooleap's Blog 8 月的跑量仿佛是那暑假的作业 | Fooleap's Blog 三伏天跑步那么难受,为何还要跑? | Fooleap's Blog 解决小程序开发“当前系统代理不是安全代理” | Fooleap's Blog 忘却配速的夏日跑步 | Fooleap's Blog 六月天时“带水”跑步更爽 | Fooleap's Blog 出来混迟早要还的 | Fooleap's Blog 跑步不能当饭吃 | Fooleap's Blog 将京东移动端详情页链接转为 PC 端 | Fooleap's Blog 不是热就是雨 | Fooleap's Blog 这半月,我跑了 11 个 520 | Fooleap's Blog 跑完流汗一时爽,一直流汗一直爽 | Fooleap's Blog 初夏夜跑 | Fooleap's Blog Electron 中打开 QQ 临时会话 | Fooleap's Blog 春节期间的培隆角 | Fooleap's Blog 从春天跑到夏天 | Fooleap's Blog 晨雾中奔跑 | Fooleap's Blog 漫步春雨中 | Fooleap's Blog 跑在木棉花下 | Fooleap's Blog 我在春节依然坚持跑步 | Fooleap's Blog 伴随着日出跑步 | Fooleap's Blog 没有最好,只有更好 | Fooleap's Blog 电子气温计 | Fooleap's Blog 渡亭小学的金凤花 | Fooleap's Blog 随心而跑 | Fooleap's Blog 2018 跑步小结 | Fooleap's Blog 在 gVim 中使用“非等宽字体” | Fooleap's Blog 动车进汕,喜大普奔 | Fooleap's Blog 雨战汕马,漫步鮀城 | Fooleap's Blog 准备出发汕马 | Fooleap's Blog 环苏溪跑个半马 | Fooleap's Blog 不义之财 | Fooleap's Blog 跑去培隆看日落 | Fooleap's Blog 雨后跑土路 | Fooleap's Blog 秋意渐浓 | Fooleap's Blog 在夕阳下奔跑 | Fooleap's Blog 准备参加 2018 汕马 | Fooleap's Blog 不可立见的 spoiler 标签 | Fooleap's Blog TomTom Spark 表带 | Fooleap's Blog Disqus 支持新浪微博图床 | Fooleap's Blog 暂存 Disqus 匿名评论者邮箱地址 | Fooleap's Blog 组一台迷你主机 DeskMini 310 | Fooleap's Blog 我的个人信息卖给了谁? | Fooleap's Blog 我发了违法短信? | Fooleap's Blog 使用 Python 合并地图瓦片 | Fooleap's Blog 使用 Python 合并瓦片图 | Fooleap's Blog 拆电热水壶 | Fooleap's Blog 使用树莓派做监控显示 | Fooleap's Blog 南方的冷 | Fooleap's Blog 蓝牙耳机 Avantree Jogger Plus | Fooleap's Blog 新厝布网 | Fooleap's Blog 报装移动宽带 | Fooleap's Blog 双十一战绩 | Fooleap's Blog 郁闷的心情 | Fooleap's Blog 像 Disqus 一样获取链接颜色 | Fooleap's Blog Disqus 的 URL 编码问题 | Fooleap's Blog 选择框的全选联动 | Fooleap's Blog 弹出层中的视频全屏问题 | Fooleap's Blog 2016 年台风海马 | Fooleap's Blog 纯 CSS 实现导航图标动画 | Fooleap's Blog 湾头晨跑路线推荐:南湾小学跑道 | Fooleap's Blog Jekyll 显示每一年的文章数 | Fooleap's Blog 湾头晨跑路线推荐:南湾堤顶 | Fooleap's Blog Disqus 的 @ 提及功能 | Fooleap's Blog 近日渡亭堤顶的夕阳 | Fooleap's Blog 使用 Disqus API 上传图片 | Fooleap's Blog Disqus API 评论嵌套问题 | Fooleap's Blog Disqus API 的权限问题 | Fooleap's Blog 湾头晨跑路线推荐:环三湾 | Fooleap's Blog 如何下载 Apple Emoji 的 PNG 图片 公众号文章二维码 | Fooleap's Blog Disqus 的评论预审核 | Fooleap's Blog 湾头最好的跑道 | Fooleap's Blog 结合七牛和高德地图 API 显示照片位置 | Fooleap's Blog Zip 压缩排除特定目录 | Fooleap's Blog 流水涸摸蚬热 | Fooleap's Blog 2017 跨年跑 | Fooleap's Blog Jekyll 的中文字数统计 | Fooleap's Blog 为 Jekyll 文章页添加相关文章 | Fooleap's Blog 为 Jekyll 添加一个标签页面 | Fooleap's Blog 干了这瓶蛇草水 | Fooleap's Blog 在 macOS 上使用 NTFS 差点丢数据 Disqus Moderator Badge Text 已支持中文 为 Jekyll 添加一个简单的 API | Fooleap's Blog 为 Jekyll 加上简单搜索功能 | Fooleap's Blog 解决 Jemoji 的出错 | Fooleap's Blog 检测网络是否能够访问 Disqus | Fooleap's Blog 解决 This socket is closed 问题 更好的 Markdown 插图方式 | Fooleap's Blog 转换 Nike+ 的坐标数据 | Fooleap's Blog 高德地图 API 显示跑步路线 | Fooleap's Blog 善用 Google 搜索工具 | Fooleap's Blog 七牛 API 生成页面 URL 二维码 旧年 12 月跑步笔记 | Fooleap's Blog 科学使用 Disqus | Fooleap's Blog 培隆角的日出 | Fooleap's Blog 11 月跑步笔记 | Fooleap's Blog
利用 Nike+ API 获取跑步路线数据 | Fooleap's Blog
fooleap · 2017-04-20 · via Fooleap's Blog

常光临小博的博友不难发现,去年晒的几次跑步均有带上跑步路线地图,那么都是怎么实现的呢?这事暂且分两步来说,一是获取数据,二是显示地图。这篇主要讲获取数据部分。

讲正事之前,我先废话几句。跑步好处多多,对身体的好处不说,跑步爱好者就是喜欢各种装逼,有些人去参加马拉松就是为了去拍照的。我极少自拍,但几乎每次跑步途中都会拍几张图,跑步后贴到社交平台时间线,后面整理也有一些会贴到博客里面来。

折腾过程

作为地理爱好者的我,对跑步路线地图十分喜欢,于是就有了把跑步路线贴到博文中的想法。如何显示跑步路径这个问题令我头疼许久,要显示地图,就得获取到组成跑步折线相应的坐标数据,下面是我逐步实践的一个过程。

刚开始,我觉得只要自己根据跑步路线,地图上描点再用地图 API 画出来,大致差不多就行,于是就用 Google Earth 描点,并导出 KML 文件进行处理。

st=>start: 开始
e=>end: 结束
op1=>operation: Google Earth 画线 
op2=>operation: 转换坐标
op3=>operation: 地图 API 画线

st(right)->op1(right)->op2(right)->op3(right)->e

虽操作还算简单,但略显繁琐,且折线并非跑步的实际路线,显得有点 LOW,装逼还得认真点。

随后,我将目光转向 Nike+,因为 Nike+ 官网本身就有令人羡慕的跑步路线地图,肯定就有相应的坐标数据。不求能实现得跟他一模一样,哪怕窃取一小部分也可。

st=>start: 开始
e=>end: 结束
op1=>operation: Nike+ API 获取数据
op2=>operation: 转换坐标
op3=>operation: 地图 API 画线

st(right)->op1(right)->op2(right)->op3(right)->e

操作起来不算复杂,只需要去官网复制一个 ID 即可获取到相应的数据。这样做有个问题,每次转换坐标后得到的坐标数组太大了,经研究发现 Nike+ 大概每 10 米描一个点,跑个半马点的数量就是 2100 个。

把坐标数据放进一个静态页面里,真不是理智的方法,亏我好几次贴地图都是使用这种方法。

每次贴地图都需要操作好几个步骤,写篇博文略显麻烦,我觉得应该处理成传一个参数(活动 ID)即可返回跑步地图,后来我就将几个手动步骤写成脚本,直接显示地图。

st=>start: 开始
e=>end: 结束
op1=>operation: Nike+ API 获取数据
op2=>operation: 直接转换坐标
op3=>operation: 并使用地图 API 画线

st(right)->op1(right)->op2(right)->op3(right)->e

目前脚本用起来还算比较方便舒心,就是一旦 Nike+ API 有了变化,脚本就不能用,到时候再想办法解决。

实现流程

从前文不难看出,想要实现画跑步路线地图,大致流程如下:

st=>start: 开始
e=>end: 结束
op1=>operation: 获取数据
op2=>operation: 转换坐标
op3=>operation: 显示地图

st(right)->op1(right)->op2(right)->op3(right)->e

以上步骤缺一不可,获取数据是前提,转换坐标是必需,显示地图则是重点。

  1. Nike+ 官网本身就有跑步轨迹的显示,使用官网所用的 API 获取是准确的方法
  2. 转换坐标是我国多出的一步,Nike+ 所采用的是 WGS84 坐标系统,应将坐标点转换为地图 API 所采用的,路线才能在地图上正确显示,坐标转换在《百度地图坐标转换》已经有所提及
  3. 地图具体能折腾成什么样,还是取决于地图 JS API 以及前端技能的熟练程度

去年早些时候,去 Nike+ 开发者门户网站[1]学习,但发现自己并无法获取到相关的 API Keys。不过在网站里有个 TEST CONSOLE,登录后可获得一个临时授权。使用 GPS Data[2] 这个 API 便可以轻松获取相关的坐标数据。

后来,Nike+ 网站改版,官网的 API 也升级为 V3 版,在此之后的 activityId,前面所说的 API V1 没法再用,获取不到 GPS 数据,也找不着 API V3 的相关文档。那我也只能硬着头皮在官网按 F12 去研究,寻找获取坐标数据的 API。

最终,发现 Nike+ 获取单次活动的 API 是这样的:

https://api.nike.com/sport/v3/me/activity/{activityId}

其中 activityId 是单次活动的 ID,在 Nike+ 官网查看源码、或点开某次活动后在地址栏,都可以找到。

这个接口返回的数据挺详细,详细到感觉文件有点大,其中有 metric 所有类型名的数组 metric_types。需要详细数据时,可通过 metrics 这个参数来指定,默认指定 all 则代表获取所有数据。具体的实例如下(只取经纬坐标的详细数据):

https://api.nike.com/sport/v3/me/activity/e39a37be-d4e8-4ef7-82cc-0b255c0f2834?metrics=longitude,latitude

以上链接复制至浏览器打开,妥妥的提示未授权,返回去看官网那个请求头,发现字段 Authorization

使用 PHP cURL 加上这个授权码去请求,成功返回想要的数据。

<?php 
$options = array(
    CURLOPT_URL => 'https://api.nike.com/sport/v3/me/activity/e39a37be-d4e8-4ef7-82cc-0b255c0f2834?metrics=longitude,latitude',
    CURLOPT_HEADER => false,
    CURLOPT_RETURNTRANSFER => true,
    CURLOPT_HTTPHEADER => array('Authorization: Bearer ******')
);
$curl = curl_init(); 
curl_setopt_array($curl, $options);
$data = curl_exec($curl); 
curl_close($curl); 
?>

本以为这个授权码会很快过期,可没想到几个月还一直能用,干脆就不考虑如何获取授权码的问题。后来亦发现官网在 LocalStorage 也存了不同的授权码,只不过其生命只有一个小时。

参考资料

本文历史

  • 2017 年 04 月 20 日 完成初稿

最近更新

猜你喜欢