I Voice Command Definition sono dei file XML che permettono di configurare quali sono i comandi vocali, gestiti da Windows Phone 8, a cui la nostra applicazione risponde.
Per una trattazione più approfondita sull’argomento vi rimando al blog di Michele Locuratolo (anatomia del file VCD, registrazione del file VCD, Gestione del Voice Command).
In questo post vorrei suggerire un modo per gestire dinamicamente l’installazione e la configurazione di tali file.
Una app può installare un solo VCD e, una volta installato, si possono solamente modificare le phrase list e non si possono aggiungere o rimuovere i comandi (a meno di non reinstallare il file).
L’idea è quella di creare una struttura dati che descriva il voice command definition:
e, utilizzando, queste strutture costruire “al volo” i file VCD da salvare su storage e installare in maniera “canonica”.
- Public Shared Async Function InstallVoiceCommandDefinitionAsync(voiceCommandDefinition As VoiceCommandDefinition) As Task
- If voiceCommandDefinition Is Nothing Then Throw New ArgumentNullException("voiceCommandDefinition")
- Try
- Dim xmlString = CreateXml(voiceCommandDefinition)
- If Await SaveAsync(VCDFileName, xmlString) Then
- Await MSSpeech.VoiceCommandService.InstallCommandSetsFromFileAsync(GetLocalUri(VCDFileName))
- End If
- Catch ex As Exception
- Dim newEx = ExceptionFactory.CreateException(ex)
- Throw newEx
- End Try
- End Function
In questo contesto non stiamo a dettagliare i vari metodi utilizzati (anche perchè il codice è disponibile su Codeplex).
In sostanza potremo creare una nostra classe VoiceCommandService che fa da wrapper all’omologa fornita dalle Speech API di Windows Phone 8 e che fornisce, oltre alle funzioni di serie, anche la possibilità di creare ed installare al volo un VCD.
Un esempio può essere:
- Public Async Function InstallVCD() As task
- Dim vcd = New VoiceCommandDefinition
- ' Define command set
- Dim cs = New CommandSet
- cs.Name = "MyAppCommandSet"
- cs.Culture = "en-US"
- cs.CommandPrefix = "MyApp"
- cs.Example = "Sample"
- vcd.AddCommandSet(cs)
- ' Define single Command
- Dim c = New Command() With {.Name = "OpenDocument",
- .Feedback = "I'm opening a document...",
- .Example = "Open a document"}
- c.ListenForList.Add("open [a] document")
- c.ListenForList.Add("show [a] document")
- cs.AddCommand(c)
- ' Try to install the VCD
- Try
- Await VoiceCommandService.InstallVoiceCommandDefinitionAsync(vcd)
- MessageBox.Show("VCD installed correctly")
- Catch ex As Exception
- MessageBox.Show(ex.Message)
- End Try
- End Function
Sta alla nostra fantasia, poi, utilizzare le funzionalità di configurazione al volo in maniera opportuna. Ad esempio si potrebbero attivare comandi in base alle funzionalità acquistate dall’utente o permettere allo stesso di personalizzare i propri comandi.
Il progetto, il cui nome è DynamicVCD, è disponibile in licensa Ms-PL su CodePlex all’indirizzo https://dynamicvcd.codeplex.com/ ed è disponibile anche su NuGet (https://www.nuget.org/packages/DynamicVCD/).
Critiche, consigli e proposte di nuove funzionalità sono bene accetti!
Commenti