Skip to content

Files

 
 

demo-RollerSkill

Roller Skill Bot Sample

A sample bot optimized for speech-enabled channels such as Cortana.

Deploy to Azure

Prerequisites

The minimum prerequisites to run this sample are:

Code Highlights

Many channels provides an audio component besides the usual visual component, allowing your bot to have a voice. The BotBuilder SDK has set of features designed specifically to support speech based channels such as Cortana.

The IMessageActivity interface contains two properties (Speak and InputHint) to support speech responses allowing you to define what the bot will say and the speech based client should manage the microphone.

The Speak property should contain text or Speech Synthesis Markup Language (SSML).

The InputHint property expects one of the following values from the InputHints enumeration:

Name Description
AcceptingInput Your bot is passively ready for input but is not waiting on a response (the mic should be closed)
ExpectingInput Your bot is actively expecting a response from the user (the mic should be left open)
IgnoringInput Your bot is ignoring input. Bots may send this hint if they are actively processing a request and will ignore input from users until the request is complete

In general the BotBuilder SDK will send these hints for you automatically, so you don't have to worry too much about them. Checkout the use of the Speak and InputHint properties in the StartAsync method from the HelpDialog class.

public async Task StartAsync(IDialogContext context)
{
    var message = context.MakeMessage();
    message.Speak = SSMLHelper.Speak(Resources.HelpSSML);
    message.InputHint = InputHints.AcceptingInput;

    message.Attachments = new List<Attachment>
    {
        new HeroCard(Resources.HelpTitle)
        {
            Buttons = new List<CardAction>
            {
                new CardAction(ActionTypes.ImBack, "Roll Dice", value: RollDiceOptionValue),
                new CardAction(ActionTypes.ImBack, "Play Craps", value: PlayCrapsOptionValue)
            }
        }.ToAttachment()
    };

    await context.PostAsync(message);

    context.Done<object>(null);
}

Built-in prompts also have speech support and they can send plain text as well as SSML thanks to the Speak and RetrySpeak properties from the PromptOptions<T> class. Checkout the use of the Speak property in a PromptChoice dialog in the StartAsync method from the CreateGameDialog class.

public async Task StartAsync(IDialogContext context)
{
    context.UserData.SetValue<GameData>(Utils.GameDataKey, new GameData());

    var descriptions = new List<string>() { "4 Sides", "6 Sides", "8 Sides", "10 Sides", "12 Sides", "20 Sides" };
    var choices = new Dictionary<string, IReadOnlyList<string>>()
        {
        { "4", new List<string> { "four", "for", "4 sided", "4 sides" } },
        { "6", new List<string> { "six", "sex", "6 sided", "6 sides" } },
        { "8", new List<string> { "eight", "8 sided", "8 sides" } },
        { "10", new List<string> { "ten", "10 sided", "10 sides" } },
        { "12", new List<string> { "twelve", "12 sided", "12 sides" } },
        { "20", new List<string> { "twenty", "20 sided", "20 sides" } }
    };

    var promptOptions = new PromptOptions<string>(
        Resources.ChooseSides,
        choices: choices,
        descriptions: descriptions,
        speak: SSMLHelper.Speak(Utils.RandomPick(Resources.ChooseSidesSSML)));

    PromptDialog.Choice(context, this.DiceChoiceReceivedAsync, promptOptions);
}

Outcome

You will see the following when talking to the Bot via Cortana.

Sample Outcome

More Information

To get more information about how to get started in Bot Builder for .NET and Attachments please review the following resources: