Как создать языковой бот в прямом канале - PullRequest
0 голосов
/ 25 сентября 2018

Я создаю бота, используя бот-фреймворк, на прямом канале.Я создал 2 ботов, один на английском, один на французском, но моя идея состоит в том, чтобы создать только одного бота и вызывать диалоги englishluis и frenchluis в зависимости от пользователей.

Мой бот также использует распознавание речи.

Вот мой код для французской прямой линии:

<!DOCTYPE html>
 <html>
<head>
<link href="https://cdn.botframework.com/botframework- 
  webchat/latest/botchat.css" rel="stylesheet" />
   </head>
  <body>
<div id="bot" />
<script src="https://cdn.botframework.com/botframework- 
  webchat/latest/botchat.js"></script>
<script src="https://cdn.botframework.com/botframework- 
    webchat/latest/CognitiveServices.js"></script>
<script>
var speechOptions = {
    speechRecognizer: new CognitiveServices.SpeechRecognizer(
        { locale: 'fr-fr', subscriptionKey: 
    'xxxxxxx' }),

    speechSynthesizer: new CognitiveServices.SpeechSynthesizer(
        {
            subscriptionKey: 'xxxxxxxxxxx',
            gender: CognitiveServices.SynthesisGender.Female,
            voiceName: 'Microsoft Server Speech Text to Speech Voice (fr-FR, 
         HortenseRUS)'
        })
}

var botConnection = new BotChat.DirectLine({
    // secret: 
         "yF0xxxxxxxxxxxxxxM",
    secret: "yBxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
    webSocket: true ,

});


  BotChat.App({
        speechOptions: speechOptions,
        botConnection: botConnection,
        user: {
            id: 'userid',
            name: 'User',
        },
        bot: { id: 'botid' },
        resize: 'detect',
        locale: 'fr-FR'

    },
  document.getElementById("bot"));

   function postHelp() {
    botConnection
        .postActivity({
            from: { id: 'userid', name: 'User' },
            name: 'postHelp',
            type: 'message',
            text: 'help'
        })
        .subscribe(function(id) {
            console.log('"postHelp" sent');
        });
};

function welcome() {
    botConnection
        .postActivity({
            from: { id: 'userid', name: 'User' },
            name: 'welcome',
            type: 'event',
            value: 'help'
        })
        .subscribe(function (id) {
            console.log('"welcome" sent');
        });
  }
    </script>
   </body>
    </html>

Как создать функцию для определения языка из messagecontroller.cs, или если у вас есть какие-либо другие идеи, пожалуйста, помогите мне.

Заранее спасибо

Новый код directline.html

<!DOCTYPE html>
<html>
<head>
<link href="https://cdn.botframework.com/botframework- 
 webchat/latest/botchat.css" rel="stylesheet" />
 </head>
 <div id="bot" />
  <script src="https://cdn.botframework.com/botframework- 
 webchat/latest/botchat.js"></script>
  <script src="https://cdn.botframework.com/botframework- 
  webchat/latest/CognitiveServices.js"></script>
  <script>
   var speechOptions = {
    speechRecognizer: new CognitiveServices.SpeechRecognizer(
        { locale: String.localrec, subscriptionKey: 
   'xxxxxxxxxxxxx' }),

    speechSynthesizer: new CognitiveServices.SpeechSynthesizer(
        {
            subscriptionKey: 'xxxxxxxxxxxxxxxx',
            gender: CognitiveServices.SynthesisGender.Female,
           // voiceName: 'Microsoft Server Speech Text to Speech Voice (fr- 
         FR, HortenseRUS)'
            voiceName: String.localevoice

        })
}

var botConnection = new BotChat.DirectLine({
    // secret: "yxxxxxxxxxxxxxxxM",
    secret: "yxxxxxxxxxxxxxxxxxxx",
    webSocket: true ,

  });


      BotChat.App({
        speechOptions: speechOptions,
        botConnection: botConnection,
        user: {
            id: 'userid',
            name: 'User',
        },
        bot: { id: 'botid' },
        resize: 'detect',
        locale: String.localed

    },
document.getElementById("bot"));

function postHelp() {
    botConnection
        .postActivity({
            from: { id: 'userid', name: 'User' },
            name: 'postHelp',
            type: 'message',
            text: 'help'
        })
        .subscribe(function(id) {
            console.log('"postHelp" sent');
        });
};

function welcome() {
    botConnection
        .postActivity({
            from: { id: 'userid', name: 'User' },
            name: 'welcome',
            type: 'event',
            value: 'help'
        })
        .subscribe(function (id) {
            console.log('"welcome" sent');
        });
}
     var getFirstBrowserLanguage = function () {
var nav = window.navigator,
browserLanguagePropertyKeys = ['language', 'browserLanguage', 
'systemLanguage', 'userLanguage'],
i,
language;

    // support for HTML 5.1 "navigator.languages"
 if (Array.isArray(nav.languages)) {
  for (i = 0; i < nav.languages.length; i++) {
    language = nav.languages[i];
    if (language && language.length) {
      return language;
    }
  }
    }

// support for other well known properties in browsers
for (i = 0; i < browserLanguagePropertyKeys.length; i++) {
  language = nav[browserLanguagePropertyKeys[i]];
  if (language && language.length) {
    return language;
    }
   }

    return null;
   };

  console.log(getFirstBrowserLanguage());

let localed = "";
if ((navigator.languages != undefined) || (navigator.languages == "fr") || 
 getFirstBrowserLanguage() =="fr")
String.localed = 'fr-fr';
  else
String.localed = 'en-US';

    let localrec = "";
  if ((navigator.languages != undefined) || (navigator.languages == "fr") || 
  getFirstBrowserLanguage() =="fr")
String.localrec = 'fr-fr';
else
String.localrec = null;


function getVoice(localevoice) {
if (locale.startsWith('fr'))
    return 'Microsoft Server Speech Text to Speech Voice (fr-FR, 
      HortenseRUS)';
else
    return 'Microsoft Server Speech Text to Speech Voice (en-US, ZiraRUS)';
  }

let localevoice = "";
if ((navigator.languages != undefined) || (navigator.languages == "fr") || 
 (getFirstBrowserLanguage() =="fr")  || (navigator.languages[0] == "fr") || 
    (navigator.language == "fr") || (navigator.userLanguage == "fr" ))// IE 
            <= 10

    String.localevoice = 'Microsoft Server Speech Text to Speech Voice (fr- 
           FR, HortenseRUS)';
      else
    String.localevoice = 'Microsoft Server Speech Text to Speech Voice (en- 
                   US, 
         ZiraRUS)';



   </script>
      </body>
     </html>

Теперь проблема в том, что бот может понять, что bonjour для frenchdialog и привет или других слов в английском языке, называют englishdialog.Но когда я начинаю говорить, бот на французском языке читает слова, как это было на английском.Я не могу найти проблему в своем коде

1 Ответ

0 голосов
/ 26 сентября 2018

Вы можете проверить свойство .Locale действия в контроллере сообщений и загрузить на его основе другой диалог:

if (activity.Locale.StartsWith("fr"))
    await Conversation.SendAsync(activity, () => new FrenchLuisDialog());
else
    await Conversation.SendAsync(activity, () => new EnglishLuisDialog());

А на странице, на которой размещен элемент управления веб-чата, получить локаль из навигатора и использоватьчтобы установить распознаватель речи, выбрать голос и установить локаль для BotChat.App:

<script>

function getVoice(locale) {
    if (locale.startsWith('fr'))
        return 'Microsoft Server Speech Text to Speech Voice (fr-FR, HortenseRUS)';
    else
        return 'Microsoft Server Speech Text to Speech Voice (en-US, ZiraRUS)';
}

let locale = "";
if (navigator.languages != undefined)
    locale = navigator.languages[0];
else
    locale = navigator.language;


var speechOptions = {
    speechRecognizer: new CognitiveServices.SpeechRecognizer(
        {locale: locale, subscriptionKey:'xxxxxxx' }),

    speechSynthesizer: new CognitiveServices.SpeechSynthesizer(
        {
            subscriptionKey: 'xxxxxxxxxxx',
            gender: CognitiveServices.SynthesisGender.Female,
            voiceName: getVoice(locale)
        })
}

var botConnection = new BotChat.DirectLine({
    secret: "yBxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
    webSocket: true ,

});


  BotChat.App({
        speechOptions: speechOptions,
        botConnection: botConnection,
        user: {
            id: 'userid',
            name: 'User',
        },
        bot: { id: 'botid' },
        resize: 'detect',
      locale: locale

    },
  document.getElementById("bot"));

...

...