一块自制自行车码表从B站火到GitHub,稚晖君点赞,网友催量产

JAVA葵花宝典

共 1934字,需浏览 4分钟

 ·

2021-10-14 22:13

5691eee7baccb401c589c33cc5583bd2.webp

丰色 发自 凹非寺
量子位 报道 | 公众号 QbitAI

民间又有高手“出没”:

一位“技术宅”自制的自行车码表在B站火了,短短几天引来20多万人围观!

a5beb7c69e36d175efe169169d259789.webp

速度、距离、时间、卡路里、航向显示的记录功能自不用多提,还可显示经纬度和海拔。

它还配有离线地图,可显示你的实时位置与骑行轨迹

2ae539619e4a01ec3b524ece7f0e27e4.webp

在汽车、高铁上也能测速!

545268f7ec84578bed7d7b48c79945c6.webp

切换界面查看电量、骑行记录、GPS定位、传感器等系统数据,相当丝滑:

4d1d929020888a1d5be447a2f0012b45.webp

再看细节上,UI设计可是比市面上不少码表都要高级!(佳明:你直接报我身份证得了)

这要是告诉我它是某个大牌而非自制的(除了壳很明显以外),我可能都信了。

网友们也是纷纷respect,称赞它打爆那些溢价离谱的码表:

ee71247cd7f70dc1681e827fbfc87d33.webp

“完成度离谱”,是不是很想要链接?

1a3de3c3c429e3cbc6973eb4cac012ca.webp

好家伙,连稚晖君都被吸引过来了(后来佳明也现身评论区“自黑”,见后文)

6664a8b92e37a650efe32ef20bcbfc30.webp

诶?稚晖君的真·自行车和这个码表是不是可以搭配使用?

a319bf603a6fdffad21bcaa480200179.webp

除了在B站上很火,这个码表项目也登上了今日GitHub热榜:

53430cbdf59238b837eba84a39d35bbb.webp

而据网友粗略估算这个码表的硬件成本大概不到300,如此优秀的它,是如何DIY出来的呢?

如何DIY一个自行车码表

X-TRACK软件架构示意图如下:由HAL、Framework 和 APP 三层组成,Framework为核心。

2f1da1f97069c2fa38820640c0839379.webp


HAL层负责底层芯片驱动和传感器原始数据获取;

Framework又包括三个模块,分别负责图形渲染、页面生命周期管理和消息分发处理。

其中消息框架模块提供数据的分发和处理。

使用订阅发布机制,将HAL层的接收到的传感器数据发布,转发给对应的订阅者进行数据处理。

以GPS为例,GPS数据处理节点每秒读取一次卫星数据,然后发起publish,由消息框架将 GPS 数据推送给订阅者。

在运动数据处理节点中订阅GPS数据。在收到GPS数据之后,运动数据处理节点根据 GPS 数据计算总里程,平均速度等信息。在表盘页面中,拉取运动数据节点信息,将其显示在表盘页面中。

ps. 地图软件为GPXSee。

实现主要有7步:

1、首先是硬件设计

用AD(Altium Designer)进行PCB板线路设计:

b2ed607d160e6bcb9bc9b8adc3e062ff.webp

电路图和PCB文件也可以在GitHub详细查看。

2、然后就是被大家纷纷夸赞的UI设计:

设计软件是Adobe AI。

0fe16de69dd99ab052eb0173fdcaa819.webp

3、接着在3ds MAX上进行外壳设计:

2dcff280aadf234be20a281619ec787a.webp

4、再然后就是软件设计了:

编程语言为C++:

b015a03c2270adb63b8dac7acc1effbf.webp

5、再使用模拟器直接在PC上模拟效果。

99087c07b4fa7d3f7c18d1255fec320a.webp

码表的图形界面采用了免费开源的GUI图形库LVGL

成品使用了许多LVGL提供的基础控件,例如在地图页面的轨迹显示中使用了line控件,地图显示使用了image控件,在表盘页面的页面切换选择,使用了button控件。

6、调试调试,没问题就可进行编译下载。

这里用的是Keil

9ac4191f0328e85dc4bb55acc0dd00d0.webp

7、最后,将最终程序烧录到单片机(AT32F403ACGU7)上运行,再连上ST-Link进行调试。

成功!

a9da335c005c5bb0a87c748025f615b4.webp


另外可能很多人不知道,UP主用的这个AT32系列MCU是国产设计(重庆雅特力),可替代意法半导体STM32F103系列,主频更高、RAM更大。

全部硬件配置如下:

2dfcdb4009ff4891f087c9e46b36eb40.webp

内存有32GB,存下一个1GB多的北京地图不是事儿。

另外,除了开头提到的功能以外,它还支持地图缩放、计步功能、导出标准GPX格式的轨迹、RTC自动根据GPS校准、掉电自动保存数据(JSON格式文件)、不过续航为4小时(持续工作,始终亮屏)……

907f8d902c855598710f2004d5d264e5.webp

整个设计的硬件和软件部分都已开源

连“竞品”佳明都来点赞

怎么样?学会(废)了吗?

不少围观群众觉得这样一个UI颜值爆表、功能丰富的自行车码表如果真的能有厂商合作生产的话,那还有佳明这些产品什么事儿ee94ab6d0ff69cf8fd4c118b6e39f1f7.webp

有人在评论区@Garmin佳明,没想到还真把它引过来了:这下好了,连“竞品”都给X-TRACK点赞

b6966d4a97181a675c4ca2705df9e207.webp

有人还算了一笔账,在某宝按教程买这些配件一共需要不到300元,比佳明上千的价格是便宜不少(虽然续航能力低一点)

fc214041460973dd9da9b7bb675076d6.webp

催量产的网友真的非常非常多,不过真要商业化的话,除了续航能力,有自行车骑行爱好者认为还需支持ant+、踏频、心率、功率设备的连接、防尘防水等功能,以及考虑现在的屏幕在阳光下的能见度等问题。

7ecf38ad97fd1e0f4bf879ebaacf3f08.webp

不知道未来,X-TRACK还会不会被继续增加或改进呢?

毕竟毕业于电子信息专业的UP主说自己也算半个自行车爱好者。

最后,除了这个梦幻般的自行车码表,他还用STM32自制过智能手表、航模遥控器(被网友称赞可以直接拿来卖的程度)

31a71797245bc19b542f3711be9dd347.webp

视频链接:
https://www.bilibili.com/video/BV1GB4y1K7VV

开源地址:
https://github.com/FASTSHIFT/X-TRACK

软件设计介绍:
https://mp.weixin.qq.com/s/rCtmW7tawr7zRIuMK1l5Iw

d13951f5aec7c0c7261d1bc678b47f23.webp

浏览 42
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报