色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

深入淺出學習eTs之天氣語音預報

Harmony&嵌入式學習 ? 來源:Harmony&嵌入式學習 ? 作者:Harmony&嵌入式學 ? 2023-05-13 13:31 ? 次閱讀

一、需求分析

本章節我們基于上節課的內容(HTTP協議),在上節課的基礎上進行延伸,方便我們去理解協議,以及引入在線語音播報的功能實現以下功能:

文字輸入城市

獲取城市的天氣狀況

語音播放天氣情況

圖標更換

二、控件介紹

(1)Video

用于播放視頻文件并控制其播放狀態的組件。

說明:

該組件從API Version 7開始支持。后續版本如有新增內容,則采用上角標單獨標記該內容的起始版本。

權限列表

使用網絡視頻時,需要申請權限ohos.permission.INTERNET。具體申請方式請參考權限申請聲明。

子組件

接口

Video(value: {src?: string | Resource, currentProgressRate?: number | string | PlaybackSpeed, previewUri?: string | PixelMap | Resource, controller?: VideoController})

參數

參數名 參數類型 必填 參數描述
src string | Resource 視頻播放源的路徑,支持本地視頻路徑和網絡路徑。 支持在resources下面的video或rawfile文件夾里放置媒體資源。 支持dataability://的路徑前綴,用于訪問通過Data Ability提供的視頻路徑,具體路徑信息詳見DataAbility說明。 說明: 視頻支持的格式是:mp4、mkv、webm、TS。
currentProgressRate number | string | PlaybackSpeed8+ 視頻播放倍速。 說明: number取值僅支持:0.75,1.0,1.25,1.75,2.0。 默認值:1.0 | PlaybackSpeed.Speed_Forward_1_00_X
previewUri string | PixelMap8+ | Resource 視頻未播放時的預覽圖片路徑。
controller VideoController 設置視頻控制器。

三、協議介紹

(1)天氣API

wKgZomRfIKqAWHltAAJotDt8eTk860.png

和上一期一樣,本系統依然是使用HTTP來實現的,這里使用了天氣API來實現,通過輸入地區即可獲得很多天氣數據

1.數據分析

wKgaomRfIKuAA1_EAAJv14Qb8CM659.png

未處理的數據如上,經過json分析后得到下圖

wKgZomRfIKuAGv0VAAHf52Q5Iy0999.png

在這個基礎上使用上節課的內容對文本進行拆分,比如我們要獲得當前溫度

? “tem”: “6”,

其數據是這樣的,我們觀察前面和后面"tem":“6”,“tem1”:“13”,使用掐頭去尾法可以得到當前溫度6℃

2.數據概括

本次不打算全部顯示,這里挑選幾個進行展示

當前溫度

當前天氣

當日溫度區間

溫馨小提示

(2)語音轉文字API

這里選擇使用搜狗的語音轉文字API,url如下

https://fanyi.sogou.com/reventondc/synthesis?text=一鍵三連&speed=1&lang=zh-CHS&from=translateweb&speaker=6

text 要轉換的文本

speed 語速 1~?(我測試到15都還可以) 越大,語速越慢

lan 語言類型 lan=en 英文 lan = zh-CHS 中文

from 哪種方式請求的

speaker 語音類型 1-6的數字

四、UI設計

(1)天氣圖標

wKgaomRfIKyAWuTFAAF0IUsAeg8230.jpg


尋找資源如上,但本次內容只選擇云、雨、晴三個經典天氣來分析,將三個圖標放入目錄下

wKgZomRfIK2AE_PTAACxcynlEnE083.png

使用image控件進行生成

wKgaomRfIK2AY1QMAAB0hsUSSrc452.png

Image(this.IMAGE_URL)
          .width(200)
          .height(200)
          .objectFit(ImageFit.Fill)

復制

(2)輸入框

同上期內容

wKgZomRfIK6AVFPpAAEG364w5m0196.png

        TextInput({ placeholder: '請輸入要查詢的城市', controller: this.controller })
          .placeholderColor(Color.Grey)
          .placeholderFont({ size: 25, weight: 400 })
          .caretColor(Color.Blue)
          .width('90%')
          .height(80)
          .margin(20)
          .fontSize(25)
          .fontColor(Color.Black)
          .onChange((value: string) => {
            this.IN_Value = value
            console.log(JSON.stringify(this.IN_Value));
          })

復制

(3)按鈕和顯示框

 Button('查  詢')
          .width('60%')
          .height(60)
          .fontSize(30)
          .onClick(() => {
     
 		 });
Blank()
          .height(20)
        Text(this.Out_Value)
          .fontSize(25)
          .width('80%')
          .height(300)
          .textAlign(TextAlign.Center)
          .border({ width: 1 })

(4)Vedio設計

在這里我們選擇取巧的方式,使用vedio播放網絡視頻,只需要隱藏控制按鈕,同時將控件的寬度和高度設置為1即可

音頻試聽:https://tts.youdao.com/fanyivoice?word=一鍵三連&le=zh&keyfrom=speaker-target

大家復制上面的url放進瀏覽器里面可用聽到

Video({
          src: this.videoSrc,
          controller: this.v_controller,
        })
          .controls(false)
          .onStart(() => {
            console.info('onStart')
          })
          .width(1)
          .height(1)

五、代碼設計

(1)HTTPS獲得數據部分

我這里將我注冊的API放上來了,key部分隱藏了,不能直接使用,大家去天氣API那里申請個帳號就行,免費使用2000次

          httpRequest.request(
              // 填寫http請求的url地址,可以帶參數也可以不帶參數。URL地址需要開發者自定義。請求的參數可以在extraData中指定
              "https://v0.yiketianqi.com/api?appid=56959347&appsecret=*******&version=v61&unescape=1&city=" + this.IN_Value,
              {
                method: http.RequestMethod.GET, // 可選,默認為http.RequestMethod.GET
                connectTimeout: 60000, // 可選,默認為60s
                readTimeout: 60000, // 可選,默認為60s
              }, (err, data) => {
              if (!err) {
                // data.result為http響應內容,可根據業務需要進行解析

                var Get_Return = data.result.toString()
                console.log(JSON.stringify(Get_Return));

(2)數據拆分

該部分將返回的內容進行拆分為五個單元

//天氣 當前溫度 溫度區間 空氣質量
let Get_TQ = ''
let Get_dq = ''
let Get_wdg = ''
let Get_wdd = ''
let Get_KQZ = ''
                var Begin_Num =  Get_Return.indexOf('"wea":"')
                var Last_Num = Get_Return.lastIndexOf('","wea_img"')
                var Get_TQ = Get_Return.substring(Begin_Num+7,Last_Num)

                var Begin_Num =  Get_Return.indexOf('"tem":"')
                var Last_Num = Get_Return.lastIndexOf('","tem1"')
                var Get_dq = Get_Return.substring(Begin_Num+7,Last_Num)


                var Begin_Num =  Get_Return.indexOf('"tem1":"')
                var Last_Num = Get_Return.lastIndexOf('","tem2"')
                var Get_wdg = Get_Return.substring(Begin_Num+8,Last_Num)

                var Begin_Num =  Get_Return.indexOf('"tem2":"')
                var Last_Num = Get_Return.lastIndexOf('","win"')
                var Get_wdd = Get_Return.substring(Begin_Num+8,Last_Num)

                var Begin_Num =  Get_Return.indexOf('","air_tips":"')
                var Last_Num = Get_Return.lastIndexOf('","alarm":')
                var Get_KQZ = Get_Return.substring(Begin_Num+14,Last_Num)

                console.log(JSON.stringify(Get_TQ));
                console.log(JSON.stringify(Get_dq));
                console.log(JSON.stringify(Get_wdg));
                console.log(JSON.stringify(Get_wdd));
                console.log(JSON.stringify(Get_KQZ));
             this.Out_Value = '城市:' + this.IN_Value + 'rn' + '天氣:' + Get_TQ +'rn'+ '溫度:' + Get_dq +'℃  '+Get_wdd+'-'+Get_wdg+'rn' + '溫馨提示:'+Get_KQZ

(3)音頻播放部分

//            this.videoSrc = 'http://tts.youdao.com/fanyivoice?word=****&le=zh&keyfrom=speaker-target'
//            this.v_controller.start()

將****部分替換成想播報的內容就行

六、演示

注意:音頻部分我嘗試了模擬器和遠程真機都不行,聲音沒法傳遞過來,但是實際效果是有的,這個我之前做過真機

這里選擇使用上海和安陽進行演示(任意城市都可以)

wKgaomRfIK6AZOIpAAgaJIhLpL0069.gifwKgZomRfIK-ANiW8AAhlWtg0rus173.gif
編輯:黃飛

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • ets
    ets
    +關注

    關注

    0

    文章

    20

    瀏覽量

    1630
  • https
    +關注

    關注

    0

    文章

    52

    瀏覽量

    6203
  • OpenHarmony
    +關注

    關注

    25

    文章

    3744

    瀏覽量

    16536
收藏 人收藏

    評論

    相關推薦

    #深入淺出學習eTs#(八)“猜大小”小游戲

    本項目Gitee倉地址:[深入淺出eTs學習: 帶大家深入淺出學習eTs (gitee.com)
    的頭像 發表于 05-17 15:08 ?1074次閱讀
    #<b class='flag-5'>深入淺出</b><b class='flag-5'>學習</b><b class='flag-5'>eTs</b>#(八)“猜大小”小游戲

    #深入淺出學習eTs#(十)藍藥丸還是紅藥丸

    本項目Gitee倉地址: 深入淺出eTs學習: 帶大家深入淺出學習eTs (gitee.com)
    的頭像 發表于 05-17 15:07 ?997次閱讀
    #<b class='flag-5'>深入淺出</b><b class='flag-5'>學習</b><b class='flag-5'>eTs</b>#(十)藍藥丸還是紅藥丸

    深入淺出Android

    深入淺出Android
    發表于 08-20 10:14

    ARM7 深入淺出學習

    深入淺出ARM7 LPC213x_214 學習
    發表于 12-04 17:28

    深入淺出Android

    深入淺出Android
    發表于 04-26 10:48

    深入淺出排序學習使用指南

    深入淺出排序學習:寫給程序員的算法系統開發實踐
    發表于 09-16 11:38

    #深入淺出學習eTs#(一)模擬器/真機環境搭建

    本項目的Gitee倉地址: 深入淺出eTs學習: 帶大家深入淺出學習eTs (gitee.com
    發表于 12-24 13:02

    #深入淺出學習eTs#(七)判斷密碼是否正確

    本項目Gitee倉地址:深入淺出eTs學習: 帶大家深入淺出學習eTs (gitee.com)一
    發表于 12-29 10:06

    深入淺出Cortex-M0學習資料

    深入淺出Cortex-M0學習資料
    發表于 06-18 10:50 ?0次下載
    <b class='flag-5'>深入淺出</b>Cortex-M0<b class='flag-5'>學習</b>資料

    STM32深入淺出新手篇

    STM32深入淺出新手篇,很好的單片機學習資料。
    發表于 03-21 17:43 ?128次下載

    深入淺出學習250個通信原理資源下載

    深入淺出學習250個通信原理資源下載
    發表于 04-12 09:16 ?28次下載

    深入淺出學習低功耗藍牙協議棧

    深入淺出學習低功耗藍牙協議棧
    發表于 06-23 10:35 ?57次下載

    深入淺出學習eTs(一)模擬器/真機環境搭建

    本項目的Gitee倉地址: 深入淺出eTs學習: 帶大家深入淺出學習eTs (gitee.com
    的頭像 發表于 05-13 13:17 ?1768次閱讀
    <b class='flag-5'>深入淺出</b><b class='flag-5'>學習</b><b class='flag-5'>eTs</b>(一)模擬器/真機環境搭建

    深入淺出學習eTs(七)如何判斷密碼是否正確

    本項目Gitee倉地址: 深入淺出eTs學習: 帶大家深入淺出學習eTs (gitee.com)
    的頭像 發表于 05-13 13:20 ?953次閱讀
    <b class='flag-5'>深入淺出</b><b class='flag-5'>學習</b><b class='flag-5'>eTs</b>(七)如何判斷密碼是否正確

    深入淺出學習eTs九宮格密碼鎖功能實現

    本項目Gitee倉地址:深入淺出eTs學習: 帶大家深入淺出學習eTs (gitee.com)
    的頭像 發表于 05-13 13:25 ?1651次閱讀
    <b class='flag-5'>深入淺出</b><b class='flag-5'>學習</b><b class='flag-5'>eTs</b><b class='flag-5'>之</b>九宮格密碼鎖功能實現
    主站蜘蛛池模板: 成人bt下载 | 伊人久久综合谁合综合久久 | 国精产品一区二区三区 | 漂亮的保姆3集电影免费观看中文 | 色欲AV亚洲永久无码精品麻豆 | 欧美高清视频www夜色资源网 | 日本A级作爱片金瓶双艳 | 国产国产成年在线视频区 | 亚洲精品乱码久久久久久直播 | 免费鲁丝片一级在线观看 | 国产在线精彩视频 | 亚洲欧美日韩精品自拍 | 亚洲欧美一区二区成人片 | 在线中文字幕网站 | 无人影院在线播放 | 日韩精品久久日日躁夜夜躁影视 | 亚洲精品久久国产高清 | 中文字幕一区二区三区在线不卡 | 久久毛片网站 | 蜜桃成熟时2电影免费观看d | 69国产精品人妻无码免费 | 色琪琪无码成人AV视频 | 杨幂被视频在线观看 | 亚洲AV久久无码精品蜜桃 | 疯狂做受XXXX高潮欧美日本 | 丰满人妻妇伦又伦精品APP国产 | 国产亚洲精品久久久久久鸭绿欲 | 99香蕉精品视频在线观看 | 国产伊人自拍 | 免费精品国产人妻国语麻豆 | 久久久久久久久久综合情日本 | 伦理片飘花免费影院 | 一级特黄aa大片欧美 | 国产啪视频在线播放观看 | 超碰免费碰免费视频 | 69国产精品人妻无码免费 | 精品夜夜澡人妻无码AV蜜桃 | 忘忧草在线社区WWW日本直播 | 曰本少妇高潮久久久久久 | 男人把女人桶到爽免费看视频 | 精品国产高清自在线看 |