Commit 32ff219e authored by xuchaozou's avatar xuchaozou

peraf: 优化语音逻辑

parent a32c8fae
Pipeline #85758 passed with stages
...@@ -67,9 +67,23 @@ const PandaUi = props => { ...@@ -67,9 +67,23 @@ const PandaUi = props => {
}, },
finish (data) { finish (data) {
event.emit("aiSound:finish", data) event.emit("aiSound:finish", data)
},
fail ({data}) {
message.info(data.msg)
console.log(data)
emitSwitch({
loading: false,
checked: false
})
} }
} }
}) })
// await testText("请打开泵站。")
// await testText("第2个")
// await testText("请打开泵站。")
// await testText("第3个")
// await testText("关闭泵站。");
// await testText("第二个");
// await testText("我需要打开浩源孪生平台菜单") // await testText("我需要打开浩源孪生平台菜单")
// await testText("我需要返回首页") // await testText("我需要返回首页")
// await testText("我需要打开礼泉孪生平台菜单") // await testText("我需要打开礼泉孪生平台菜单")
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
position: absolute; position: absolute;
right: 50px; right: 50px;
bottom: 50px; bottom: 50px;
z-index: 100; z-index: 9999;
.image{ .image{
width: 80px; width: 80px;
height: 80px; height: 80px;
......
...@@ -216,6 +216,7 @@ class PandaRecordWebSocket extends PandaWebSocket { ...@@ -216,6 +216,7 @@ class PandaRecordWebSocket extends PandaWebSocket {
} }
// 开启wpgs会有此字段(前提:在控制台开通动态修正功能) // 开启wpgs会有此字段(前提:在控制台开通动态修正功能)
// 取值为 "apd"时表示该片结果是追加到前面的最终结果;取值为"rpl" 时表示替换前面的部分结果,替换范围为rg字段 // 取值为 "apd"时表示该片结果是追加到前面的最终结果;取值为"rpl" 时表示替换前面的部分结果,替换范围为rg字段
if (data.pgs) { if (data.pgs) {
if (data.pgs === 'apd') { if (data.pgs === 'apd') {
// 将resultTextTemp同步给resultText // 将resultTextTemp同步给resultText
...@@ -226,6 +227,9 @@ class PandaRecordWebSocket extends PandaWebSocket { ...@@ -226,6 +227,9 @@ class PandaRecordWebSocket extends PandaWebSocket {
} else { } else {
this.resultText = this.resultText + str; this.resultText = this.resultText + str;
} }
if(!this.resultTextTemp) {
return
}
this.events.frame({ this.events.frame({
resultTextTemp: this.resultTextTemp, resultTextTemp: this.resultTextTemp,
resultText: this.resultText, resultText: this.resultText,
...@@ -234,8 +238,10 @@ class PandaRecordWebSocket extends PandaWebSocket { ...@@ -234,8 +238,10 @@ class PandaRecordWebSocket extends PandaWebSocket {
}); });
} }
if (jsonData.code == 0 && jsonData.data.status == 2) { if (jsonData.code == 0 && jsonData.data.status == 2) {
const resultText = this.resultTextTemp ? this.resultTextTemp : this.resultText
if(!resultText) return
this.events.finish({ this.events.finish({
resultText: this.resultTextTemp ? this.resultTextTemp : this.resultText, resultText,
}); });
this.reconnect(); this.reconnect();
} }
...@@ -245,8 +251,10 @@ class PandaRecordWebSocket extends PandaWebSocket { ...@@ -245,8 +251,10 @@ class PandaRecordWebSocket extends PandaWebSocket {
msg: FAIL_TYPE_DATA_ERRRO_MSG, msg: FAIL_TYPE_DATA_ERRRO_MSG,
data: { data: {
code: jsonData.code, code: jsonData.code,
msg : jsonData.message
}, },
}); });
console.log(jsonData)
this.destroy(); this.destroy();
} }
} }
......
...@@ -3,7 +3,7 @@ import BaseDirective from "./BaseDirective"; ...@@ -3,7 +3,7 @@ import BaseDirective from "./BaseDirective";
class ByeDirective extends BaseDirective { class ByeDirective extends BaseDirective {
match () { match () {
const {text} = this const {text} = this
if(/再见|拜拜|关闭/.test(text)) { if(/再见|拜拜|关闭熊猫/.test(text)) {
return true return true
} }
return false return false
......
import BaseDirective from "./BaseDirective"; import BaseDirective from "./BaseDirective";
import {store , event} from '@wisdom-utils/utils' import {store , event} from '@wisdom-utils/utils'
import Utils from "../utils/Utils";
class CloseMenuDirective extends BaseDirective { class CloseMenuDirective extends BaseDirective {
match () { match () {
const { text } = this const { text } = this
let result = null let result = null
if(this.getBeforeLastGroupDirective()) {
result = text.match(/第([一|二|三|四|五|六|七|八|九|十]+)个/)
if(result && result.length >= 2) {
this.matchResult = Utils.chineseToNumber(result[1])
} else if(!result) {
result = text.match(/第[\u4e00-\u9fa5]?(\d+)个/)
if(result && result.length >= 2) {
this.matchResult = Number(result[1])
}
}
}
result = text.match(/关闭(.*)(?=(?:菜单|功能|路径))/) result = text.match(/关闭(.*)(?=(?:菜单|功能|路径))/)
if (!result) { if (!result) {
result = text.match(/关闭(.*)(?=(?:,|,|。))/) result = text.match(/关闭(.*)(?=(?:,|,|。))/)
...@@ -15,11 +29,30 @@ class CloseMenuDirective extends BaseDirective { ...@@ -15,11 +29,30 @@ class CloseMenuDirective extends BaseDirective {
return !!this.matchResult return !!this.matchResult
} }
getBeforeLastGroupDirective() {
const lastMenu = this.directives.at(-1)
if(!lastMenu) return false
if(!(lastMenu instanceof CloseMenuDirective) ) return false
if(!lastMenu.data || lastMenu.data.type != "widgets" || lastMenu.data.widgets.length == 0) return false
return true
}
async excute () { async excute () {
let widgets = null let widgets = null
if(this.data) { if(typeof this.matchResult == "number") {
const widgets = this.getOpenedMenus()
if(this.matchResult == 0 || this.matchResult > widgets.length) {
this.data = {}
this.data.type = "widgets"
this.data.widgets = widgets
return `索引超出了界限,请重新语音选择关闭第几个菜单`
} else { } else {
const menu = widgets[this.matchResult]
event.emit("event:closeMenuByName", menu.name)
return `关闭${menu.name}菜单成功`
}
}
else {
widgets = this.getIsOneWdiget() widgets = this.getIsOneWdiget()
if(!widgets) { if(!widgets) {
widgets = this.getCompleteMenus() widgets = this.getCompleteMenus()
......
...@@ -8,11 +8,11 @@ class OpenMenuDirective extends BaseDirective { ...@@ -8,11 +8,11 @@ class OpenMenuDirective extends BaseDirective {
const { text } = this const { text } = this
let result = null let result = null
if(this.getBeforeLastGroupDirective()) { if(this.getBeforeLastGroupDirective()) {
result = text.match(/打开.*([一|二|三|四|五|六|七|八|九|十]+)/) result = text.match(/([一|二|三|四|五|六|七|八|九|十]+)/)
if(result && result.length >= 2) { if(result && result.length >= 2) {
this.matchResult = Utils.chineseToNumber(result[1]) this.matchResult = Utils.chineseToNumber(result[1])
} else if(!result) { } else if(!result) {
result = text.match(/打开[\u4e00-\u9fa5]?(\d+)/) result = text.match(/[\u4e00-\u9fa5]?(\d+)/)
if(result && result.length >= 2) { if(result && result.length >= 2) {
this.matchResult = Number(result[1]) this.matchResult = Number(result[1])
} }
...@@ -22,7 +22,7 @@ class OpenMenuDirective extends BaseDirective { ...@@ -22,7 +22,7 @@ class OpenMenuDirective extends BaseDirective {
result = text.match(/打开(.*)(?=(?:菜单|功能|路径))/) result = text.match(/打开(.*)(?=(?:菜单|功能|路径))/)
} }
if (!result) { if (!result) {
result = text.match(/打开(.*)(?=(?:,|,|。|))/) result = text.match(/打开(.*)(?=(?:,|,|。))/)
} }
if (result && result.length >= 2 && !this.matchResult) { if (result && result.length >= 2 && !this.matchResult) {
this.matchResult = result[1] this.matchResult = result[1]
...@@ -33,7 +33,7 @@ class OpenMenuDirective extends BaseDirective { ...@@ -33,7 +33,7 @@ class OpenMenuDirective extends BaseDirective {
getBeforeLastGroupDirective () { getBeforeLastGroupDirective () {
const lastMenu = this.directives.at(-1) const lastMenu = this.directives.at(-1)
if(!lastMenu) return false if(!lastMenu) return false
if(!lastMenu instanceof OpenMenuDirective ) return false if(!(lastMenu instanceof OpenMenuDirective) ) return false
if(!lastMenu.data || lastMenu.data.type != "widgets" || lastMenu.data.widgets.length == 0) return false if(!lastMenu.data || lastMenu.data.type != "widgets" || lastMenu.data.widgets.length == 0) return false
return true return true
} }
...@@ -86,7 +86,7 @@ class OpenMenuDirective extends BaseDirective { ...@@ -86,7 +86,7 @@ class OpenMenuDirective extends BaseDirective {
} }
widgetsToMsg (widgets) { widgetsToMsg (widgets) {
return `有以下${widgets.length}个菜单\n${widgets.map((widget, index) => `${index + 1}.${widget.label}`).join("\n")},\n请语音确认一下打开第几个菜单` return `有以下${widgets.length}个菜单\n${widgets.map((widget, index) => `${index + 1}.${widget.label}`).join("\n")}\n请语音确认一下打开第几个菜单`
} }
getCompleteMenus() { getCompleteMenus() {
......
...@@ -11,9 +11,6 @@ const SoundAi = props => { ...@@ -11,9 +11,6 @@ const SoundAi = props => {
try { try {
await getIsOpenConfig() await getIsOpenConfig()
await getKey() await getKey()
event.emit("record:changeVisible", {
visible: true
})
setVisible(true) setVisible(true)
} catch (error) { } catch (error) {
console.warn(error) console.warn(error)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment