AWTK 開源串口屏開發(11) - 天氣預報

# AWTK 開源串口屏開發 - 天氣預報

天氣預報是一個很常用的功能,在很多設備上都有這個功能。實現天氣預報的功能,不能說很難但是也絕不簡單,首先需要從網上獲取數據,再解析數據,最后更新到界面上。

在 AWTK 串口屏中,內置了 XML/JSON/INI 等各種數據文件的模型,并支持用 HTTP/HTTPS 從網絡獲取數據。所以實現天氣預報非常簡單,不用編寫一行代碼即可實現天氣預報的功能。而且用同樣的方式,也可以實現其它功能,比如:股票行情、新聞、公交查詢、火車查詢、航班查詢、快遞查詢等等。

這里以 http://t.weather.sojson.com 提供的接口為例,來實現一個顯示天氣信息的應用程序。這個是免費的,無需注冊的 API,當然也有些限制,在實際工作中,你可以換成自己的接口。

它返回的數據是 JSON 格式的,如下所示:

{"message": "success 感謝又拍云 (upyun.com) 提供 CDN 贊助","status": 200,"date": "20240101","time": "2024-01-01 08:13:13","cityInfo": {"city": "天津市","citykey": "101030100","parent": "天津","updateTime": "08:01"},"data": {"shidu": "86%","pm25": 57.0,"pm10": 93.0,"quality": "良","wendu": "-7","ganmao": "極少數敏感人群應減少戶外活動","forecast": [],"yesterday": {"date": "31","high": "高溫 1℃","low": "低溫 -3℃","ymd": "2023-12-31","week": "星期日","sunrise": "07:30","sunset": "16:57","aqi": 35,"fx": "北風","fl": "2 級","type": "晴","notice": "愿你擁有比陽光明媚的心情"}}
}

AWTK 串口屏中的 json 模型,支持用下面的語法從網絡獲取數據,它會自動解析 JSON 數據,并生成一個模型,通過路徑可以引用模型中的數據。

json(url=http://t.weather.sojson.com/api/weather/city/101030100)

網上有很多天氣預報的接口,這里只是舉個例子,如果你有自己的接口,可以用自己的接口。

1. 功能

不用編寫代碼,實現天氣預報。

2. 創建項目

從模板創建項目,將 hmi/template_app 拷貝 hmi/weather 即可。

第一個項目最好不要放到其它目錄,因為放到其它目錄需要修改配置文件中的路徑,等熟悉之后再考慮放到其它目錄。路徑中也不要中文和空格,避免不必要的麻煩。

3. 制作界面

用 AWStudio 打開上面 weather 目錄下的 project.json 文件。里面有一個空的窗口,做出類似下面的界面。

在這里插入圖片描述

4. 添加綁定規則

4.1 城市

綁定屬性綁定規則說明
v-data:value{cityInfo.city}不同的 JSON API 需要使用不同的路徑,請根據具體的 JSON 數據填寫

4.2 溫度

綁定屬性綁定規則說明
v-data:value{data.wendu}不同的 JSON API 需要使用不同的路徑,請根據具體的 JSON 數據填寫

4.3 濕度

綁定屬性綁定規則說明
v-data:value{data.shidu}不同的 JSON API 需要使用不同的路徑,請根據具體的 JSON 數據填寫

4.4 PM2.5

綁定屬性綁定規則說明
v-data:value{data.pm25}不同的 JSON API 需要使用不同的路徑,請根據具體的 JSON 數據填寫

4.5 空氣質量

綁定屬性綁定規則說明
v-data:value{data.quality}不同的 JSON API 需要使用不同的路徑,請根據具體的 JSON 數據填寫

4.6 感冒指數

綁定屬性綁定規則說明
v-data:value{data.ganmao}不同的 JSON API 需要使用不同的路徑,請根據具體的 JSON 數據填寫

4.7 刷新按鈕

  • 刷新 按鈕的 點擊 事件綁定到 reload 命令。添加自定義的屬性 v-on:click,將值設置為 {reload}
綁定屬性綁定規則說明
v-on:click{reload}reload 命令是內置的命令,用于重新加載持久化的配置,命令要用英文大括號括起來。

4.8 窗口模型

  • 指定窗口的模型為 json, url 為 http://t.weather.sojson.com/api/weather/city/101030100
綁定屬性綁定規則說明
v-modeljson(url=http://t.weather.sojson.com/api/weather/city/101030100)不同的 JSON API 需要使用不同的 URL,可以換成自己的 URL

5. 初始化數據

6. 描述需要持久化的數據

7. 編譯運行

運行 bin 目錄下的 demo 程序:

在這里插入圖片描述

點擊 刷新 按鈕,可以重新加載數據,但是通常界面沒有變化,因為天氣數據沒有變化。

8. 注意

  • 本項目并沒有編寫界面相關的代碼,AWStudio 在 src/pages 目錄下生成了一些代碼框架,這些代碼并沒有用到,可以刪除也可以不用管它,但是不能加入編譯。

  • 完整示例請參考:demo_weather

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/718174.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/718174.shtml
英文地址,請注明出處:http://en.pswp.cn/news/718174.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

數字革命的浪潮:Web3如何改變一切

隨著數字技術的不斷發展,人類社會正迎來一場前所未有的數字革命浪潮。在這個浪潮中,Web3技術以其去中心化、安全、透明的特性,正在逐漸改變著我們的生活方式、商業模式以及社會結構。本文將深入探討Web3技術如何改變一切,以及其所…

volatile關鍵字的作用 以及 單例模式(餓漢模式與懶漢模式的區別及改進)

文章目錄 💡volatile保證內存可見性💡單例模式💡餓漢模式💡懶漢模式💡懶漢模式多線程版💡volatile防止指令重排序 💡volatile保證內存可見性 Volatile 修飾的變量能夠保證“內存可見性”以及防…

解決連接工具Mobaxterm連接錯誤Connection timed out----VMware里Linux端口號固定

錯誤:Connection timed out 原因: 沒有固定ip,網絡斷開,再次連接就是新的IP 解決: 再次測試連接,彈出這個就代表成功了

CUDA 中的線程組織

明朝那些事中有一句話:我之所以寫徐霞客是想告訴你,所謂千秋霸業萬古流芳,與一件事相比,其實都算不了什么,這件事情就是——用你喜歡的方式度過一生。 我們以最簡單的 CUDA 程序:從 GPU 中輸出 Hello World…

實現一個簡單的哈希映射功能

說在前面 🎈哈希表大家應該都經常用到吧,那么大家有沒有想過哈希表是怎么實現的呢?今天讓我們一起從一道簡單的題目來初步了解一個哈希表的簡單原理。 目的 不使用任何內建的哈希表庫設計一個哈希映射(HashMap)。 實…

bert 相似度任務訓練完整版

任務 之前寫了一個相似度任務的版本:bert 相似度任務訓練簡單版本,faiss 尋找相似 topk-CSDN博客 相似度用的是 0,1,相當于分類任務,現在我們相似度有評分,不再是 0,1 了,分數為 0-5,數字越大…

EasyRecovery易恢復2024免費文件數據恢復軟件下載

一、軟件概述 EasyRecovery易恢復中文文件數據恢復軟件是一款專為中文用戶設計的強大數據恢復工具。該軟件致力于幫助用戶從各種存儲設備中恢復因各種原因丟失的中文文件,如文檔、圖片、視頻、音頻等。憑借其核心技術和多年的研發經驗,EasyRecovery易恢…

C語言計算誤碼率

#include <stdio.h> #include <stdlib.h> bool dayintrue; //是否打印 int main(){ int i,k,g0; int n10,n20; int good0,bad0; double rate; (dayin)? printf("打印具體數據\n"):printf("不打印具體數據\n\n");…

STM32-SPI通信協議

串行外設接口SPI&#xff08;Serial Peripheral Interface&#xff09;是由Motorola公司開發的一種通用數據總線。 在某些芯片上&#xff0c;SPI接口可以配置為支持SPI協議或者支持I2S音頻協議。 SPI接口默認工作在SPI方式&#xff0c;可以通過軟件把功能從SPI模式切換…

Python·算法·每日一題(3月4日)最長公共前綴

題目 編寫一個函數來查找字符串數組中的最長公共前綴。 如果不存在公共前綴&#xff0c;返回空字符串 “”。 示例 示例 1&#xff1a; 輸入&#xff1a;strs ["flower","flow","flight"] 輸出&#xff1a;"fl"示例 2&#xff1a;…

【數據結構與算法】常見排序算法(Sorting Algorithm)

文章目錄 相關概念1. 冒泡排序&#xff08;Bubble Sort&#xff09;2. 直接插入排序&#xff08;Insertion Sort&#xff09;3. 希爾排序&#xff08;Shell Sort&#xff09;4. 直接選擇排序&#xff08;Selection Sort&#xff09;5. 堆排序&#xff08;Heap Sort&#xff09;…

【腦科學相關合集】有關腦影像數據相關介紹的筆記及有關腦網絡的筆記合集

【腦科學相關合集】有關腦影像數據相關介紹的筆記及有關腦網絡的筆記合集 前言腦模板方面相關筆記清單 基于腦網絡的方法方面數據基本方面 前言 這里&#xff0c;我將展開有關我自己關于腦影像數據相關介紹的筆記及有關腦網絡的筆記合集。其中&#xff0c;腦網絡的相關論文主要…

【錯誤處理】【Hive】【Spark】ERROR FileFormatwriter: Aborting job null.

問題背景 近日&#xff0c;使用 Spark 在讀寫 Hive 表時發生了報錯&#xff1a;Aborting job null&#xff0c;如果怎么都使用不了那張表的話&#xff0c;大概率是那張表有臟數據&#xff0c;導致整張表無法正常使用。 ERROR FileFormatwriter: Aborting job null.解決方法 …

SpringBoot 如何快速過濾出一次請求的所有日志?

前言 在現網出現故障時&#xff0c;我們經常需要獲取一次請求流程里的所有日志進行定位。如果請求只在一個線程里處理&#xff0c;則我們可以通過線程ID來過濾日志&#xff0c;但如果請求包含異步線程的處理&#xff0c;那么光靠線程ID就顯得捉襟見肘了。 華為IoT平臺&#x…

《自然》:人工智能在創造性思維方面超越人類

發散性思維被認為是創造性思維的指標。ChatGPT-4 在三項有151名人類參與的**發散思維測試中&#xff0c;**展現出比人類更高水平的創造力&#xff0c;結果顯示人工智能在創意領域持續發展。 發散性思維的特點是能夠針對沒有預期解決方案的問題提出獨特的解決方案&#xff0c;例…

TOMCAT的安裝與基本信息

一、TOMCAT簡介 Tomcat 服務器是一個免費的開放源代碼的Web 應用服務器&#xff0c;屬于輕量級應用服務器&#xff0c;在中小型系統和并發訪問用戶不是很多的場合下被普遍使用&#xff0c;是開發和調試JSP 程序的首選。對于一個初學者來說&#xff0c;可以這樣認為&#xff0c…

IO 與 NIO

優質博文&#xff1a;IT-BLOG-CN 一、阻塞IO / 非阻塞NIO 阻塞IO&#xff1a;當一條線程執行read()或者write()方法時&#xff0c;這條線程會一直阻塞直到讀取到了一些數據或者要寫出去的數據已經全部寫出&#xff0c;在這期間這條線程不能做任何其他的事情。 非阻塞NIO&…

記錄踩過的坑-macOS下使用VS Code

目錄 切換主題 安裝插件 搭建Python開發環境 裝Python插件 配置解釋器 打開項目 打開終端 切換主題 安裝插件 方法1 方法2 搭建Python開發環境 裝Python插件 配置解釋器 假設解釋器已經通過Anaconda建好&#xff0c;只需要在VS Code中關聯。 打開項目 打開終端

ArmV8架構

Armv8/armv9架構入門指南 — Armv8/armv9架構入門指南 v1.0 documentation 上面只是給了一個比較好的參考文檔 其他內容待補充

網絡-httpclient調用https服務端繞過證書的方法

httpclient調用https服務端繞過證書的方法 在日常開發或者測試中&#xff0c;通常會遇到需要用httpclient客戶端調用對方http是服務器的場景&#xff0c;由于沒有證書&#xff0c;所以直接是無法調用的。采用下面的方法可以繞過證書驗證&#xff1a; TrustManager[] trustAll…