2025-03-25 发布 浏览:0 次
怎样用Go语言实现远程语音呢?
本文描述了使用Go语言调用HTTP接口,实现远程语音,。
可选用产品:可根据实际场景需求,选择对应的规格
序号 | 设备名称 | 厂商 |
---|---|---|
1 | 智能语音喇叭3 | 友友物联 |
2 | 智能语音音柱|10W |
下面以每款产品为例,用Go语言编程实现远程语音:
1. 智能语音喇叭3
远程语音播报、语音提醒、语音通知、语音警报;
广泛应用于各种线下服务的订单提醒、线下流程的语音提醒等;
无需上传录音、无需后台设置;
直接通过HTTP接口推送文本,即可实时远程语音播报;
真人发声、语调自然柔和,支持男、女音色;
双发声单元、音量大;
支持远程音量、音色、语调、语速设置;
支持多音字、支持数字(数值、金额、手机号等)读法;
内置铃声、提示音、警示音各5种;
可远程控制环状LED灯带颜色,同时实现视觉提醒;
可无缝接入各种OA、ERP、SaaS软件和低代码平台中;
即插即用,无需安装、走线;
使用Go语言调用HTTP接口控制智能语音喇叭3的代码
以设备控制(向设备下发命令)为例
全部接口文档复制
package main
import (
"fmt"
"io/ioutil"
"net/http"
"net/url"
"strings"
)
func main() {
body, err := request()
if err != nil {
fmt.Println(err)
return
}
fmt.Println(string(body))
}
func request() ([]byte, error) {
uri := "https://api.yoyoiot.cn/{AppID}/device/control/?sign={sign}&ts={ts}"
payload := url.Values{}
payload.Set("device", "设备ID")
payload.Set("order", "命令")
/*
device[字符串]:设备唯一ID,可传多个,可在控制台可查看,也可通过接口拉取;
order[json字符串]:命令,取值参考:
1. 音量 - 可用值[0(0),1(1),2(2),3(3),4(4),5(5),6(6),7(7),8(8),9(9)]
示例[5], order为:{"volume":"5"}
2. 音色 - 可用值[0(女声),1(男声)]
示例[男声], order为:{"voice":"1"}
3. 语速 - 可用值[0(0),1(1),2(2),3(3),4(4),5(5),6(6),7(7),8(8),9(9)]
示例[5], order为:{"speed":"5"}
4. 语调 - 可用值[0(0),1(1),2(2),3(3),4(4),5(5),6(6),7(7),8(8),9(9)]
示例[5], order为:{"tone":"5"}
5. 播报 - 自定义
示例[提示音+文字], order为:{"play:gbk:16":"[message_3]欢迎光临"}
6. 铃声 - 可用值[1(1),2(2),3(3),4(4),5(5)]
示例[3], order为:{"ring":"3"}
7. 提示音 - 可用值[1(1),2(2),3(3),4(4),5(5)]
示例[3], order为:{"message":"3"}
8. 警示音 - 可用值[1(1),2(2),3(3),4(4),5(5)]
示例[3], order为:{"alert":"3"}
9. 重复 - 可用值[]
示例[], order为:
10. 停止 - 可用值[0(停止当前),1(全部停止)]
示例[全部停止], order为:{"stop":"1"}
11. 灯带 - 可用值[1(开),0(关),default(恢复默认)]
示例[关], order为:{"led":"0"}
12. 颜色 - 自定义
示例[黄], order为:{"color":"[255,255,0]"}
13. 闪烁 - 可用值[100(快),500(慢),0(停)]
示例[慢], order为:{"twinkle":"500"}
14. 呼吸 - 可用值[1000(快),2000(慢),0(停)]
示例[慢], order为:{"breath":"2000"}
15. 多彩 - 可用值[{"speed":1500,"colors":[[155,0,0],[0,0,155]]}(红蓝切换),{"speed":1500,"colors":[[155,0,0],[0,155,0],[0,0,155]]}(三色切换),{"speed":0}(停)]
示例[三色切换], order为:{"colorful":{"speed":1500,"colors":[[155,0,0],[0,155,0],[0,0,155]]}}
*/
req, _ := http.NewRequest("POST", uri, strings.NewReader(payload.Encode()))
req.Header.Add("X-APISpace-Token","")
req.Header.Add("Content-Type","")
res, err := http.DefaultClient.Do(req)
if err != nil {
return nil, err
}
defer res.Body.Close()
return ioutil.ReadAll(res.Body)
}
说明:{AppID}为您的应用ID(由平台生成),免费注册登录后,可在控制台查看;sign和ts的取值,请参考文档。
2. 智能语音音柱|10W
远程语音播报、语音提醒、语音通知、语音警报;
广泛应用于各种线下服务的订单提醒、线下流程的语音提醒等;
无需上传录音、无需后台设置;
直接通过HTTP接口推送文本,即可实时远程语音播报;
真人发声、语调自然柔和,支持男、女音色;
支持远程音量、音色、语调、语速设置;
支持多音字、支持数字(数值、金额、手机号等)读法;
内置铃声、提示音、警示音各5种;
可无缝接入各种OA、ERP、SaaS软件和低代码平台中;
防尘防水,外形美观,安装简单;
使用Go语言调用HTTP接口控制智能语音音柱|10W的代码
以设备控制(向设备下发命令)为例
全部接口文档复制
package main
import (
"fmt"
"io/ioutil"
"net/http"
"net/url"
"strings"
)
func main() {
body, err := request()
if err != nil {
fmt.Println(err)
return
}
fmt.Println(string(body))
}
func request() ([]byte, error) {
uri := "https://api.yoyoiot.cn/{AppID}/device/control/?sign={sign}&ts={ts}"
payload := url.Values{}
payload.Set("device", "设备ID")
payload.Set("order", "命令")
/*
device[字符串]:设备唯一ID,可传多个,可在控制台可查看,也可通过接口拉取;
order[json字符串]:命令,取值参考:
1. 音量 - 可用值[0(0),1(1),2(2),3(3),4(4),5(5),6(6),7(7),8(8),9(9)]
示例[5], order为:{"volume":"5"}
2. 音色 - 可用值[0(女声),1(男声)]
示例[男声], order为:{"voice":"1"}
3. 语速 - 可用值[0(0),1(1),2(2),3(3),4(4),5(5),6(6),7(7),8(8),9(9)]
示例[5], order为:{"speed":"5"}
4. 语调 - 可用值[0(0),1(1),2(2),3(3),4(4),5(5),6(6),7(7),8(8),9(9)]
示例[5], order为:{"tone":"5"}
5. 播报 - 自定义
示例[提示音+文字], order为:{"play:gbk:16":"[message_3]欢迎光临"}
6. 铃声 - 可用值[1(1),2(2),3(3),4(4),5(5)]
示例[3], order为:{"ring":"3"}
7. 提示音 - 可用值[1(1),2(2),3(3),4(4),5(5)]
示例[3], order为:{"message":"3"}
8. 警示音 - 可用值[1(1),2(2),3(3),4(4),5(5)]
示例[3], order为:{"alert":"3"}
9. 重复 - 可用值[]
示例[], order为:
10. 停止 - 可用值[0(停止当前),1(全部停止)]
示例[全部停止], order为:{"stop":"1"}
*/
req, _ := http.NewRequest("POST", uri, strings.NewReader(payload.Encode()))
req.Header.Add("X-APISpace-Token","")
req.Header.Add("Content-Type","")
res, err := http.DefaultClient.Do(req)
if err != nil {
return nil, err
}
defer res.Body.Close()
return ioutil.ReadAll(res.Body)
}
说明:{AppID}为您的应用ID(由平台生成),免费注册登录后,可在控制台查看;sign和ts的取值,请参考文档。
产品参数对比
产品 / 版本 参数 | 智能语音喇叭3 | 智能语音音柱|10W |
---|---|---|
白色 | 白色 | |
外壳材质 | 塑料 | 铝合金 |
产品尺寸 | 宽:80mm;长:80mm;厚:50mm | 104mm宽84mm x高260mm |
产品净重 | 105g | 1.04KG |
产品颜色 | 白色 | 白色 |
工作电压 | 100-250V AC(交流 / 市电) | DC 12V2A(直流) |
待机功耗 | 0.4(静音) - 3.7(最大音量播放)W | 0.4(静音) - 3.7(最大音量播放)W |
安装方式 | 2p插头|即插即用 | |
无线连接 | WiFi IEEE 802.11 b / g / n 2.4GHz | WiFi IEEE 802.11 b / g / n 2.4GHz |
产品外壳 | 防火V0级PC,耐高温,符合安规标准 | 铝合金,分隔式绝缘隔断,防止漏电风险,符合安规标准 |
包装清单 | 智能语音喇叭*1 | 智能音响*1 、 支架*3 、 螺丝*3 、 12V2A电源*1 |
发声单元 | 2个 | 2寸高音 + 4寸中低音 |
灵敏度 | 89db | |
频率响应 | 0.1-16K |