# e-calender **Repository Path**: xueqinglin_admin/e-calender ## Basic Information - **Project Name**: e-calender - **Description**: 基于AB32VG1开发板和RT-Thread系统 - **Primary Language**: Unknown - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 4 - **Created**: 2021-12-21 - **Last Updated**: 2021-12-21 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # 基于AB32VG1的墨水屏智能日历 ## 项目背景 本项目是【RT-Thread x RISC-V 应用创新大赛】参赛项目之一,大赛活动页面: [RT-Thread X RISC-V 创新应用设计大赛 (elecfans.com)](http://www.elecfans.com/project/contest/2021RTThread/index.html) 作品上传内容应包含: 1.应用的背景,实现功能,开发板或RT-Thread使用情况概述,硬件框架,软件框架说明,软件模块说明,作品完整图片,视频演示效果,代码地址。 2.参赛者比赛项目代码须托管到Gitee(如无可上传到附件)。 ## 项目简介 本项目解决了什么问题? 1. 传统纸质日历需要手动翻页,容易遗忘; 2. 传统纸质日历仅有静态信息,没有天气、时间等信息,内容较为单调; 3. 传统纸质日历一次购买后样式不能更换,比较无趣(不在乎的可以买新的); 本项目有什么创新点(实现了哪些功能)? 1. 相比纸质日历,无需手动翻页; 2. 相比纸质日历,可以显示实时天气信息; 3. 相比LCD/OLED屏的同类产品,电子墨水屏的功耗更低,更节能环保; ## 硬件部分 本项目主要包括五个硬件模块: 1. AB32VG1开发板,作为主控制器控制其他外设; 2. ESP8266 WiFi模块,用于联网获取时间和实时天气信息; 3. 微雪的Arduino墨水屏扩展板,用于驱动墨水屏,同时带有一个128KB的SPI RAM芯片(用于作为显存),和一个T-Flash卡槽(没用到); 3. 4.2英寸三色墨水屏,分辨率400x300,用于显示画面,一帧画面至少需要占用45KB 内存(400 x 300 x 3 / 8 = 45000); 3. W25Q128闪存模块,容量16MB,用于存储中文字体; ### 硬件模块间连接 五个硬件模块之间的整体连接关系如下图: ![模块连接关系](pic/mod-con.png) ### 开发板引脚分配 开发板和外设的引脚连接关系(电源部分): ![外设供电](pic/pow-sup.png) 主要使用到的资源,以及开发板和外设的引脚连接关系(控制部分): ![引脚连接关系](pic/pin-map.png) 具体使用情况说明: 1. RTC * 用于保存当前时间和日期,以及时间的自动递增; 2. UART1 * 连接ESP-01S模块,用于实现联网获取时间和实时天气信息; 3. SPI1 * 连接墨水屏扩展板,用于和上面的SRAM芯片、墨水屏芯片通信; 4. GPIO * 连接墨水屏扩展板上的RAM_CS,用于输出SRAM的片选信号 * 连接墨水屏扩展板上的EPD_CS,用于输出墨水屏的片选信号; * 连接墨水屏扩展板上的EPD_DC,用于输出墨水屏的数据/命令信号; * 连接墨水屏扩展板上的EPD_RST,用于输出墨水屏的复位信号; * 连接墨水屏扩展板上的EPD_BUSY,用于墨水屏的繁忙状态的输入; * 连接W25Q128模块的CS,用于输出闪存芯片的片选信号; * 开发板自带的三个按键,用于作为输入按键; 5. 3V3/GND * 连接ESP-01S模块,用于向ESP8266芯片供电; * 连接墨水屏扩展板,用于向SRAM和墨水屏供电; * 连接W25Q128模块,用于向闪存芯片供电; ## 软件部分 本项目的软件部分基于RT-Thread物联网操作系统,除了本项目开发的业务逻辑代码外,还使用了一些RT-Thread 内核API、一些RT-Thread软件包,以及一些三方组件,下面分别介绍。 主代码仓:https://gitee.com/swxu/e-calender.git 下载命令:`git clone --recursive https://gitee.com/swxu/e-calender.git ` 部分组件通过git submodule引用了其他代码仓,具体见`.gitmodules`文件; ### 业务代码 本项目开发的业务代码位于`applications`目录下,具体文件功能如下: 1. amap_location_api 高德IP定位API; 2. amap_weather_api 高德天气预报API; 3. chinese_date_api 农历查询API; 4. flash_init.c 闪存分区挂载; 5. http_api_utils http工具函数; 6. hzk16 HZK16汉字字体相关接口; 7. hzk16_data HZK16汉字字体数据; 8. hzk16_setup 将HZK16字体安装到闪存分区; 9. key_task 按键扫描任务; 10. kvdb 封装了FlashDB里面的KVDB,使用更容易; 11. main 入口; 12. network_task 网络任务,主要负责查询农历(比较慢); 13. time_utils 时间处理工具函数; 14. ui_consts UI常量; 15. ui_draw UI绘制; 16. ui_task UI任务; ### RT-Thread软件包 本项目使用到的RT-Thread软件包位于`packages`目录下: 1. bluetrum_sdk * RT-Thread Studio创建项目时自带,包含了二进制的`libhal.a`; 2. at_device * 提供ESP8266 AT命令构造和响应解析功能,实现联网; * **修改**:将所有sscanf都替换为atoi和strtol了(测试过程中间发现,每次send/recv会crash在sscanf里面); * 修改后代码仓:https://gitee.com/swxu/fal.git 3. netutils * 提供网络时间协议(NTP)的实现,实现从网络获取时间、设置时间; 4. webclient * 提供了超文本传输协议(HTTP)客户端的实现,用于天气查询请求的发送和接收; 5. cJSON * 一个轻量级的纯C实现的JSON字符串解析库,用于解析天气查询响应的JSON字符串; * 未做修改 6. FlashDB * 一个嵌入式数据库,提供了键值数据库(KVDB)和时序数据库(TSDB)两类API,同时提供了一些msh的测试命令; * **修改**:开启了DEBUG日志,bench命令中的KV测试次数改为100 * 代码仓:https://gitee.com/swxu/FlashDB.git 7. fal * 闪存抽象层,FlashDB依赖的软件包,提供了闪存操作的封装和抽象,同时提供了一些msh的测试命令; * **修改**:添加了w25q128的移植文件; * 代码仓:https://gitee.com/swxu/fal.git 8. gbk2utf8 * GBK和UTF8互相转换,HTTP API返回的汉字是UTF8编码的; ### 其他三方软件包 本项目使用到的其他三方软件均来自外设模块供应商,代码放在`board`目录下,包括: 1. epaper * 微雪墨水屏扩展板驱动软件包,来自微雪的[E-Paper_Shield]([E-Paper Shield - Waveshare Wiki](https://www.waveshare.net/wiki/E-Paper_Shield))页面; * **删除**了无用的代码,包括不是4.2寸屏幕的代码、以及SD卡驱动; * **修改**了GPIO相关的代码,改为用RT-Thread的pin驱动接口; * **修改**了SPI相关的代码,改为用重新实现的bsp_spi接口; * **添加**了基于RT-Thread finsh的墨水屏测试程序(绘制棋盘格、全屏填充、输出引脚测试),可以在shell模式下通过命令调用执行; 2. w25qxx * W25Q128 闪存驱动,来自微雪的[W25QXX DataFlash Board](https://www.waveshare.net/wiki/W25QXX_DataFlash_Board)页面; * **修改**了GPIO向代码,改为使用RT-Thread的pin驱动接口; * **修改**了SPI相关代码,改为用重新实现的bsp_spi接口; * **添加**了基于RT-Thread msh的RAM测试程序(字模式、页模式、流模式),可以在shell模式下通过命令调用执行; 3. **重新实现**的bsp_spi.h和bsp_spi.c * 使用了greedyhao大佬提供的硬件SPI初始化代码 * SPI接收和发送,使用了Bluetrum技术群中的SDK_AB53XX_V061_20190103.zip里面的相关代码; * greedyhao大佬提供的驱动,实现部分全部在libhal.a中,暂时不太好移植到RT-Thread驱动框架上;