Blazor.SpeechRecognition.WebAssembly
9.0.0
See the version list below for details.
dotnet add package Blazor.SpeechRecognition.WebAssembly --version 9.0.0
NuGet\Install-Package Blazor.SpeechRecognition.WebAssembly -Version 9.0.0
<PackageReference Include="Blazor.SpeechRecognition.WebAssembly" Version="9.0.0" />
paket add Blazor.SpeechRecognition.WebAssembly --version 9.0.0
#r "nuget: Blazor.SpeechRecognition.WebAssembly, 9.0.0"
// Install Blazor.SpeechRecognition.WebAssembly as a Cake Addin #addin nuget:?package=Blazor.SpeechRecognition.WebAssembly&version=9.0.0 // Install Blazor.SpeechRecognition.WebAssembly as a Cake Tool #tool nuget:?package=Blazor.SpeechRecognition.WebAssembly&version=9.0.0
Blazorators: The Source Generated speechRecognition
JavaScript Interop library for Blazor WebAssembly
The Blazor.SpeechRecognition.WebAssembly
package consumes the Blazor.SourceGenerators
package. It exposes a source generated ISpeechRecognition
interface specific to Blazor WebAssembly and the speechRecognition
Web API.
Get started
After the NuGet package is added as a reference, call the AddSpeechRecognitionServices
method to register the ISpeechRecognitionService
type.
using Microsoft.AspNetCore.Components.Web;
using Microsoft.AspNetCore.Components.WebAssembly.Hosting;
var builder = WebAssemblyHostBuilder.CreateDefault(args);
builder.RootComponents.Add<App>("#app");
builder.RootComponents.Add<HeadOutlet>("head::after");
builder.Services.AddScoped(
sp => new HttpClient
{
BaseAddress = new Uri(builder.HostEnvironment.BaseAddress)
});
builder.Services.AddSpeechRecognitionServices();
await builder.Build().RunAsync();
Anywhere needed within your Razor component, or Blazor client code — either @inject
or [Inject]
the ISpeechRecognitionService
type. The interface takes the following shape:
namespace Microsoft.JSInterop;
/// <summary>
/// A service the exposes various JavaScript interop capabilities specific to the
/// <c>speechRecognition</c> APIs. See <a href="https://developer.mozilla.org/docs/Web/API/SpeechRecognition"></a>
/// </summary>
public interface ISpeechRecognitionService : IAsyncDisposable
{
/// <summary>
/// Call once, before using in the consuming components
/// <c>OnAfterRenderAsync(bool firstRender)</c> override, when firstRender is <c>true</c>.
/// </summary>
Task InitializeModuleAsync();
/// <summary>
/// Cancels the active speech recognition session.
/// </summary>
/// <param name="isAborted">
/// Is aborted controls which API to call,
/// either <c>speechRecognition.stop</c> or <c>speechRecognition.abort</c>.
/// </param>
void CancelSpeechRecognition(bool isAborted);
/// <summary>
/// Starts the speech recognition process. Returns an <see cref="IDisposable"/>
/// that acts as the subscription. The various callbacks are invoked as they occur,
/// and will continue to fire until the subscription is disposed of.
/// </summary>
/// <param name="language">The BCP47 language tag.</param>
/// <param name="onRecognized">The callback to invoke when <c>onrecognized</c> fires.</param>
/// <param name="onError">The optional callback to invoke when <c>onerror</c> fires.</param>
/// <param name="onStarted">The optional callback to invoke when <c>onstarted</c> fires.</param>
/// <param name="onEnded">The optional callback to invoke when <c>onended</c> fires.</param>
/// <returns>
/// To unsubscribe from the speech recognition, call
/// <see cref="IDisposable.Dispose"/>.
/// </returns>
IDisposable RecognizeSpeech(
string language,
Action<string> onRecognized,
Action<SpeechRecognitionErrorEvent>? onError = null,
Action? onStarted = null,
Action? onEnded = null);
}
Initialize the module
In the consuming component, call ISpeechRecognitionService.InitializeModuleAsync
in the OnAfterRenderAsync
override:
public partial class ExampleConsumingComponent
{
[Inject]
public ISpeechRecognitionService SpeechRecognition { get; set; } = null!;
protected override async Task OnAfterRenderAsync(bool firstRender)
{
if (firstRender)
{
await SpeechRecognition.InitializeModuleAsync();
}
}
// Omitted for brevity...
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net8.0
- Microsoft.Extensions.DependencyInjection (>= 8.0.0)
- Microsoft.Extensions.Primitives (>= 8.0.0)
- Microsoft.JSInterop (>= 8.0.0)
- System.Reactive.Linq (>= 6.0.0)
-
net9.0
- Microsoft.Extensions.DependencyInjection (>= 9.0.0)
- Microsoft.Extensions.Primitives (>= 9.0.0)
- Microsoft.JSInterop (>= 9.0.0)
- System.Reactive.Linq (>= 6.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories (3)
Showing the top 3 popular GitHub repositories that depend on Blazor.SpeechRecognition.WebAssembly:
Repository | Stars |
---|---|
Azure-Samples/azure-search-openai-demo-csharp
A sample app for the Retrieval-Augmented Generation pattern running in Azure, using Azure Cognitive Search for retrieval and Azure OpenAI large language models to power ChatGPT-style and Q&A experiences.
|
|
IEvangelist/learning-blazor
The application for the "Learning Blazor: Build Single Page Apps with WebAssembly and C#" O'Reilly Media book by David Pine.
|
|
IEvangelist/blazor-azure-openai
The Blazor WebAssembly app that inspired the Microsoft //Build 2023 demo app.
|
Version | Downloads | Last updated |
---|---|---|
9.0.1 | 245 | 12/1/2024 |
9.0.0 | 160 | 11/22/2024 |
8.0.0 | 24,661 | 11/17/2023 |
8.0.0-rc.2.23480.2 | 2,284 | 10/13/2023 |
7.0.3 | 7,247 | 2/15/2023 |
7.0.2 | 298 | 2/7/2023 |
7.0.1 | 316 | 1/24/2023 |
7.0.0 | 315 | 1/11/2023 |
2.0.11 | 461 | 10/10/2022 |
2.0.10 | 2,479 | 5/19/2022 |
2.0.9 | 496 | 4/18/2022 |
2.0.8 | 440 | 4/14/2022 |
2.0.7 | 450 | 4/14/2022 |
2.0.6 | 456 | 4/7/2022 |
2.0.5 | 871 | 4/5/2022 |