[源码下载]

重新想象 Windows 8.1 Store Apps (87) - TTS: Speak Text, Speak SSML

作者:webabcd

介绍
重新想象 Windows 8.1 Store Apps 之 TTS(Text To Speech)

  • Speak Text
  • Speak SSML

示例
1、演示如何通过 TTS 朗读一段文本,以及如何将其保存为音频文件
SpeakText.xaml

<Page
x:Class="Windows81.TTS.SpeakText"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Windows81.TTS"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"> <Grid Background="Transparent">
<StackPanel Margin="120 0 0 0"> <!--用于播放音频-->
<MediaElement Name="mediaElement" AutoPlay="False" /> <TextBlock Name="lblMsg" FontSize="14.667" Margin="0 10 0 0" /> <!--需要被 TTS 的文本-->
<TextBlock Name="lblText" FontSize="14.667" Margin="0 10 0 0" Text="TTS 是 Text To Speech 的缩写,即“从文本到语音”,是人机对话的一部分,让机器能够说话。" /> <!--开始 TTS-->
<Button Name="btnSpeakText" Content="Speek Text" Click="btnSpeakText_Click" Margin="0 10 0 0" /> <!--保存 TTS 转换出的音频文件-->
<Button Name="btnSaveAudio" Content="Save Audio" Click="btnSaveAudio_Click" Margin="0 10 0 0" /> </StackPanel>
</Grid>
</Page>

SpeakText.xaml.cs

/*
* 演示如何通过 TTS 朗读一段文本,以及如何将其保存为音频文件
*
* 注:Windows Phone 中的“TTS, 语音识别, 语音命令”请参见:http://www.cnblogs.com/webabcd/archive/2014/01/02/3501356.html
*/ using System;
using System.Collections.Generic;
using Windows.Media.SpeechSynthesis;
using Windows.Storage;
using Windows.Storage.Pickers;
using Windows.Storage.Streams;
using Windows.UI.Popups;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
using Windows.UI.Xaml.Media; namespace Windows81.TTS
{
public sealed partial class SpeakText : Page
{
// TTS 引擎
private SpeechSynthesizer _synthesizer = new SpeechSynthesizer(); public SpeakText()
{
this.InitializeComponent(); lblMsg.Text = "系统支持的语音有:";
// TTS 引擎所支持的全部语音信息
var voices = SpeechSynthesizer.AllVoices;
foreach (VoiceInformation voice in voices)
{
lblMsg.Text += voice.DisplayName + ", ";
} lblMsg.Text += Environment.NewLine;
// 获取或设置当前 TTS 引擎所使用的语音
lblMsg.Text += "当前 TTS 使用的语音是:" + _synthesizer.Voice.DisplayName; // SpeechSynthesizer 实现了 IDisposable 接口
// _synthesizer.Dispose(); this.mediaElement.CurrentStateChanged += mediaElement_CurrentStateChanged;
} void mediaElement_CurrentStateChanged(object sender, RoutedEventArgs e)
{
if (mediaElement.CurrentState == MediaElementState.Paused)
{
btnSpeakText.IsEnabled = true;
}
} // 播放 TTS 音频
private async void btnSpeakText_Click(object sender, RoutedEventArgs e)
{
// TTS 引擎生成的音频流
SpeechSynthesisStream synthesisStream; try
{
// 通过 TTS 引擎将字符串转换成音频流
synthesisStream = await _synthesizer.SynthesizeTextToStreamAsync(lblText.Text);
}
catch (Exception ex)
{
lblMsg.Text = ex.ToString(); synthesisStream = null;
btnSpeakText.IsEnabled = true;
} // 播放音频流
mediaElement.AutoPlay = true;
mediaElement.SetSource(synthesisStream, synthesisStream.ContentType);
mediaElement.Play();
} // 保存 TTS 音频
private async void btnSaveAudio_Click(object sender, RoutedEventArgs e)
{
FileSavePicker savePicker = new FileSavePicker();
savePicker.DefaultFileExtension = ".wav";
savePicker.FileTypeChoices.Add("Audio file", new List<string>() { ".wav" }); StorageFile file = await savePicker.PickSaveFileAsync();
if (file != null)
{
btnSaveAudio.IsEnabled = false; SpeechSynthesisStream synthesisStream;
try
{
synthesisStream = await _synthesizer.SynthesizeTextToStreamAsync(lblText.Text);
}
catch (Exception ex)
{
lblMsg.Text = ex.ToString(); synthesisStream = null;
btnSaveAudio.IsEnabled = true;
} // 保存音频数据到文件
Windows.Storage.Streams.Buffer buffer = new Windows.Storage.Streams.Buffer();
IRandomAccessStream writeStream = (IRandomAccessStream)await file.OpenAsync(FileAccessMode.ReadWrite);
IOutputStream outputStream = writeStream.GetOutputStreamAt();
DataWriter dataWriter = new DataWriter(outputStream); while (synthesisStream.Position < synthesisStream.Size)
{
await synthesisStream.ReadAsync(buffer, , InputStreamOptions.None);
dataWriter.WriteBuffer(buffer);
} dataWriter.StoreAsync().AsTask().Wait();
outputStream.FlushAsync().AsTask().Wait(); btnSaveAudio.IsEnabled = true;
}
}
}
}

2、演示如何通过 TTS 朗读 SSML 协议文档,以及如何将其保存为音频文件
SpeakSSML.xaml

<Page
x:Class="Windows81.TTS.SpeakSSML"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Windows81.TTS"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"> <Grid Background="Transparent">
<StackPanel Margin="120 0 0 0"> <!--用于播放音频-->
<MediaElement Name="mediaElement" AutoPlay="False" /> <TextBlock Name="lblMsg" FontSize="14.667" Margin="0 10 0 0" /> <!--开始 TTS-->
<Button Name="btnSpeakSSML" Content="Speek SSML" Click="btnSpeakSSML_Click" Margin="0 10 0 0" /> <!--保存 TTS 转换出的音频文件-->
<Button Name="btnSaveAudio" Content="Save Audio" Click="btnSaveAudio_Click" Margin="0 10 0 0" /> </StackPanel>
</Grid>
</Page>

SpeakSSML.xaml.cs

/*
* 演示如何通过 TTS 朗读 SSML 协议文档,以及如何将其保存为音频文件
*
* 注:Windows Phone 中的“TTS, 语音识别, 语音命令”请参见:http://www.cnblogs.com/webabcd/archive/2014/01/02/3501356.html
*
*
* 另外:
* 1、SSML - Speech Synthesis Markup Language
* 2、微软关于 ssml 的说明:http://msdn.microsoft.com/en-us/library/hh361578
* 3、W3C 关于 ssml 的说明:http://www.w3.org/TR/speech-synthesis/
*/ using System;
using System.Collections.Generic;
using Windows.Media.SpeechSynthesis;
using Windows.Storage;
using Windows.Storage.Pickers;
using Windows.Storage.Streams;
using Windows.UI.Popups;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
using Windows.UI.Xaml.Media; namespace Windows81.TTS
{
public sealed partial class SpeakSSML : Page
{
// TTS 引擎
private SpeechSynthesizer _synthesizer = new SpeechSynthesizer(); public SpeakSSML()
{
this.InitializeComponent(); lblMsg.Text = "系统支持的语音有:";
// TTS 引擎所支持的全部语音信息
var voices = SpeechSynthesizer.AllVoices;
foreach (VoiceInformation voice in voices)
{
lblMsg.Text += voice.DisplayName + ", ";
} lblMsg.Text += Environment.NewLine;
// 获取或设置当前 TTS 引擎所使用的语音
lblMsg.Text += "当前 TTS 使用的语音是:" + _synthesizer.Voice.DisplayName; // SpeechSynthesizer 实现了 IDisposable 接口
// _synthesizer.Dispose(); this.mediaElement.CurrentStateChanged += mediaElement_CurrentStateChanged;
} void mediaElement_CurrentStateChanged(object sender, RoutedEventArgs e)
{
if (mediaElement.CurrentState == MediaElementState.Paused)
{
btnSpeakSSML.IsEnabled = true;
}
} // 播放 TTS 音频(SSML)
private async void btnSpeakSSML_Click(object sender, RoutedEventArgs e)
{
// TTS 引擎生成的音频流
SpeechSynthesisStream synthesisStream; try
{
// 构造一个 SSML 协议文档
string ssml = "<speak version=\"1.0\" xmlns=\"http://www.w3.org/2001/10/synthesis\" xml:lang=\"zh-CN\">"; // 中文
ssml += "<voice gender=\"male\">"; // 男声
ssml += "<prosody rate=\"-50%\">"; // 语速放慢 50%
ssml += "TTS 是 Text To Speech 的缩写,即“从文本到语音”,是人机对话的一部分,让机器能够说话。";
ssml += "</prosody>";
ssml += "</voice>";
ssml += "</speak>"; // 通过 TTS 引擎将 SSML 协议文档转换成音频流
synthesisStream = await _synthesizer.SynthesizeSsmlToStreamAsync(ssml);
}
catch (Exception ex)
{
lblMsg.Text = ex.ToString(); synthesisStream = null;
btnSpeakSSML.IsEnabled = true;
} // 播放音频流
mediaElement.AutoPlay = true;
mediaElement.SetSource(synthesisStream, synthesisStream.ContentType);
mediaElement.Play();
} // 保存 TTS 音频(SSML)
private async void btnSaveAudio_Click(object sender, RoutedEventArgs e)
{
FileSavePicker savePicker = new FileSavePicker();
savePicker.DefaultFileExtension = ".wav";
savePicker.FileTypeChoices.Add("Audio file", new List<string>() { ".wav" }); StorageFile file = await savePicker.PickSaveFileAsync();
if (file != null)
{
btnSaveAudio.IsEnabled = false; SpeechSynthesisStream synthesisStream;
try
{
// 构造一个 SSML 协议文档
string ssml = "<speak version=\"1.0\" xmlns=\"http://www.w3.org/2001/10/synthesis\" xml:lang=\"zh-CN\">"; // 中文
ssml += "<voice gender=\"male\">"; // 男声
ssml += "<prosody rate=\"-50%\">"; // 语速放慢 50%
ssml += "TTS 是 Text To Speech 的缩写,即“从文本到语音”,是人机对话的一部分,让机器能够说话。";
ssml += "</prosody>";
ssml += "</voice>";
ssml += "</speak>"; // 通过 TTS 引擎将 SSML 协议文档转换成音频流
synthesisStream = await _synthesizer.SynthesizeSsmlToStreamAsync(ssml);
}
catch (Exception ex)
{
lblMsg.Text = ex.ToString(); synthesisStream = null;
btnSaveAudio.IsEnabled = true;
} // 保存音频数据到文件
Windows.Storage.Streams.Buffer buffer = new Windows.Storage.Streams.Buffer();
IRandomAccessStream writeStream = (IRandomAccessStream)await file.OpenAsync(FileAccessMode.ReadWrite);
IOutputStream outputStream = writeStream.GetOutputStreamAt();
DataWriter dataWriter = new DataWriter(outputStream); while (synthesisStream.Position < synthesisStream.Size)
{
await synthesisStream.ReadAsync(buffer, , InputStreamOptions.None);
dataWriter.WriteBuffer(buffer);
} dataWriter.StoreAsync().AsTask().Wait();
outputStream.FlushAsync().AsTask().Wait(); btnSaveAudio.IsEnabled = true;
}
}
}
}

OK
[源码下载]

重新想象 Windows 8.1 Store Apps (87) - TTS: Speak Text, Speak SSML的更多相关文章

  1. 重新想象 Windows 8.1 Store Apps 系列文章索引

    [源码下载] [重新想象 Windows 8 Store Apps 系列文章] 重新想象 Windows 8.1 Store Apps 系列文章索引 作者:webabcd 1.重新想象 Windows ...

  2. 重新想象 Windows 8.1 Store Apps (81) - 控件增强: WebView 之加载本地 html, 智能替换 html 中的 url 引用, 通过 Share Contract 分享 WebView 中的内容, 为 WebView 截图

    [源码下载] 重新想象 Windows 8.1 Store Apps (81) - 控件增强: WebView 之加载本地 html, 智能替换 html 中的 url 引用, 通过 Share Co ...

  3. 重新想象 Windows 8.1 Store Apps (72) - 新增控件: AppBar, CommandBar

    [源码下载] 重新想象 Windows 8.1 Store Apps (72) - 新增控件: AppBar, CommandBar 作者:webabcd 介绍重新想象 Windows 8.1 Sto ...

  4. 重新想象 Windows 8.1 Store Apps (73) - 新增控件: DatePicker, TimePicker

    [源码下载] 重新想象 Windows 8.1 Store Apps (73) - 新增控件: DatePicker, TimePicker 作者:webabcd 介绍重新想象 Windows 8.1 ...

  5. 重新想象 Windows 8.1 Store Apps (74) - 新增控件: Flyout, MenuFlyout, SettingsFlyout

    [源码下载] 重新想象 Windows 8.1 Store Apps (74) - 新增控件: Flyout, MenuFlyout, SettingsFlyout 作者:webabcd 介绍重新想象 ...

  6. 重新想象 Windows 8.1 Store Apps (75) - 新增控件: Hub, Hyperlink

    [源码下载] 重新想象 Windows 8.1 Store Apps (75) - 新增控件: Hub, Hyperlink 作者:webabcd 介绍重新想象 Windows 8.1 Store A ...

  7. 重新想象 Windows 8.1 Store Apps (76) - 新增控件: SearchBox

    [源码下载] 重新想象 Windows 8.1 Store Apps (76) - 新增控件: SearchBox 作者:webabcd 介绍重新想象 Windows 8.1 Store Apps 之 ...

  8. 重新想象 Windows 8.1 Store Apps (77) - 控件增强: 文本类控件的增强, 部分控件增加了 Header 属性和 HeaderTemplate 属性, 部分控件增加了 PlaceholderText 属性

    [源码下载] 重新想象 Windows 8.1 Store Apps (77) - 控件增强: 文本类控件的增强, 部分控件增加了 Header 属性和 HeaderTemplate 属性, 部分控件 ...

  9. 重新想象 Windows 8.1 Store Apps (78) - 控件增强: ScrollViewer, FlipView, Popup

    [源码下载] 重新想象 Windows 8.1 Store Apps (78) - 控件增强: ScrollViewer, FlipView, Popup 作者:webabcd 介绍重新想象 Wind ...

随机推荐

  1. Difference between LET and LET* in Common LISP

    Difference between LET and LET* in Common LISP   LET   Parallel binding which means the bindings com ...

  2. English Metric Units and Open XML

    English Metric Units and Open XML 在Open XML里使用了English Metric Units(EMUs)来作为度量单位.比如 public class Ext ...

  3. SAP GUI SAPLOGON.INI

    GUI是SAP系统最常用的客户端,在一台客户机上,利用GUI可以连接多套SAP系统(连接方法参见<客户端连接配置(SAP GUI 710)>),也可以设置多个快捷方式登录(参见<用快 ...

  4. 表格CSS样式美化

    1. 单像素边框CSS表格 这是一个很常用的表格样式. <!-- CSS goes in the document HEAD or added to your external styleshe ...

  5. Linux高级编程--07.进程间通信

    每个进程各自有不同的用户地址空间,进程之间要交换数据必须通过在内核中开辟缓冲区,从而实现数据共享. 管道 管道是一种最基本的IPC机制,由pipe函数创建: int pipe(int filedes[ ...

  6. 使用Service.Stack客户端编写redis pub sub的方法

    pub相对简单 client.PublishMessage("channel", "msg");   sub有2种方法 方法1 var subscription ...

  7. 编译Libgdiplus遇到的问题

    https://github.com/mono/libgdiplus/releases 下载最新版本 解压并执行  ./autogen.sh,在执行此步时遇到如下问题,并帖出解决办法   问题:执行  ...

  8. nodejs 常用全局包

    1.nodemon 更改node程序后程序自动启动 (nodemon app.js) npm install nodemon  -g 2.gulp 压缩合并代码等 npm install gulp - ...

  9. 利用 ELK系统分析Nginx日志并对数据进行可视化展示

    一.写在前面 结合之前写的一篇文章:Centos7 之安装Logstash ELK stack 日志管理系统,上篇文章主要讲了监控软件的作用以及部署方法.而这篇文章介绍的是单独监控nginx 日志分析 ...

  10. PHP去除BOM头的方法

    BOM头是UTF-8来告诉编辑器:我是UTF8编码.它的编码是\xEF\xBB\xBF 但是PHP在设计之初并没有考虑到BOM头的问题,所以在编解码的时候很容易出现问题   比如今天遇到的问题,jso ...