成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

深入淺出學習eTs—(二十二)天氣語音預報

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

??想了解更多關于開源的內容,請訪問:??

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??

一、需求分析

本章節我們基于上節課的內容(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

#創作者激勵##深入淺出學習eTs#(二十二)天氣語音預報-開源基礎軟件社區

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

1、數據分析

#創作者激勵##深入淺出學習eTs#(二十二)天氣語音預報-開源基礎軟件社區

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

#創作者激勵##深入淺出學習eTs#(二十二)天氣語音預報-開源基礎軟件社區

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

  • “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)天氣圖標

#創作者激勵##深入淺出學習eTs#(二十二)天氣語音預報-開源基礎軟件社區

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

#創作者激勵##深入淺出學習eTs#(二十二)天氣語音預報-開源基礎軟件社區

使用image控件進行生成。

#創作者激勵##深入淺出學習eTs#(二十二)天氣語音預報-開源基礎軟件社區

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

(2)輸入框

同上期內容。

#創作者激勵##深入淺出學習eTs#(二十二)天氣語音預報-開源基礎軟件社區

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=*******&versinotallow=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 + '\r\n' + '天氣:' + Get_TQ +'\r\n'+ '溫度:' + Get_dq +'℃ '+Get_wdd+'-'+Get_wdg+'\r\n' + '溫馨提示:'+Get_KQZ

(3)音頻播放部分

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

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

六、演示

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

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

#創作者激勵##深入淺出學習eTs#(二十二)天氣語音預報-開源基礎軟件社區

#創作者激勵##深入淺出學習eTs#(二十二)天氣語音預報-開源基礎軟件社區

??想了解更多關于開源的內容,請訪問:??

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??

責任編輯:jianghua 來源: 51CTO 開源基礎軟件社區
相關推薦

2022-12-01 08:20:00

2022-12-01 08:25:23

eTsTCP聊天室

2009-11-30 16:46:29

學習Linux

2021-03-16 08:54:35

AQSAbstractQueJava

2011-07-04 10:39:57

Web

2019-01-07 15:29:07

HadoopYarn架構調度器

2017-07-02 18:04:53

塊加密算法AES算法

2012-05-21 10:06:26

FrameworkCocoa

2021-07-20 15:20:02

FlatBuffers阿里云Java

2022-09-26 09:01:15

語言數據JavaScript

2009-06-18 12:59:39

Criteria Qu深入淺出Hiberna

2012-02-21 13:55:45

JavaScript

2022-01-11 07:52:22

CSS 技巧代碼重構

2018-11-09 16:24:25

物聯網云計算云系統

2019-11-11 14:51:19

Java數據結構Properties

2022-11-09 08:06:15

GreatSQLMGR模式

2022-12-02 09:13:28

SeataAT模式

2022-10-31 09:00:24

Promise數組參數

2019-12-04 10:13:58

Kubernetes存儲Docker

2009-11-18 13:30:37

Oracle Sequ
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 黑人巨大精品欧美一区二区免费 | 日韩美女在线看免费观看 | 成人三级视频在线观看 | 麻豆视频国产在线观看 | 中文字幕乱码亚洲精品一区 | 国产一区二区 | 精品一区二区三区在线视频 | 国产一区91精品张津瑜 | 不卡一二三区 | 欧美成人a∨高清免费观看 老司机午夜性大片 | 久久亚洲国产精品日日av夜夜 | 99久久视频| 日韩欧美专区 | 二区不卡| 国产免费色 | 欧美成人在线网站 | 综合在线视频 | 国产成人精品久久二区二区 | 欧美激情一区二区三区 | 亚洲 中文 欧美 日韩 在线观看 | 在线观看成年视频 | 色综合网站 | 亚洲精品一区中文字幕乱码 | 国产精品福利在线 | 日韩伦理一区二区 | 中文字幕高清免费日韩视频在线 | 成人精品视频免费 | 成人国产免费视频 | 一区二区三区四区在线视频 | 一区二区视频 | 国产精品一区二区在线 | 欧美一级久久 | 91久久久久 | 最近日韩中文字幕 | 精品国产免费人成在线观看 | 天天欧美| 亚洲精品国产成人 | 成年人免费在线视频 | 国际精品久久 | 成人在线精品视频 | 日韩欧美在线视频播放 |