sync voice && cc with r16 code

This commit is contained in:
wangzijiao 2019-01-04 09:24:39 +08:00
parent 8ccc4b2b1f
commit 8d682c33b5
44 changed files with 661 additions and 183 deletions

View File

@ -1 +1 @@
{"version":"1.0.0.9", "md5":"ba700cada4fd3bd2a74c50fd6108431e"}
{"version":"1.0.1.1", "md5":"a8c96b3d7625adb7ab1139db6016e13d"}

View File

@ -27,4 +27,6 @@ var (
PARAMS_ERR_INVALID = errors.New("参数异常")
Net_ERR_Post = errors.New("网络异常,请稍后再试")
Normal_Dlna_Mode = errors.New("普通dlna模式")
)

View File

@ -42,8 +42,8 @@ var (
OneShot OneShotArray
WkupArray = [MaxWords]wakeupVal{
MainWakeup: wakeupVal{WkupWord: MainWakeupWord, DayThresh: "0.52", NightThresh: "0.59", Major: "0", Dcheck: "0", DayThresh2: "0.36", NightThresh2: "0.36"},
NextSong: wakeupVal{WkupWord: NextSongWord, DayThresh: "0.43", NightThresh: "0.49", Major: "0", Dcheck: "0", DayThresh2: "0.28", NightThresh2: "0.28"},
VolumeAdjust: wakeupVal{WkupWord: string(VolumeUpWord + "," + VolumeDownWord), DayThresh: "0.33,0.35", NightThresh: "0.37,0.40", Major: "0,0", Dcheck: "0,0", DayThresh2: "0.25,0.23", NightThresh2: "0.25,0.23"},
NextSong: wakeupVal{WkupWord: NextSongWord, DayThresh: "0.43", NightThresh: "0.49", Major: "0", Dcheck: "0", DayThresh2: "0.29", NightThresh2: "0.29"},
VolumeAdjust: wakeupVal{WkupWord: string(VolumeUpWord + "," + VolumeDownWord), DayThresh: "0.34,0.34", NightThresh: "0.38,0.40", Major: "0,0", Dcheck: "0,0", DayThresh2: "0.25,0.23", NightThresh2: "0.25,0.23"},
}
)

View File

@ -144,7 +144,8 @@ const (
APP_CMD_DEVICE_EVENT Cmd = 5152 //exec vol=0
APP_CMD_ENV_CHANGE Cmd = 5153
APP_CMD_TIMINGPAUSE_SET Cmd = 5154
APP_CMD_TIMINGPAUSE_QUERY Cmd = 5155
APP_CMD_CFGLIST_GET Cmd = 5998 //exec vol=0
APP_CMD_CFGLIST_GET_RSP Cmd = 5999 //exec vol=0
)
@ -158,6 +159,9 @@ const (
)
const (
MSC_CMD_YUNBOX_NEXT Cmd = 9991
MSC_CMD_TIMINGPAUSE_SET Cmd = 9992
MSC_CMD_TIMINGPAUSE_CANCEL Cmd = 9993
MSC_CMD_TTS_IDLE Cmd = 9994
)

View File

@ -113,6 +113,10 @@ type VboxBroadcastSt struct {
CurTask uint8 `json:"curTask"`
TimingPauseSet int64 `json:"timingPauseSet,omitempty"`
TimingPauseRemain int64 `json:"timingPauseRemain,omitempty"`
TimingPauseOnComplete bool `json:"timingPauseOnComplete,omitempty"`
DeviceMode DeviceMode `json:"deviceMode"`
TimeStamp int64 `json:"timeStamp"`

View File

@ -12,6 +12,7 @@ const (
Type_Inform_TtsDelay InformType = 108
Type_Inform_TtsPush InformType = 109 //上传成对出现的tts信息流
Type_Inform_BtOnWifiOff InformType = 110
Type_Inform_TimingPause InformType = 111
)
const (
Type_Inform_Top3_Play InformType = 104 + iota

View File

@ -19,6 +19,7 @@ import (
"reflect"
"strconv"
"time"
"fmt"
)
var (
@ -256,6 +257,8 @@ func (this *HttpReq) PostAuto(reqBody interface{}, resDetail interface{}) (int,
url = api.Url + "?aes=0"
}
url += fmt.Sprintf("&t=%d", time.Now().UnixNano()/1e6)
if api.IsEncrypted || api.ReqparamIsString {
data, _ := json.Marshal(reqBody)
log.Println(log.DebugLog, "http req body:", string(data))

View File

@ -194,6 +194,9 @@ func coreSchedule(cmd SCmdStruct) {
case PlayerArg:
isGlobalPause = eType.GloablePause
showIcon = !eType.NotShowIcon
if eType.UserTrig == true {
ClearTimeoutTimingPause()
}
default:
}
@ -213,6 +216,7 @@ func coreSchedule(cmd SCmdStruct) {
}
eventPoint.PlayPauseEvent(eventPoint.ModelValPause, curRunningPlayer.GetPlayerStatus().Uuid)
case SCMD_MusicPlayer_PlayOrPause:
ClearTimeoutTimingPause()
showIcon := false
if len(cmd.Arg) == 1 {
if notshow, ok := cmd.Arg[0].(bool); ok {
@ -686,6 +690,7 @@ func changePlayer(from *SPlayer, to *SPlayer) {
}
curRunningPlayer = to
PlayerChangeCheckTimingPause()
globals.ResetBroadCastTimer()
}

View File

@ -8,6 +8,7 @@ import (
"netease_control_center/modules/hardware/misc"
"strings"
"sync"
"fmt"
)
var (
@ -327,6 +328,10 @@ func SetPlayerStatus(status PlayerDetail) {
log.Println(log.ErrorLog, "Set player status, but not find the id:", status.PlayerId)
}
}
if status.Status == globals.MUSIC_ST_COMPLETED {
TrigTimingPauseOnComplete()
}
}
func GetCurPlayerId() globals.PlayerType {
@ -514,3 +519,45 @@ func TryMicAdcIdle() {
misc.IdleMicAdc()
}
}
func GetCurDeviceMode(print bool) (ret globals.DeviceMode) {
curPlayer := GetCurPlayer()
if print {
fmt.Printf("curplayer:%+v\n", *curPlayer)
}
if curPlayer.IsPlaying() {
ret = globals.Exec_MusicPlay_mode
} else {
if !curPlayer.IsInterrupt() {
if GetCurScheduleDomain().IsMusicDomain() == false {
ret = globals.Exec_Non_Music_Idle_mode
} else if globals.MUSIC_ST_PAUSED == curPlayer.GetPlayerStatus().Status {
ret = globals.Pause_mode
} else {
ret = globals.Idle_mode
}
} else {
// 播放器被打断过
if curPlayer.PlayAfterResume {
if GetCurScheduleDomain().IsMusicDomain() == true {
ret = globals.Exec_MusicPlay_mode
} else {
ret = globals.Exec_Non_Music_Played_mode
}
} else {
if GetCurScheduleDomain().IsMusicDomain() == false {
ret = globals.Exec_Non_Music_Idle_mode
} else if globals.MUSIC_ST_PAUSED == curPlayer.GetPlayerStatus().Status {
ret = globals.Pause_mode
} else {
ret = globals.Idle_mode
}
}
}
}
if print {
fmt.Printf("deviceMode:%+v, curplayer:%+v, domain:%+v\n", ret, curPlayer, GetCurScheduleDomain())
}
return ret
}

View File

@ -19,6 +19,7 @@ type PlayerArg struct {
NotShowIcon bool
TtsNextPre *string
UserTrig bool
ServerPlayerBase
}
@ -303,6 +304,7 @@ func (this *SPlayer) ContinuePlay() (isSuccess bool) {
return this.StartPlay(0)
case difftime > GetT2Duration():
this.Pause(true, "")
ClearTimeoutTimingPause()
return true
}

View File

@ -0,0 +1,156 @@
package schedule
import (
"time"
"netease_control_center/interfaces/log"
"netease_control_center/globals"
"fmt"
"netease_control_center/interfaces/http"
)
type TimingPauseDuration time.Duration
func (this TimingPauseDuration) TimeName() string {
sec := int(time.Duration(this).Seconds())
mins := sec / 60
if time.Duration(this) < time.Minute {
return fmt.Sprintf("%d秒", sec)
} else if time.Duration(this) < time.Hour {
return fmt.Sprintf("%d分钟", mins)
} else {
if yu := mins % 60; yu == 0 {
return fmt.Sprintf("%d小时", mins/60)
} else {
return fmt.Sprintf("%d小时%d分钟", mins/60, yu)
}
}
}
func (this TimingPauseDuration) Vui_Timeout() (tmp string) {
return this.TimeName() + "的定时关闭时间到了,已为你关闭音源"
}
func (this TimingPauseDuration) Vui_Cancel() string {
return "好的,已为你取消了" + this.TimeName() + "后的定时关闭"
}
func Vui_Timeout() string {
if setDuration == 0 {
return "你还没有设置定时关闭呢"
} else {
return TimingPauseDuration(setDuration).Vui_Timeout()
}
}
var (
timingPause_time time.Time = time.Now()
timingPause_timer *time.Timer = nil
pauseOnComplete bool = false
setDuration time.Duration
)
func IstimingPauseRunning() bool {
if pauseOnComplete == true || time.Now().Before(timingPause_time) {
return true
} else {
return false
}
}
func GetTPTimeName() string {
return TimingPauseDuration(setDuration).TimeName()
}
func GetTimeDurationOfTimingPause() (remainMillisecond int64, IsPauseOnComplete bool, toSetMillisecond int64) {
remain := timingPause_time.Sub(time.Now())
if remain > 0 {
return int64(remain.Nanoseconds() / 1e6), pauseOnComplete, int64(setDuration.Nanoseconds() / 1e6)
} else {
return int64(0), pauseOnComplete, int64(setDuration.Nanoseconds() / 1e6)
}
}
//player stataus trig
func TrigTimingPauseOnComplete() {
if pauseOnComplete == true && !time.Now().Before(timingPause_time) {
log.Println(log.DebugLog, "Play Complete, do pause!")
//hang dad,add delay to avoid ihwplayer bug
time.AfterFunc(300*time.Millisecond, func() {
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{GloablePause: true, NotShowIcon: true})
})
go http.InformMsgToServer(http.Type_Inform_TimingPause, TimingPauseDuration(setDuration).Vui_Timeout())
ClearTimingPause()
}
}
func ClearTimeoutTimingPause() {
if pauseOnComplete == true && time.Now().After(timingPause_time) {
ClearTimingPause()
log.Println(log.DebugLog, "ClearTimeoutTimingPause!")
}
}
//Player change, clear player status
func PlayerChangeCheckTimingPause() {
if pauseOnComplete == true && !time.Now().Before(timingPause_time) {
ClearTimingPause()
}
}
func ClearTimingPause() (vui string) {
if now, set := time.Now(), timingPause_time; now.Before(set) {
vui = fmt.Sprintf("好的,已为你取消了%s后的定时关闭", TimingPauseDuration(set.Sub(now)).TimeName())
} else if pauseOnComplete {
vui = "好的,已为你取消定时关闭"
} else {
vui = "你还没有设置定时关闭呢"
}
pauseOnComplete = false
if timingPause_timer != nil {
timingPause_timer.Stop()
}
timingPause_time = time.Now()
setDuration = 0
globals.ResetBroadCastTimer()
return
}
func timingPauseTimeout() {
log.Println(log.DebugLog, "TimingPause timeout!")
if GetCurPlayerId() == globals.PlayerType_Wifi && pauseOnComplete == true {
if GetCurDeviceMode(false).IsActive() {
log.Println(log.DebugLog, "Cur is wifi player, wait to play complete to pause!")
} else {
ClearTimingPause()
log.Println(log.DebugLog, "Player not active, stop timingPause!")
}
} else {
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{GloablePause: true, NotShowIcon: true})
go http.InformMsgToServer(http.Type_Inform_TimingPause, TimingPauseDuration(setDuration).Vui_Timeout())
ClearTimingPause()
}
}
func SetTimingPause(remainMillisecond *int64, IsPauseOnComplete *bool) {
if remainMillisecond != nil {
afterDuration := time.Duration(*remainMillisecond) * time.Millisecond
if timingPause_timer != nil {
timingPause_timer.Stop()
}
setDuration = afterDuration
timingPause_time = time.Now().Add(afterDuration)
timingPause_timer = time.AfterFunc(afterDuration, timingPauseTimeout)
}
if IsPauseOnComplete != nil && IstimingPauseRunning() == true {
pauseOnComplete = *IsPauseOnComplete
}
log.Println(log.DebugLog, "Set timingPause:", setDuration, pauseOnComplete)
globals.ResetBroadCastTimer()
}

View File

@ -89,7 +89,7 @@ func DlnaCmdProcess(cmdid uint32, msg string) {
//player.SetDlnaPausePhone(true)
player.DlnaPlaySeek = true
eventPoint.SetEpOsSouce("F141", eventPoint.EpOs_App)
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{GloablePause: false, NotShowIcon: true}) // 不显示icon
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{GloablePause: false, NotShowIcon: true, UserTrig:true}) // 不显示icon
} else {
log.Println(log.DebugLog, "dlna player is not playing, ignore pause.")
}

View File

@ -255,6 +255,13 @@ func HTTPSERVER_test(w http.ResponseWriter, r *http.Request, ps httprouter.Param
}
switch args[0] {
case "timingpause":
t,_ := strconv.Atoi(args[1])
b,_ := strconv.ParseBool(args[2])
set := int64(1000*t)
schedule.SetTimingPause(&set, &b)
fmt.Fprintln(w, "time:", t, " Pause On Complete:", b)
case "fespa_set":
switch args[1] {
case "once":

View File

@ -594,6 +594,9 @@ func systemServiceTaskRegiste() {
tmp += fmt.Sprintln(" Tag:", *GitTag, " build time:", BuildDate, " Hv:", *Hv)
tmp += fmt.Sprintln(" OemManufature:", OemManufature, " OemManufactureCheckOk:", OemManufactureCheckOk)
tmp += fmt.Sprintln(" MicClose:", IsMicClose, "MicCloseTrig:", MicCloseTrig, "IsMicLightOn:", IsMicLightOn)
if remain, pauseOnC,set := GetTimeDurationOfTimingPause(); true {
tmp += fmt.Sprintln("TimingPause: remain(millisecond):", remain, " pauseOnComplete:", pauseOnC, " setTime:", set)
}
tmp += fmt.Sprintf(" cronMic:%+v\n", micControl)
tmp += fmt.Sprintln(" laststatusicon:", GetLastStatusIcon())
tmp += fmt.Sprintln(" lasticon:", GetLastIcon())

View File

@ -33,11 +33,11 @@ const (
)
func MscToastLed_Before() {
if IsMicClose == false {
//if IsMicClose == false {
vui.IconLed_iconMusic004.Show()
tmp := DirectLed{EffectId: atservice.GUIDE_EFFECT_ID_EXEC_CMD, Action: atservice.GUIDE_ACTION_START}
led_mcu.DirectLedControl(tmp.EffectId, tmp.Action, tmp.StartLampNum, []byte{uint8(adau1761.MustGetVol())})
}
//}
switch nembd.Host(*ActualHv) {
case nembd.HostPv1C:
@ -65,11 +65,11 @@ func MscToastFinish(arg TtsPlayerArg) {
func volChangeCb(params *NoticePlayerParams) {
params.BeforeSpecialFunc = func() {
if IsMicClose == false {
//if IsMicClose == false {
AlwaysShowVolumeIcon()
tmp := DirectLed{EffectId: atservice.GUIDE_EFFECT_ID_EXEC_CMD, Action: atservice.GUIDE_ACTION_START}
led_mcu.DirectLedControl(tmp.EffectId, tmp.Action, tmp.StartLampNum, []byte{uint8(adau1761.MustGetVol())})
}
//}
}
params.SpecialFunc = func(arg TtsPlayerArg) {
//if IsMicClose == false {
@ -207,6 +207,34 @@ func MscSuccessCommand(msg *[]byte, msglen uint32) {
ntp.SetUnixTimeToLocal(retData.TimeStamp, 5*time.Minute, true)
switch Cmd(retData.Cmd) {
case MSC_CMD_TIMINGPAUSE_SET:
backupstatus := IstimingPauseRunning()
var toastContent string
var tmp struct {
Data struct{
PauseOnComplate bool `json:"pauseOnComplate"`
RemainTime int64 `json:"timeOffset"`
} `json:"data"`
}
if err := json.Unmarshal([]byte(retData.Detail), &tmp); err == nil {
SetTimingPause(&tmp.Data.RemainTime, &tmp.Data.PauseOnComplate)
if backupstatus == true {
toastContent = "好的,已将你的定时调整成了" + GetTPTimeName() + "后关闭"
} else {
toastContent = "好的,我会在" + GetTPTimeName() + "后关闭音响"
}
MscToastTts(toastContent, retData.RspId, true, false, nil)
http.InformMsgToServer(http.Type_Inform_TtsDelay, toastContent)
} else {
log.Println(log.ErrorLog, "Decode server data err:", err)
}
case MSC_CMD_TIMINGPAUSE_CANCEL:
tts := ClearTimingPause()
MscToastTts(tts, retData.RspId, true, false, nil)
http.InformMsgToServer(http.Type_Inform_TtsDelay, tts)
case MSC_CMD_IOTWIFIPARING:
SendSCmd(SCMD_SuperTask_Enter_IOT_WifiParing)
@ -234,7 +262,7 @@ func MscSuccessCommand(msg *[]byte, msglen uint32) {
// 不显示icon
log.Println(log.DebugLog, "pause music by chat interrupt")
eventPoint.SetEpOsSouce("F141", eventPoint.EpOs_Server)
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{GloablePause: false, NotShowIcon: true})
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{GloablePause: false, NotShowIcon: true, UserTrig:true})
}
}
@ -389,6 +417,10 @@ func MscSuccessCommand(msg *[]byte, msglen uint32) {
}
}
case MSC_CMD_YUNBOX_NEXT:
//yunbox mode, treat as pause, no voice and icon
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{GloablePause: false, NotShowIcon: true})
case MSC_CMD_PAUSE:
//SendSCmd(SCMD_MusicPlayer_Pause, nil)
//player.SoundEffectPlayCmd(CMD_SE_PLAY, vui.SoundNotice_Scaozuofankui001.GetPath())
@ -406,11 +438,11 @@ func MscSuccessCommand(msg *[]byte, msglen uint32) {
vui.IconLed_IconChaozuo001.Show()
case Exec_MusicPlay_mode:
eventPoint.SetEpOsSouce("F141", eventPoint.EpOs_Server)
SendSCmd(SCMD_MusicPlayer_Pause, nil)
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{GloablePause: false, NotShowIcon: true, UserTrig: true})
case Exec_Non_Music_Played_mode:
// 不显示icon
eventPoint.SetEpOsSouce("F141", eventPoint.EpOs_Server)
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{GloablePause: false, NotShowIcon: true})
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{GloablePause: false, NotShowIcon: true, UserTrig:true})
}
case MSC_CMD_NEXT, MSC_CMD_PRE:
// prd reverse : 20180316
@ -445,7 +477,7 @@ func MscSuccessCommand(msg *[]byte, msglen uint32) {
case PlayerType_Dlna:
if retData.Desc != MSC_CMD_ONE_SHOT_WAKEUP && retData.Desc != MSC_CMD_ONE_SHOT {
log.Println(log.DebugLog, "not one shot cmd for dlna in pause mode, just return")
log.Println(log.DebugLog, "not one shot cmd for dlna, server will deal it, so just return")
/*MscToastTts(TTS_NOT_UNSUPPORT, retData.RspId, true, false, nil) //lupeng 20190908 #PV1-4216
if retData.Desc == MSC_CMD_ONE_SHOT_WAKEUP {
@ -475,9 +507,11 @@ func MscSuccessCommand(msg *[]byte, msglen uint32) {
}
_, err := GetMusicListNew(PlayerType_Wifi, true, serverListParams)
if nil != err {
log.Println(log.ErrorLog, err.Error())
if !strings.EqualFold(err.Error(), Normal_Dlna_Mode.Error()) {
NoticePlayerSendSCmd(SCMD_SuperTask_Tts_Play, MusicErrTtsMap[string(MUSIC_LIST_NULL)], CONST_AUDIO_ID, AdSrcType_TTS,
TTS_LEVEL_1, true, false)
log.Println(log.ErrorLog, err.Error())
}
} else {
go http.InformLocalMsgToServer(http.Type_Inform_TtsPush, int(MSC_CMD_NEXT), TTS_MUSIC_NEXT, TTS_MUSIC_NEXT) //上传信息流
}
@ -493,6 +527,7 @@ func MscSuccessCommand(msg *[]byte, msglen uint32) {
case GetScenePlayerId(), PlayerType_Wifi, PlayerType_Bt, PlayerType_Airplay:
if retData.Desc == MSC_CMD_ONE_SHOT || retData.Desc == MSC_CMD_ONE_SHOT_WAKEUP {
log.Println(log.DebugLog, "one shot cmd for next song")
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{GloablePause: false, NotShowIcon: true, UserTrig:false})
/*播放反馈声音prd暂时不需要
PlayNoticeAsync(AdSrcType_FILE, vui.SoundNotice_Shuanxing001.GetPath(), WAKEUP_AUDIO_ID, false, nil, func(id uint32, reason NoticeStopReason) {
log.Println(log.WarningLog, "one shot cmd audio sound end")
@ -500,7 +535,7 @@ func MscSuccessCommand(msg *[]byte, msglen uint32) {
}
case PlayerType_Dlna:
if retData.Desc != MSC_CMD_ONE_SHOT_WAKEUP && retData.Desc != MSC_CMD_ONE_SHOT {
log.Println(log.DebugLog, "not one shot cmd for dlna in pause mode, just return")
log.Println(log.DebugLog, "not one shot cmd for dlna, server will deal it, so just return")
/*MscToastTts(TTS_NOT_UNSUPPORT, retData.RspId, true, false, nil) //lupeng 20190908 #PV1-4216
if retData.Desc == MSC_CMD_ONE_SHOT_WAKEUP {
@ -530,9 +565,11 @@ func MscSuccessCommand(msg *[]byte, msglen uint32) {
}
_, err := GetMusicListNew(PlayerType_Wifi, true, serverListParams)
if nil != err {
log.Println(log.ErrorLog, err.Error())
if !strings.EqualFold(err.Error(), Normal_Dlna_Mode.Error()) {
NoticePlayerSendSCmd(SCMD_SuperTask_Tts_Play, MusicErrTtsMap[string(MUSIC_LIST_NULL)], CONST_AUDIO_ID, AdSrcType_TTS,
TTS_LEVEL_1, true, false)
log.Println(log.ErrorLog, err.Error())
}
} else {
go http.InformLocalMsgToServer(http.Type_Inform_TtsPush, int(MSC_CMD_NEXT), TTS_MUSIC_NEXT, TTS_MUSIC_NEXT) //上传信息流
}
@ -653,7 +690,7 @@ func MscSuccessCommand(msg *[]byte, msglen uint32) {
if PlayListSrcRec.BizType != BIZ_TYPE_MUSIC {
SendSCmd(SCMD_MusicPlayer_Play, nil)
} else {
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{GloablePause: false, NotShowIcon: true})
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{GloablePause: false, NotShowIcon: true, UserTrig:true})
}
//检查是否网络缓存播放失败
@ -783,11 +820,11 @@ func MscSuccessCommand(msg *[]byte, msglen uint32) {
MscToastTts(tmp.Tts, retData.RspId, true, tmp.Keep, func(params *NoticePlayerParams) {
if Cmd(retData.Cmd) == MSC_CMD_COLLECT_MUSIC {
params.BeforeExecFunc = func() {
if IsMicClose == false {
//if IsMicClose == false {
vui.IconLed_IconChaozuo005.Show()
tmp := DirectLed{EffectId: atservice.GUIDE_EFFECT_ID_EXEC_CMD, Action: atservice.GUIDE_ACTION_START}
led_mcu.DirectLedControl(tmp.EffectId, tmp.Action, tmp.StartLampNum, []byte{uint8(adau1761.MustGetVol())})
}
//}
switch Cmd(retData.Cmd) {
case MSC_CMD_COLLECT_MUSIC:
@ -1394,7 +1431,11 @@ func MscSuccessCommand(msg *[]byte, msglen uint32) {
DataType: http.DATA_TYPE_STRING})
}
specialFuncBackup := ttsRepeatInfo.NoticePlayerParams.SpecialFunc
ttsRepeatInfo.NoticePlayerParams.SpecialFunc = func(arg TtsPlayerArg) {
if specialFuncBackup != nil {
specialFuncBackup(arg)
}
//检查是否网络缓存播放失败
if arg.StopReason == NoticeStopReason_Error {
go MscToastFile(vui.SoundNotice_Song_Get_Timeout.GetPath(), CONST_AUDIO_ID, false, false, nil)
@ -1495,11 +1536,13 @@ func MscSuccessCommand(msg *[]byte, msglen uint32) {
return
}
PlayListSrcRec.ModeId = tmp.ModeInfoDto.NewModeId
log.Printf(log.DebugLog, "Detail:%+v tmp:%+v\n", retData.Detail, tmp)
SendSCmdStruct(SCmdStruct{SCmd: SCMD_MusicPlayer_Pause, Arg: []interface{}{PlayerArg{NotShowIcon: true}}, ExecCb: func(cb SCmdStructExecCb) {
tmp := GetCurVboxBroadcastSt(false)
tmp.PlayerStPtr.ContinuousTaskSt = MUSIC_ST_IDLE
TrigBroadcastStatus(tmp)
SendSCmdStruct(SCmdStruct{SCmd: SCMD_MusicPlayer_Pause, Arg: []interface{}{PlayerArg{NotShowIcon: true, UserTrig:true}}, ExecCb: func(cb SCmdStructExecCb) {
tmpSt := GetCurVboxBroadcastSt(false)
tmpSt.PlayerStPtr.ContinuousTaskSt = MUSIC_ST_IDLE
TrigBroadcastStatus(tmpSt)
ResetWifiPlayer()
}})
@ -1550,10 +1593,44 @@ func AppSuccessCommand(msg *[]byte, msglen uint32) {
// return
//}
switch app.CmdId {
case APP_CMD_TIMINGPAUSE_SET:
var tmp struct {
RemainTime *int64 `json:"timingPauseRemain"`
TimingPauseOnComplete *bool `json:"timingPauseOnComplete"`
Switch bool `json:"timingPauseSwitch"`
}
if err := json.Unmarshal([]byte(app.Detail), &tmp); err == nil {
if tmp.Switch == true {
SetTimingPause(tmp.RemainTime, tmp.TimingPauseOnComplete)
} else {
ClearTimingPause()
}
}
var tmp2 struct {
RemainTime int64 `json:"timingPauseRemain"`
SetTime int64 `json:"timingPauseSet"`
TimingPauseOnComplete bool `json:"timingPauseOnComplete"`
}
tmp2.RemainTime, tmp2.TimingPauseOnComplete, tmp2.SetTime = GetTimeDurationOfTimingPause()
SendCmdByYunxin(APP_CMD_TIMINGPAUSE_SET, tmp2, false, app.MsgId)
case APP_CMD_TIMINGPAUSE_QUERY:
var tmp struct {
RemainTime int64 `json:"timingPauseRemain"`
SetTime int64 `json:"timingPauseSet"`
TimingPauseOnComplete bool `json:"timingPauseOnComplete"`
}
tmp.RemainTime, tmp.TimingPauseOnComplete, tmp.SetTime = GetTimeDurationOfTimingPause()
SendCmdByYunxin(APP_CMD_TIMINGPAUSE_QUERY, tmp, false, app.MsgId)
case APP_CMD_DEVICE_EVENT:
var tmp DeviceEventStruct
if err = json.Unmarshal([]byte(app.Detail), &tmp); err == nil {
switch tmp.EventType {
case DeviceEventType_QueryDevStatus:
ResetBroadCastTimer()
case DeviceEventType_IotWifiParing:
var ev DeviceEventAction
if iot_running {
@ -1561,11 +1638,12 @@ func AppSuccessCommand(msg *[]byte, msglen uint32) {
} else {
ev = DeviceEventAction_End
}
SendEventnByYunxinWithRid(DeviceEventType_IotWifiParing, ev, app.ReplyId, false, nil)
SendEventnByYunxinWithRid(DeviceEventType_IotWifiParing, ev, app.MsgId, false, nil)
default:
log.Println(log.DebugLog, "Un support event status query!", tmp.EventType)
}
}
case APP_CMD_MUSIC_PLAY:
RestoreDefaultVolWhen0()
if len(app.Detail) < 1 {
@ -1607,12 +1685,12 @@ func AppSuccessCommand(msg *[]byte, msglen uint32) {
SendSCmd(SCMD_MusicPlayer_Play)
case APP_CMD_MUSIC_PAUSE:
eventPoint.SetEpOsSouce("F141", eventPoint.EpOs_App)
SendSCmd(SCMD_MusicPlayer_Pause)
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{UserTrig:true})
case APP_CMD_MUSIC_NEXT:
RestoreDefaultVolWhen0()
mode := getCurDeviceMode(true)
if Exec_MusicPlay_mode == mode {
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{NotShowIcon: true})
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{NotShowIcon: true, UserTrig:false})
}
base := ServerPlayerBase{Action: MUSIC_ACTION_NEXT, ActionSrc: MUSIC_ACTION_SRC_APP}
@ -1624,7 +1702,7 @@ func AppSuccessCommand(msg *[]byte, msglen uint32) {
RestoreDefaultVolWhen0()
mode := getCurDeviceMode(true)
if Exec_MusicPlay_mode == mode {
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{NotShowIcon: true})
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{NotShowIcon: true, UserTrig:false})
}
PlayListSrcRec.ListHasEnd = false //歌单播放结束标志位false
@ -1759,7 +1837,7 @@ func AppSuccessCommand(msg *[]byte, msglen uint32) {
RestoreDefaultVolWhen0()
mode := getCurDeviceMode(true)
if Exec_MusicPlay_mode == mode {
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{NotShowIcon: true})
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{NotShowIcon: true, UserTrig:false})
}
var ret struct {
@ -1798,7 +1876,7 @@ func AppSuccessCommand(msg *[]byte, msglen uint32) {
mode := getCurDeviceMode(true)
if Exec_MusicPlay_mode == mode {
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{NotShowIcon: true})
SendSCmd(SCMD_MusicPlayer_Pause, PlayerArg{NotShowIcon: true, UserTrig:false})
}
var tmp VboxChangeInfo
err := json.Unmarshal([]byte(app.Detail), &tmp)
@ -2265,6 +2343,7 @@ func ignoreCmdInDAB() bool {
return PlayerType_Wifi != GetCurPlayerId()
}
// Deprecated: use schedule.GetCurDeviceMode instead of this
func getCurDeviceMode(print bool) (ret DeviceMode) {
curPlayer := GetCurPlayer()
if print {

View File

@ -844,17 +844,17 @@ loop_finishConnectWifi:
}
tmpconfig.BeforeSpecialFunc = func() {
if IsMicClose == false {
//if IsMicClose == false {
tmp := schedule.DirectLed{EffectId: atservice.GUIDE_EFFECT_ID_EXEC_CMD, Action: atservice.GUIDE_ACTION_START}
led_mcu.DirectLedControl(tmp.EffectId, tmp.Action, tmp.StartLampNum, []byte{})
}
//}
}
tmpconfig.SpecialFunc = func(arg schedule.TtsPlayerArg) {
if IsMicClose == false {
//if IsMicClose == false {
tmp := schedule.DirectLed{EffectId: atservice.GUIDE_EFFECT_ID_EXEC_CMD, Action: atservice.GUIDE_ACTION_STOP}
led_mcu.DirectLedControl(tmp.EffectId, tmp.Action, tmp.StartLampNum, []byte{})
}
//}
DoOnceInit()
}
player.NoticePlayerSendSCmd2(schedule.SCMD_SuperTask_Tts_Ctrl_Play, tmpconfig)

View File

@ -154,7 +154,9 @@ func DbusYunxinSysMsgControl(data []byte) {
go http.InformMsgToServer(http.Type_Inform_TtsDelay, tmp.Tts)
}
specialFuncBackup := tmpconfig.SpecialFunc
tmpconfig.SpecialFunc = func(arg schedule.TtsPlayerArg) {
specialFuncBackup(arg)
//检查是否网络缓存播放失败
if arg.StopReason == schedule.NoticeStopReason_Error {
go MscToastFile(vui.SoundNotice_Song_Get_Timeout.GetPath(), CONST_AUDIO_ID, false, false, nil)
@ -254,10 +256,21 @@ func DbusYunxinSysMsgControl(data []byte) {
case YxSCmd_ChangeAccountMode:
log.Println(log.DebugLog, "Change account mode!")
schedule.SendSCmdStruct(schedule.SCmdStruct{SCmd: schedule.SCMD_MusicPlayer_Pause, Arg: []interface{}{schedule.PlayerArg{NotShowIcon: true}}, ExecCb: func(cb schedule.SCmdStructExecCb) {
tmp := GetCurVboxBroadcastSt(false)
tmp.PlayerStPtr.ContinuousTaskSt = MUSIC_ST_IDLE
TrigBroadcastStatus(tmp)
var tmp struct {
ModeId int64 `json:"modeid"`
}
err := json.Unmarshal([]byte(cmd.Detail), &tmp)
if err != nil {
log.Println(log.ErrorLog, err.Error())
break
}
PlayListSrcRec.ModeId = tmp.ModeId
schedule.SendSCmdStruct(schedule.SCmdStruct{SCmd: schedule.SCMD_MusicPlayer_Pause, Arg: []interface{}{schedule.PlayerArg{NotShowIcon: true, UserTrig:true}}, ExecCb: func(cb schedule.SCmdStructExecCb) {
tmpSt := GetCurVboxBroadcastSt(false)
tmpSt.PlayerStPtr.ContinuousTaskSt = MUSIC_ST_IDLE
TrigBroadcastStatus(tmpSt)
player.ResetWifiPlayer()
}})

View File

@ -194,7 +194,7 @@ func alarmPlay(alarm *globals.DbusAlarmRemind, canExec bool) {
SendEventByYunxin(DeviceEventType_Alarm, DeviceEventAction_Start, map[string]interface{}{"id": alarm.Id, "timestamp": alarm.ComingTime.Unix() * 1000, "ringtimestamp": time.Now().Unix() * 1000})
if curAlarm == nil {
//to alarm is nil means cur no alarm ring and need backup volume!
time.Sleep(10 * time.Millisecond)
time.Sleep(80 * time.Millisecond)
preVolume, _ = adau1761.GetVol()
if preVolume > globals.DefaultVol.GetCfgListVui() {
VolSet(preVolume)

View File

@ -40,6 +40,8 @@ func GetCurVboxBroadcastSt(print bool) VboxBroadcastSt {
st.DeviceMode = getCurDeviceMode(print)
st.ModeId = PlayListSrcRec.ModeId
st.TimingPauseRemain,st.TimingPauseOnComplete,st.TimingPauseSet = schedule.GetTimeDurationOfTimingPause()
st.CurTask = uint8(schedule.GetCurScheduleDomain())
if st.CurrentStatus == SCENE_FIELD_ST && len(schedule.GetCurScenePlayerDetail().Uuid) == 0 {

View File

@ -9,6 +9,7 @@ import (
"netease_control_center/globals"
"netease_control_center/interfaces"
"netease_control_center/interfaces/log"
"netease_control_center/interfaces/schedule"
)
var (
@ -29,6 +30,9 @@ func BroadcastStatus(st globals.VboxBroadcastSt) {
}
}()
//final pack broadcastSt
st.TimingPauseRemain,st.TimingPauseOnComplete, st.TimingPauseSet = schedule.GetTimeDurationOfTimingPause()
boxData, err := json.Marshal(st)
if err != nil {
log.Println(log.WarningLog, err.Error())

View File

@ -129,7 +129,7 @@ func volChangefunc(vol int) {
if schedule.GetCurPlayer().IsPlaying() || (schedule.GetCurPlayer().InterruptStatus && schedule.GetCurPlayer().PlayAfterResume) {
ctrlMusicByVol = true
schedule.SendSCmd(schedule.SCMD_MusicPlayer_Pause, nil)
schedule.SendSCmd(schedule.SCMD_MusicPlayer_Pause, schedule.PlayerArg{UserTrig:true, NotShowIcon:true, GloablePause:true})
}
} else {
CurVboxVolSt.MuteVol = false

View File

@ -108,6 +108,7 @@ const (
DeviceEventType_Alarm DeviceEventType = 1
DeviceEventType_FirstWifiParing DeviceEventType = 2
DeviceEventType_IotWifiParing DeviceEventType = 3
DeviceEventType_QueryDevStatus DeviceEventType = 4
)
type DeviceEventAction int

View File

@ -176,7 +176,14 @@ func DirectLedControl(EffectId GUIDE_EFFECT_ID, Action GUIDE_ACTION, StartLampNu
defer LastDirectLed.Lock.Unlock()
var toShowLed DirectLed
toShowLed.EffectId = EffectId
tmpEffectId := EffectId
//执行灯目前不随声音而动,改为长亮
if tmpEffectId == GUIDE_EFFECT_ID_EXEC_CMD {
//log.Println(log.WarningLog, "exec cmd: EffectId = ", EffectId, ", action = ", Action)
tmpEffectId = GUIDE_EFFECT_ID_LIGHT_CMD
}
toShowLed.EffectId = tmpEffectId
toShowLed.Action = Action
toShowLed.StartNum = StartLampNum
toShowLed.Data = data
@ -214,6 +221,13 @@ func DirectLedClear(id GUIDE_EFFECT_ID) {
if LastDirectLed.EffectId == GUIDE_EFFECT_ID_VOICE_INPUT {
LastDirectLed.EffectId = GUIDE_EFFECT_ID_CLEAR
}
//执行灯目前不随声音而动,改为长亮, 需要渐变退出
if id == GUIDE_EFFECT_ID_EXEC_CMD {
//log.Println(log.WarningLog, "DirectLedClear, EffectId = ", LastDirectLed.EffectId, ", action = ", LastDirectLed.Action)
LastDirectLed.EffectId = GUIDE_EFFECT_ID_LIGHT_CMD
}
LastDirectLed.Action = GUIDE_ACTION_STOP
LastDirectLed.Data = []byte{}
ShowDirectLed(LastDirectLed)

View File

@ -51,6 +51,7 @@ const (
GUIDE_EFFECT_ID_MIC_OFF GUIDE_EFFECT_ID = 40 //禁Mic灯
GUIDE_EFFECT_ID_VOLUME_ADJUST GUIDE_EFFECT_ID = 41
GUIDE_EFFECT_ID_SYSTEM_ERR GUIDE_EFFECT_ID = 60 //错误灯
GUIDE_EFFECT_ID_LIGHT_CMD GUIDE_EFFECT_ID = 66 //长亮
GUIDE_EFFECT_ID_CLEAR GUIDE_EFFECT_ID = 163
GUIDE_EFFECT_ID_MIC_STAT_OFF GUIDE_EFFECT_ID = 227 //mic status on/off
GUIDE_EFFECT_ID_DO_NOTHING GUIDE_EFFECT_ID = 255

View File

@ -51,6 +51,13 @@ func uartInit() error {
c := &serial.Config{Name: "/dev/ttyS2", Baud: 1500000, FlowCtrl: serial.HWCONTROL_RTS_CTS}
var err error
sPort, err = serial.OpenPort(c)
if err != nil {
log.Println(log.ErrorLog, err)
return errors.New("port open error!")
} else {
flushUart() //flush uart data
sPort.Close()
sPort, err = serial.OpenPort(c)
if err != nil {
log.Println(log.ErrorLog, err)
return errors.New("port open error!")
@ -58,6 +65,7 @@ func uartInit() error {
flushUart() //flush uart data
go uartReadStart()
}
}
return err
}

View File

@ -567,6 +567,12 @@ func GetMusicListNew(playerType PlayerType, ttsNow bool, serverList http.MusicLi
}
}()
list, code, _, err := http.GetMusicListDoNew(serverList)
if int(ERR_SUCCESS) == code && serverList.Source == int(PlayerType_Dlna) {
log.Println(log.WarningLog, "server is return OK for normal dlna")
return nil, Normal_Dlna_Mode
}
if nil != err {
if http.SERVER_RET_NIL_OR_INVALID_LIST == code {
log.Println(log.WarningLog, "nil music list")
@ -575,7 +581,9 @@ func GetMusicListNew(playerType PlayerType, ttsNow bool, serverList http.MusicLi
}
if http.SERVER_RET_TRIG_CMD_OK == code {
log.Println(log.WarningLog, "server is return OK")
//pause@clould music mode
schedule.SendSCmd(schedule.SCMD_MusicPlayer_Pause, schedule.PlayerArg{GloablePause: false, NotShowIcon: true, UserTrig:false})
log.Println(log.WarningLog, "server is return OK for clould music mode")
return nil, nil
}
@ -954,15 +962,15 @@ func mscToastFile(file string, uuid string, needRepeat bool, keep bool, configCh
tmpconfig.IconOut = vui.IconLed_DoNothing
tmpconfig.BeforeSpecialFunc = func() {
if IsMicClose == false {
//if IsMicClose == false {
ttsExecVuiStart()
}
//}
}
tmpconfig.SpecialFunc = func(arg schedule.TtsPlayerArg) {
if IsMicClose == false {
//if IsMicClose == false {
ttsExecVuiStop()
}
//}
//检查是否网络缓存播放失败
if arg.StopReason == schedule.NoticeStopReason_Error {
@ -989,15 +997,15 @@ func mscToastTts(tts string, RespId string, needRepeat bool, keep bool, configCh
tmpconfig.IconOut = vui.IconLed_DoNothing
tmpconfig.BeforeSpecialFunc = func() {
if IsMicClose == false {
//if IsMicClose == false {
ttsExecVuiStart()
}
//}
}
tmpconfig.SpecialFunc = func(arg schedule.TtsPlayerArg) {
if IsMicClose == false {
//if IsMicClose == false {
ttsExecVuiStop()
}
//}
//检查是否网络缓存播放失败
if arg.StopReason == schedule.NoticeStopReason_Error {

View File

@ -3791,13 +3791,13 @@ func getPrepareNextAction() MusicChangeAction {
tmpMaxpage := MusicLenType(max(int(NormalListMap[NORMAL_LIST_PAGE].MaxPage), NormalListMap[NORMAL_LIST_PAGE].List.Len()))
back, _ := NormalListMap[NORMAL_LIST_PAGE].GetLast()
if nil != LocalMusicList[curMusicList].GetValidFrontBackSong(false) &&
if MUSIC_SHARE_RCMD == PlayListSrcRec.MusicSrc { //云村推荐只有一首歌直接从服务器拉取
ret = ACTION_ADD_LIST_MUSIC_SHARE
} else if nil != LocalMusicList[curMusicList].GetValidFrontBackSong(false) &&
LocalMusicList[curMusicList].GetCurPos().Value.(*SongInfo).Id != LocalMusicList[curMusicList].GetValidFrontBackSong(false).Id {
ret = ACTION_PLAY_DIRECT
} else if PRIVATE_FM == PlayListSrcRec.MusicSrc {
ret = ACTION_ADD_LIST_FM
} else if MUSIC_SHARE_RCMD == PlayListSrcRec.MusicSrc {
ret = ACTION_ADD_LIST_MUSIC_SHARE
} else if NormalListMap[NORMAL_LIST_PAGE].HasMore {
// 还有分页
ret = ACTION_NEXT_PAGE_REPLACE_LIST
@ -3868,13 +3868,13 @@ func getNextPrevAction(needNextAction bool) MusicChangeAction {
var ret MusicChangeAction
back, _ := NormalListMap[NORMAL_LIST_PAGE].GetLast()
if needNextAction {
if nil != LocalMusicList[curMusicList].GetValidFrontBackSong(false) &&
if MUSIC_SHARE_RCMD == PlayListSrcRec.MusicSrc { //云村推荐只有一首歌直接从服务器拉取
ret = ACTION_ADD_LIST_MUSIC_SHARE
} else if nil != LocalMusicList[curMusicList].GetValidFrontBackSong(false) &&
LocalMusicList[curMusicList].GetCurPos().Value.(*SongInfo).Id != LocalMusicList[curMusicList].GetValidFrontBackSong(false).Id {
ret = ACTION_PLAY_DIRECT
} else if PRIVATE_FM == PlayListSrcRec.MusicSrc {
ret = ACTION_ADD_LIST_FM
} else if MUSIC_SHARE_RCMD == PlayListSrcRec.MusicSrc {
ret = ACTION_ADD_LIST_MUSIC_SHARE
} else if NormalListMap[NORMAL_LIST_PAGE].HasMore {
// 还有分页
ret = ACTION_NEXT_PAGE_REPLACE_LIST
@ -3914,13 +3914,13 @@ func getNextPrevAction(needNextAction bool) MusicChangeAction {
}
}
} else {
if nil != LocalMusicList[curMusicList].GetValidFrontBackSong(true) &&
if MUSIC_SHARE_RCMD == PlayListSrcRec.MusicSrc { //云村推荐只有一首歌直接从服务器拉取
ret = ACTION_ADD_LIST_MUSIC_SHARE
} else if nil != LocalMusicList[curMusicList].GetValidFrontBackSong(true) &&
LocalMusicList[curMusicList].GetCurPos().Value.(*SongInfo).Id != LocalMusicList[curMusicList].GetValidFrontBackSong(true).Id {
ret = ACTION_PLAY_DIRECT
} else if PRIVATE_FM == PlayListSrcRec.MusicSrc {
ret = ACTION_PLAY_BACK
} else if MUSIC_SHARE_RCMD == PlayListSrcRec.MusicSrc {
ret = ACTION_ADD_LIST_MUSIC_SHARE
} else if NormalListMap[NORMAL_LIST_PAGE].CurPos.Value.(*PageNode).PageIndex >= 2 {
// 前一分页
ret = ACTION_PRE_PAGE_REPLACE_LIST

View File

@ -74,7 +74,8 @@ int Netease_audiobypass_init(struct audio_bypass **bypass, void **cae,
(*bypass)->queue = queue_init((*bypass)->queue_buf, cap);
(*bypass)->running = 0;
(*bypass)->chan = chan;
queue_set_name((*bypass)->queue, "audiobypass");
queue_set_debugcode((*bypass)->queue, 1);
exit:
return ret;
}
@ -98,13 +99,19 @@ static void *audiobypass_read_thread(void *param) {
char *buf = NULL;
int bufsize = 0;
while (bypass->running) {
queue_set_debugcode(bypass->queue, 2);
bufsize = queue_read(bypass->queue, &buf);
if (!buf)
continue;
queue_set_debugcode(bypass->queue, 3);
if (bypass->chan & AUDIO_BYPASS_CHANNEL_MSC_IAT) {
Netease_IAT_write(buf, bufsize);
}
queue_set_debugcode(bypass->queue, 4);
#ifdef ENABLE_YUNXIN
if (bypass->chan & AUDIO_BYPASS_CHANNEL_YUNXIN) {
Netease_yunxin_writeaudio(buf, bufsize);
@ -112,7 +119,9 @@ static void *audiobypass_read_thread(void *param) {
#endif
free(buf);
buf = NULL;
queue_set_debugcode(bypass->queue, 5);
}
queue_set_debugcode(bypass->queue, 6);
n_debug("Audio bypass thread exit");
return NULL;
}

View File

@ -98,7 +98,7 @@ void setVadStatus(VadStatus status) { vad_status = status; }
void BaseInit() {
memset(g_uuid, 0, sizeof(g_uuid));
memset(g_songInfo, 0, sizeof(g_songInfo));
g_pChipId = GetCpuSerial();
g_pChipId = GetCpuChipId();
pthread_mutex_init(&lock, NULL);
}
void BaseLock() { pthread_mutex_lock(&lock); }

View File

@ -30,10 +30,20 @@ audio_queue_t *queue_init(void *base, int capacity) {
queue->front = 0;
queue->rear = 0;
queue->more = true;
queue->debugCode = 0;
queue->name[0] = 0;
return queue;
}
void queue_set_name(audio_queue_t *queue, char *name) {
strncpy(queue->name, name, sizeof(queue->name));
}
void queue_set_debugcode(audio_queue_t *queue, int code) {
queue->debugCode = code;
}
void queue_destroy(audio_queue_t *queue) {
if (NULL != queue) {
pthread_mutex_destroy(&(queue->mutex));
@ -164,7 +174,7 @@ int queue_read(audio_queue_t *queue, char **data) {
temp_buff = (char *)malloc(queueLen);
if (NULL == temp_buff) {
//printf("queue_read malloc error queueLen%d\n", queueLen);
printf("queue_read malloc error queueLen%d\n", queueLen);
pthread_mutex_unlock(&(queue->mutex));
return 0;
}

View File

@ -22,6 +22,8 @@ typedef struct audio_queue_t {
int front; // 队头索引
int rear; // 队尾索引
int more; // 写完标记
char name[20]; //名称
int debugCode; //用来debug
} audio_queue_t;
#ifdef __cplusplus
@ -64,6 +66,9 @@ void queue_set_more(audio_queue_t* queue, int more);
int queue_get_more(audio_queue_t* queue);
void queue_set_name(audio_queue_t *queue, char *name);
void queue_set_debugcode(audio_queue_t *queue, int code);
#ifdef __cplusplus
}
#endif

View File

@ -38,7 +38,7 @@ enum {
// fprintf(stderr, format, ##arg)
#ifdef NETEASE_TOAST
#define n_toast(fmt, arg...) printf(fmt, ##arg)
#define n_toast(fmt, arg...) n_printf(fmt, ##arg)
#else
#define n_toast(fmt, arg...) \
do { \
@ -46,7 +46,7 @@ enum {
#endif
#ifdef NETEASE_DEBUG
#define n_debug(fmt, arg...) do{printf(fmt, ##arg);}while(0)
#define n_debug(fmt, arg...) n_printf(fmt, ##arg)
#else
#define n_debug(fmt, arg...) \
do { \
@ -54,7 +54,7 @@ enum {
#endif
#ifdef NETEASE_ERROR
#define n_error(fmt, arg...) printf(fmt, ##arg)
#define n_error(fmt, arg...) n_printf(fmt, ##arg)
#else
#define n_error(fmt, arg...) \
do { \

View File

@ -116,6 +116,7 @@ int netease_session_destroy(struct IAT_HD *hd);
int netease_audio_write(const char *sessionID, const void *waveData,
unsigned int waveLen, int audioStatus, int *epStatus,
int *recogStatus);
int netease_dc_wakeup_upload(char* pSession);
const char *netease_get_result(const char *sessionID, int *rsltStatus,
int waitTime, int *errorCode);

View File

@ -33,6 +33,10 @@ int Netease_nduilite_init(duilite_callback wakeup_callback,
duilite_callback doa_callback,
duilite_callback beamforming_callback,
duilite_callback vad_callback);
int Netease_nduilite_reinit(duilite_callback wakeup_callback,
duilite_callback doa_callback,
duilite_callback beamforming_callback,
duilite_callback vad_callback);
void Netease_nduilite_writeaudio(const void *audioData, unsigned int audio_len);
int Netease_duilite_vad_start();
int Netease_duilite_vad_stop(char IsLock); // 1 lock, other unlock

View File

@ -29,8 +29,7 @@ extern "C" {
** Types
** ------------------------------------------------------------------------ */
typedef void* REACORD_HANDLE;
typedef void (*recordrecord_audio_fn)(const void *audio, unsigned int audio_len, int err_code);
typedef void (*record_audio_fn)(const void *audio, unsigned int audio_len, int err_code);
typedef void (*record_audio_fn)(const void *audio, unsigned int audio_len, int err_code, audio_queue_t *queue);
/* Configuration for a stream */

View File

@ -34,6 +34,8 @@ void Netease_yunxin_login();
char *Netease_yunxin_dbus_getstatus();
int Netease_yunxin_init(struct audio_bypass **bypass);
void Netease_yunxin_writeaudio(const char *inputbuf, size_t inputsize);
void Netease_yunxin_sendmsg_offline(char *data);
void Netease_yunxin_sendmsg_online(char *data);
#ifdef __cplusplus
} /* extern "C" */

View File

@ -51,6 +51,8 @@ when who why
/* ------------------------------------------------------------------------
** Macros
** ------------------------------------------------------------------------ */
//#define BACKUP_ORIG_AUDIO
//#define BACKUP_FINAL_AUDIO
/* ------------------------------------------------------------------------
** Defines
@ -243,6 +245,16 @@ int Duilite_doa_cb(void *userdata, int type, char *msg, int len) {
BaseUnlock();
}
json_decref(js);
for(int i = 0; i < sizeof(g_pQuickWkKey) / sizeof(g_pQuickWkKey[0]); i++)
{
if(strcmp(getVoiceWakeupword(), g_pQuickWkKey[i]) == 0)
{
netease_dc_wakeup_upload("");
break;
}
}
}
}
@ -298,9 +310,10 @@ static void CAEAudioCb(const void *audioData, unsigned int audioLen, int param1,
#endif
static void record_audio_cb(const void *audio, unsigned int audio_len,
int err_code) {
int err_code, audio_queue_t *queue) {
unsigned long long cachetime;
queue_set_debugcode(queue, 5);
#ifdef DEBUG_WASTE_TIME
Netease_caltime(&cachetime, 1);
#endif
@ -312,6 +325,7 @@ static void record_audio_cb(const void *audio, unsigned int audio_len,
#if USED_NETEASE_FMAE
if (1) {
#elif USED_NETEASE_DUILITE
queue_set_debugcode(queue, 6);
Netease_nduilite_writeaudio(audio, audio_len);
debug_waste_time("duilite_writeaudio", &cachetime);
if (1) {
@ -324,6 +338,7 @@ static void record_audio_cb(const void *audio, unsigned int audio_len,
// unsigned char* pBuf = (unsigned char*)audio;
#if 1
if (Netease_IAT_GetStatus() == IAT_STATUS_AUDIOIN) {
queue_set_debugcode(queue, 7);
DCWriteAudioRec(audio, audio_len);
debug_waste_time("DCWriteAudioRec", &cachetime);
}
@ -350,15 +365,18 @@ static void record_audio_cb(const void *audio, unsigned int audio_len,
isSendCache = 1;
}
#endif
queue_set_debugcode(queue, 8);
__cacheCAEAudio((unsigned char *)audio, audio_len);
debug_waste_time("__cacheCAEAudio", &cachetime);
#endif
#if USED_NETEASE_FMAE && ENABLE_MODULE_XUNFEICAE
queue_set_debugcode(queue, 9);
ret = FMAEAudioWrite(g_hFMAE, audio, audio_len);
// printf("write %d at %p ret = %d\n", audio_len, audio, ret);
#elif ENABLE_MODULE_XUNFEICAE
queue_set_debugcode(queue, 10);
Netease_CAEAudioWrite(caeconfig, audio, audio_len);
#endif
// n_debug("write finish!\n");
@ -480,7 +498,7 @@ static PDBUS_MSG_PACK DBusMessageCb(uv_loop_t *pLoop, DBusConnection *pConn,
tmp = json_dumps(js, 0);
if (!!tmp) {
#ifdef ENABLE_YUNXIN
Netease_yunxin_sendmsg1(tmp);
Netease_yunxin_sendmsg_online(tmp);
#endif
free(tmp);
} else {
@ -494,7 +512,7 @@ static PDBUS_MSG_PACK DBusMessageCb(uv_loop_t *pLoop, DBusConnection *pConn,
case CMD_YUNXIN_SENDMSG:
#ifdef ENABLE_YUNXIN
Netease_yunxin_sendmsg(pMsg->pMsg);
Netease_yunxin_sendmsg_offline(pMsg->pMsg);
#endif
break;
@ -515,6 +533,12 @@ static PDBUS_MSG_PACK DBusMessageCb(uv_loop_t *pLoop, DBusConnection *pConn,
Netease_duilite_fespa_set(pMsg->pMsg);
break;
case CMD_NDUILITE_SDK_REINIT:
Netease_nduilite_reinit(Duilite_wakeup_cb, Duilite_doa_cb,
Duilite_beforming_cb, Duilite_vad_cb);
Netease_duilite_fespa_set(pMsg->pMsg);
break;
default:
break;
}
@ -678,7 +702,7 @@ void main(int argc, char **argv) {
n_debug("Dbus init success\n");
} else {
n_error("Dbus init fail: %d\n", ret);
// return;
return;
}
#if USED_NETEASE_FMAE

View File

@ -83,6 +83,11 @@ int Netease_duilite_fespa_set(char *arg) {
return -1;
}
if (1 != duiliteok) {
n_error("duilite not ok!\n");
return -3;
}
ret = duilite_fespa_set(fespa, arg);
n_debug("Set arg to duilite(ret=%d):%s\n", ret, arg);
}
@ -151,7 +156,7 @@ int Netease_duilite_vad_start() {
#if USED_NETEASE_DUILITE_VAD
int ret = -1;
if (NULL != duilitevad) {
if (NULL != duilitevad && 1 == duiliteok) {
duiliteLock("vad_start");
if (vadstatus == 1) {
n_debug("Begin to stop, in start!\n");
@ -164,6 +169,8 @@ int Netease_duilite_vad_start() {
duiliteUnlock("vad_start");
return ret;
} else {
n_error("Duilite check err, duilitevad:0x%p, duiliteok:%d\n", duilitevad,
duiliteok);
return -1;
}
#else
@ -175,7 +182,7 @@ int Netease_duilite_vad_stop(char IsLock) {
#if USED_NETEASE_DUILITE_VAD
int ret = 0;
n_debug("Begin to stop vad!\n");
if (NULL != duilitevad) {
if (NULL != duilitevad && 1 == duiliteok) {
if (1 == IsLock) {
duiliteLock(" vad_stop ");
}
@ -189,6 +196,8 @@ int Netease_duilite_vad_stop(char IsLock) {
}
return ret;
} else {
n_error("Duilite check err, duilitevad:0x%p, duiliteok:%d\n", duilitevad,
duiliteok);
return -1;
}
#else
@ -199,7 +208,7 @@ int Netease_duilite_vad_stop(char IsLock) {
int Neteaase_duilite_vad_cancel() {
#if USED_NETEASE_DUILITE_VAD
int ret = 0;
if (NULL != duilitevad) {
if (NULL != duilitevad && 1 == duiliteok) {
duiliteLock(" vad_cancel ");
if (1 == vadstatus) {
ret = duilite_vad_cancel(duilitevad);
@ -208,6 +217,9 @@ int Neteaase_duilite_vad_cancel() {
duiliteUnlock(" vad_cancel ");
return ret;
} else {
n_error("Duilite check err, duilitevad:0x%p, duiliteok:%d\n", duilitevad,
duiliteok);
return -1;
}
#else
@ -278,6 +290,7 @@ int Netease_nduilite_init(duilite_callback wakeup_callback,
duilite_callback doa_callback,
duilite_callback beamforming_callback,
duilite_callback vad_callback) {
int ret = 0;
char *auth_cfg = "{\"appKey\":\"15205715844583be\",\"secretKey\":"
"\"e3eee41c3276bd027f2814f6cf3b8991\", "
@ -285,18 +298,19 @@ int Netease_nduilite_init(duilite_callback wakeup_callback,
"aiengine-2.9.5-15205715844583be.provision\", "
"\"serialNumber\":\"/mnt/UDISK/device.number\"}";
///*初始化时默认采用夜间唤醒阈值thresh=0.64;major=0;thresh2=0.42 时间同步成功后再根据实际时间来切换阈值*/
char *cfg =
"{\"aecBinPath\": "
///*初始化时默认采用夜间唤醒阈值thresh=0.59;major=0;thresh2=0.36
///时间同步成功后再根据实际时间来切换阈值*/
char *cfg = "{\"aecBinPath\": "
"\"/usr/share/netease/duilite/fespa/"
"AEC_ch8-2-ch6_2ref_NTES_20180413_v0.9.3.bin\", "
"\"wakeupBinPath\": "
"\"/usr/share/netease/duilite/fespa/"
"wakeup_aihome_ntes_20180817_pre.bin\", "
"wakeup_aihome_ntes_20180914_pre.bin\", "
"\"beamformingBinPath\": "
"\"/usr/share/netease/duilite/fespa/"
"UCA_asr_ch8-2-ch6_70mm_netease_20180425_v1.1.9.bin\", "
"\"env\": \"words=di da di da;thresh=0.64;major=0;thresh2=0.42;\", "
"\"env\": \"words=di da di "
"da;thresh=0.59;major=0;dcheck=0;thresh2=0.36;\", "
"\"rollBack\": 0}";
#if USED_NETEASE_DUILITE_VAD
@ -310,8 +324,13 @@ int Netease_nduilite_init(duilite_callback wakeup_callback,
}
n_debug("Begin to init duilite!\n");
if (0 != duilite_library_load(auth_cfg)) {
n_error("Duilite library load fail!\n");
if (NULL == _duilitelock) {
_duilitelock = native_mutex_create(NULL, NULL);
}
ret = duilite_library_load(auth_cfg);
if (0 != ret) {
n_error("Duilite library load fail!(%d)\n", ret);
return 0;
}
fespa = duilite_fespa_new(cfg);
@ -319,6 +338,7 @@ int Netease_nduilite_init(duilite_callback wakeup_callback,
n_debug("fespa new success!\n");
} else {
n_error("fespa new fail!\n");
duilite_library_release();
return 0;
}
@ -327,13 +347,14 @@ int Netease_nduilite_init(duilite_callback wakeup_callback,
oem_vad_cb = vad_callback;
if (NULL == duilitevad) {
n_debug("Vad new fail!\n");
duilite_fespa_delete(fespa);
duilite_library_release();
return 0;
} else {
n_debug("Vad new success!\n");
}
#endif
_duilitelock = native_mutex_create(NULL, NULL);
duilite_fespa_register(fespa, DUILITE_CALLBACK_FESPA_WAKEUP,
wakeup_callback, NULL);
duilite_fespa_register(fespa, DUILITE_CALLBACK_FESPA_DOA, doa_callback,
@ -394,7 +415,7 @@ void Netease_nduilite_writeaudio(const void *audioData,
return;
}
n_debug("Write nduilite data, len:%d\n", audio_len);
//n_debug("Write nduilite data, len:%d\n", audio_len);
ret = duilite_fespa_feed(fespa, audioData, audio_len);
#if 0
@ -416,3 +437,29 @@ void Netease_nduilite_writeaudio(const void *audioData,
free(newbuf);
#endif
}
int Netease_nduilite_reinit(duilite_callback wakeup_callback,
duilite_callback doa_callback,
duilite_callback beamforming_callback,
duilite_callback vad_callback) {
if (1 == duiliteok) {
duiliteok = 0;
n_debug("Duilite reinit sdk!\n");
usleep(15000);
if (NULL != fespa) {
duilite_fespa_delete(fespa);
fespa = NULL;
}
if (NULL != duilitevad) {
duilite_vad_delete(duilitevad);
duilitevad = NULL;
}
duilite_library_release();
Netease_nduilite_init(wakeup_callback, doa_callback,
beamforming_callback, vad_callback);
}
return 1;
}

View File

@ -45,7 +45,7 @@
#define APP_POSTURL ("wss://vbox-asr.3.163.com/websocket")
#endif
#define AISPEECH_SDK_VERSION "aispeech_1806060936"
#define AISPEECH_SDK_VERSION "aispeech_1809201704"
// extern unsigned int g_bIsUsedTestServer;
@ -193,13 +193,75 @@ int netease_session_destroy(struct IAT_HD *hd) {
static char g_doabuf[32];
int netease_dc_wakeup_upload(char* pSession)
{
#if USED_NETEASE_DC
json_t *js = NULL;
char *tmpdata = NULL;
DataColleParam dcParam;
char *Uuid = getUuid();
if (Uuid[0] == '\0') {
Netease_dbus_initargs();
Uuid = "this is default uuid";
}
DCEndSession();
memset(g_doabuf, 0, 32);
// sprintf(g_doabuf, "%d", hd->angle);
sprintf(g_doabuf, "%d", getAng());
dcParam.URL = GetCurServerAddr(DC_MODULE);
LOG_EX(LOG_Info, "DC URL: %s\n", dcParam.URL);
// dcParam.userId = Uuid;
// dcParam.speakerId = getChipId();
// dcParam.sessionId = hd->sessionId;
// dcParam.doa = g_doabuf;
// wakeupWord 思必驰唤醒回调提供
// major 思必驰唤醒回调提供
// status 思必驰唤醒回调提供
// confidence 思必驰唤醒回调提供
// doa 思必驰唤醒回调提供
// sessionid 会话创建成功id号
// wakeupsdk sdk厂家及版本
// deviceid 音箱ID
// userid 用户ID
js = json_pack("{s:s, s:i, s:i, s:f, s:i, s:s, s:s, s:s, s:s}",
"wakeupWord", getVoiceWakeupword(), "major", getVoiceMajor(),
"status", getVoiceStatus(), "confidence",
getVoiceConfidence(), "doa", getAng(), "sessionid",
pSession, "wakeupsdk", AISPEECH_SDK_VERSION, "deviceid",
getChipId(), "userid", Uuid);
if (js) {
tmpdata = json_dumps(js, 0);
if (tmpdata) {
dcParam.info = tmpdata;
}
n_debug("Dc config:%s\n", tmpdata);
json_decref(js);
}
// printf("+++++++++++dcParam.doa = %s\n", dcParam.doa);
DCStartSession(dcParam);
if (tmpdata) {
free(tmpdata);
}
LOG_EX(LOG_Debug, "Beging WK Data\n");
DCWriteAudioWk(getDCCachebuf(), WAKE_CACHE_DATA_SIZE);
LOG_EX(LOG_Debug, "End WK Data\n");
// g_isSessionOn = 1;
#endif
}
int netease_session_create(struct IAT_HD *hd, char *recType, char *confirmParam,
char *playerStatus) {
int errcode;
#if USED_NETEASE_DC
json_t *js = NULL;
char *tmpdata;
#endif
SRCParam srcParam;
char *Uuid = getUuid();
@ -296,61 +358,7 @@ int netease_session_create(struct IAT_HD *hd, char *recType, char *confirmParam,
hd->sessionId);
}
#if USED_NETEASE_DC
DCEndSession();
DataColleParam dcParam;
memset(g_doabuf, 0, 32);
// sprintf(g_doabuf, "%d", hd->angle);
sprintf(g_doabuf, "%d", getAng());
dcParam.URL = GetCurServerAddr(DC_MODULE);
LOG_EX(LOG_Info, "DC URL: %s\n", dcParam.URL);
// dcParam.userId = Uuid;
// dcParam.speakerId = getChipId();
// dcParam.sessionId = hd->sessionId;
// dcParam.doa = g_doabuf;
// wakeupWord 思必驰唤醒回调提供
// major 思必驰唤醒回调提供
// status 思必驰唤醒回调提供
// confidence 思必驰唤醒回调提供
// doa 思必驰唤醒回调提供
// sessionid 会话创建成功id号
// wakeupsdk sdk厂家及版本
// deviceid 音箱ID
// userid 用户ID
js = json_pack("{s:s, s:i, s:i, s:f, s:i, s:s, s:s, s:s, s:s}",
"wakeupWord", getVoiceWakeupword(), "major", getVoiceMajor(),
"status", getVoiceStatus(), "confidence",
getVoiceConfidence(), "doa", getAng(), "sessionid",
hd->sessionId, "wakeupsdk", AISPEECH_SDK_VERSION, "deviceid",
getChipId(), "userid", Uuid);
if (js) {
tmpdata = json_dumps(js, 0);
if (tmpdata) {
dcParam.info = tmpdata;
}
n_debug("Dc config:%s\n", tmpdata);
json_decref(js);
}
// printf("+++++++++++dcParam.doa = %s\n", dcParam.doa);
DCStartSession(dcParam);
if (tmpdata) {
free(tmpdata);
}
LOG_EX(LOG_Debug, "Beging WK Data\n");
DCWriteAudioWk(getDCCachebuf(), WAKE_CACHE_DATA_SIZE);
LOG_EX(LOG_Debug, "End WK Data\n");
// g_isSessionOn = 1;
#endif
netease_dc_wakeup_upload(hd->sessionId);
return MSP_SUCCESS;
}

View File

@ -112,6 +112,7 @@ static void *QueueReadThread(void *param) {
printf("QueueReadThread record :%p\n", record);
while (record->runing) {
char *data_buff = NULL;
queue_set_debugcode(record->queue, 2);
readLen = queue_read(record->queue, &data_buff);
if (0 == readLen) {
printf("queue_read readLen = 0\n");
@ -121,13 +122,15 @@ static void *QueueReadThread(void *param) {
if (record->buff_size != readLen) {
// printf("\nqueue_read readLen %d\n", readLen);
}
printf("\nqueue_read readLen %d\n", readLen);
//printf("\nqueue_read readLen %d\n", readLen);
if (record->cb)
record->cb(data_buff, readLen, NETEASE_SUCCESS);
record->cb(data_buff, readLen, NETEASE_SUCCESS, record->queue);
free(data_buff);
queue_set_debugcode(record->queue, 3);
}
queue_set_debugcode(record->queue, 4);
printf("QueueReadThread end, running:%d \n", record->runing);
return NULL;
}

View File

@ -249,7 +249,7 @@ int Netease_yunxin_checklogin() {
return loginStatus;
}
void Netease_yunxin_sendmsg(char *data) {
void Netease_yunxin_sendmsg_offline(char *data) {
json_t *tmp = NULL;
char msgid[LEN_UNIXMS] = {0};
char bduser[LEN_UUID] = {0};
@ -269,15 +269,16 @@ void Netease_yunxin_sendmsg(char *data) {
return;
}
tmp = json_pack("{s:i, s:s, s:i, s:s, s:s, s:i}", kNIMMsgKeyToType,
tmp = json_pack("{s:i, s:s, s:i, s:s, s:s, s:i, s:i}", kNIMMsgKeyToType,
kNIMSessionTypeP2P, kNIMMsgKeyToAccount, bduser,
kNIMMsgKeyType, kNIMMessageTypeCustom, kNIMMsgKeyBody, data,
kNIMMsgKeyClientMsgid, msgid, kNIMMsgKeyHistorySave, 1);
kNIMMsgKeyClientMsgid, msgid, kNIMMsgKeyHistorySave, 1,
kNIMMsgKeySetMsgOffline, 1);
if (!!tmp) {
char *body = json_dumps(tmp, 0);
if (!!body) {
n_toast("YunXin send msg: %s\n", body);
n_toast("YunXin send offline msg: %s\n", body);
nim_talk_send_msg(body, NULL, NULL, NULL);
free(body);
} else {
@ -295,7 +296,7 @@ void Netease_yunxin_sendmsg(char *data) {
}
}
void Netease_yunxin_sendmsg1(char *data) {
void Netease_yunxin_sendmsg_online(char *data) {
json_t *tmp = NULL;
char msgid[LEN_UNIXMS];
char bduser[LEN_UUID];
@ -315,15 +316,16 @@ void Netease_yunxin_sendmsg1(char *data) {
return;
}
tmp = json_pack("{s:i, s:s, s:i, s:s, s:s, s:i}", kNIMMsgKeyToType,
tmp = json_pack("{s:i, s:s, s:i, s:s, s:s, s:i, s:i}", kNIMMsgKeyToType,
kNIMSessionTypeP2P, kNIMMsgKeyToAccount, bduser,
kNIMMsgKeyType, kNIMMessageTypeCustom, kNIMMsgKeyBody, data,
kNIMMsgKeyClientMsgid, msgid, kNIMMsgKeyHistorySave, 0);
kNIMMsgKeyClientMsgid, msgid, kNIMMsgKeyHistorySave, 0,
kNIMMsgKeySetMsgOffline, 0);
if (!!tmp) {
char *body = json_dumps(tmp, 0);
if (!!body) {
// n_toast("YunXin send msg: %s\n", body);
// n_toast("YunXin send online msg: %s \n", body);
nim_talk_send_msg(body, NULL, NULL, NULL);
free(body);
} else {

BIN
lib/libduilite/lib/libduilite.so Normal file → Executable file

Binary file not shown.

Binary file not shown.