.NETアセンブリとして利用
C#などによる.NETプログラム向けインターフェイスです。
専用APIで感情やコンディションを細かく制御することが可能です。
Visual Studio 2019で新しいプロジェクトを作成する場合、名前に(.NET Framework)とあるテンプレートを選んで、フレームワークに「.NET Framework 4.8」を指定します。
本ソフトのインストールフォルダにある下記DLLを、開発プロジェクトに参照登録してください。
上記DLLは本ソフトのインストール時にGACに登録されるため、インストール場所が異なる環境でも作成したプログラムは動作します。そのため、上記DLLを作成したプログラムと一緒に再頒布する必要はありません。
(許可なく本ソフトの一部または全部を再頒布することは禁止です。)
※上記のサンプルプロジェクトです。解凍後、Visual Studio 2019以降でソリューションを読み込むと実行できます。
※.NETの仕様や開発方法については、MSDN等の関連ドキュメントをご参照ください。
専用APIで感情やコンディションを細かく制御することが可能です。
.NET Frameworkについて
.NET連携APIを利用するアプリの開発には、.NET Framework 4.8 SDKが必要です。Visual Studio 2019の場合、Visual Studio Installerの「変更」→「個別のコンポーネント」で「.NET Framework 4.8 SDK」と「.NET Framework 4.8 Targeting Pack」をインストールしておいてください。(この手順ができない環境では、マイクロソフト社のページから.NET Framework 4.8 Developer Packをダウンロードしてインストールしてください。)Visual Studio 2019で新しいプロジェクトを作成する場合、名前に(.NET Framework)とあるテンプレートを選んで、フレームワークに「.NET Framework 4.8」を指定します。
DLLについて
.NET連携APIを利用するアプリの開発には、本ソフトのインストールフォルダにあるDLLが必要となります。本ソフトのインストールフォルダにある下記DLLを、開発プロジェクトに参照登録してください。
CeVIO.Talk.RemoteService2.dll
上記DLLは本ソフトのインストール時にGACに登録されるため、インストール場所が異なる環境でも作成したプログラムは動作します。そのため、上記DLLを作成したプログラムと一緒に再頒布する必要はありません。
(許可なく本ソフトの一部または全部を再頒布することは禁止です。)
API仕様
.NET連携API仕様
// トーク機能を提供します。
class Talker2
{
uint Volume { get; set; }
// 音の大きさ(0~100)を取得または設定します。
uint Speed { get; set; }
// 話す速さ(0~100)を取得または設定します。
uint Tone { get; set; }
// 音の高さ(0~100)を取得または設定します。
uint Alpha { get; set; }
// 声質(0~100)を取得または設定します。
uint ToneScale { get; set; }
// 抑揚(0~100)を取得または設定します。※バージョン4.0.7.0追加。
TalkerComponentCollection2 Components { get; }
// 現在のキャストの感情パラメータマップを取得します。
// 内容はCastによって変化します。
// 例1『さとうささら』→ "普通", "元気", "怒り", "哀しみ"
// 例2『小春六花』→ "嬉しい", "普通", "怒り", "哀しみ", "落ち着き"
string Cast { get; set; }
// キャストを取得または設定します。
static string[] AvailableCasts { get; }
// 利用可能なキャスト名を取得します。
// 備考:
// インストールされているボイスによります。
SpeakingState2 Speak(string text);
// 指定したセリフの再生を開始します。
// 引数:
// text - セリフ。
// 戻り値:
// 再生状態を表すオブジェクト。
// 備考:
// 再生終了を待たずに処理が戻ります。
// 再生終了を待つには戻り値(SpeakingState)のWaitを呼び出します。
bool Stop();
// 再生を停止します。
// 戻り値:
// 成功した場合はtrue。それ以外の場合はfalse。
double GetTextDuration(string text);
// 指定したセリフの長さを取得します。
// 引数:
// text - セリフ。
// 戻り値:
// 長さ。単位は秒。
PhonemeData2[] GetPhonemes(string text);
// 指定したセリフの音素単位のデータを取得します。
// 引数:
// text - セリフ。
// 戻り値:
// 音素単位のデータ。
// 備考:
// リップシンク等に利用できます。
bool OutputWaveToFile(string text, string path);
// 指定したセリフをWAVファイルとして出力します。
// 引数:
// text - セリフ。
// path - 出力先パス。
// 戻り値:
// 成功した場合はtrue。それ以外の場合はfalse。
// 備考:
// 出力形式はサンプリングレート48kHz, ビットレート16bit, モノラルです。
}
// キャストの感情パラメータマップを表すオブジェクト。
class TalkerComponentCollection2
{
int Count { get; }
// 要素数を取得します。
TalkerComponent2 this[int index] { get; }
// 指定したインデックスの要素を取得します。
// 引数:
// index - インデックス。
// 戻り値:
// 要素。
TalkerComponent2 this[string name] { get; }
// 指定した名前の要素を取得します。
// 引数:
// name - 名前。
// 戻り値:
// 要素。
}
// 感情パラメータの単位オブジェクト。
class TalkerComponent2
{
string Id { get; }
// 識別子を取得します。
string Name { get; }
// 感情の名前を取得します。
uint Value { get; set; }
// 感情の値(0~100)を取得または設定します。
}
// 再生状態を表すオブジェクト。
class SpeakingState2
{
bool IsCompleted { get; }
// 再生が完了したかどうかを取得します。
// 完了した場合はtrue。(失敗を含む)それ以外の場合はfalse。
bool IsSucceeded { get; }
// 再生が成功したかどうかを取得します。
// 成功した場合はtrue。それ以外の場合はfalse。
void Wait();
// 再生終了を待ちます。
void Wait(double timeout);
// 再生終了を待ちます。
// 引数:
// timeout - 最大待機時間。単位は秒。(0未満は無制限)
}
// 音素データの単位オブジェクト。
class PhonemeData2
{
string Phoneme { get; }
// 音素を取得します。
double StartTime { get; }
// 開始時間を取得します。単位は秒。
double EndTime { get; }
// 終了時間を取得します。単位は秒。
}
// 【CeVIO AI】制御機能を提供します。
static class ServiceControl2
{
static string HostVersion { get; }
// 【CeVIO AI】のバージョンを取得します。
static bool IsHostStarted { get; }
// 【CeVIO AI】にアクセス可能かどうか取得します。
static HostStartResult StartHost(bool noWait);
// 【CeVIO AI】を起動します。起動済みなら何もしません。
// 引数:
// noWait - trueは起動のみ行います。アクセス可能かどうかはIsHostStartedで確認します。
// falseは起動後に外部からアクセス可能になるまで制御を戻しません。
// 戻り値:
// 結果コード。
static void CloseHost(HostCloseMode mode = HostCloseMode.Default);
// 【CeVIO AI】に終了を要求します。
// 引数:
// mode - 処理モード。
}
// StartHost() の結果コードを表します。
enum HostStartResult
{
Succeeded = 0,
// 成功。起動済みの場合も含みます。
NotRegistered = -1,
// インストール状態が不明。
FileNotFound = -2,
// 実行ファイルが見つからない。
StartingFailed = -3,
// プロセスの起動に失敗。
HostError = -4
// アプリケーション起動後、エラーにより終了。
}
// CloseHost() の処理モードを表します。
enum HostCloseMode
{
Default = 0
// 【CeVIO AI】が編集中の場合、保存や終了キャンセルが可能。
}
サンプルプログラム
.NET連携サンプル(C#)
using CeVIO.Talk.RemoteService2;
namespace CeVIOCreativeStudioDotNetTest
{
class Program
{
static void Main(string[] args)
{
// 【CeVIO AI】起動
ServiceControl2.StartHost(false);
// Talkerインスタンス生成
Talker2 talker = new Talker2();
// キャスト設定
talker.Cast = "さとうささら";
// (例)音量設定
talker.Volume = 100;
// (例)抑揚設定
talker.ToneScale = 100;
// (例)再生
SpeakingState2 state = talker.Speak("こんにちは");
state.Wait();
// (例)音素データをトレース出力
PhonemeData2[] phonemes = talker.GetPhonemes("はじめまして");
foreach (var phoneme in phonemes)
{
System.Diagnostics.Trace.WriteLine("" + phoneme.Phoneme + " " + phoneme.StartTime + " " + phoneme.EndTime);
}
// 【CeVIO AI】終了
ServiceControl2.CloseHost();
}
}
}
※.NETの仕様や開発方法については、MSDN等の関連ドキュメントをご参照ください。