1

Microsoft SAPI5 音声エンジンを使用するアプリケーションを開発しています。しかし、私は壁にぶち当たりました。TTSエンジンがそれを繰り返すことができるように、ユーザーからの入力を格納する変数のデータを使用しようとしています。しかし、sapi5 音声関数は、私の研究ではワイド文字列へのポインタである LPCWSTR 以外の文字列、wstring、またはその他の型を許可していません。

msdn のコード例を次に示します。

#include <stdafx.h>
#include <sapi.h>

int main(int argc, char* argv[])
{
    ISpVoice * pVoice = NULL;

    if (FAILED(::CoInitialize(NULL)))
        return FALSE;

    HRESULT hr = CoCreateInstance(CLSID_SpVoice, NULL, CLSCTX_ALL, IID_ISpVoice, (void **)&pVoice;);
    if( SUCCEEDED( hr ) )
    {
        hr = pVoice->Speak(L"Hello world", 0, NULL);
        pVoice->Release();
        pVoice = NULL;
    }

    ::CoUninitialize();
    return TRUE;
}

たとえば、次のコードがあるとしましょう。

...
wstring text;
if( SUCCEEDED( hr ) )
    {
        wcin >> text;
        hr = pVoice->Speak(text, SPF_IS_XML, NULL);
        pVoice->Release();
        pVoice = NULL;
    }
...

しかし、これはうまくいきません。LPCWSTR 型を許可する変数を格納するにはどうすればよいですか? 私はC ++が初めてで、この種の問題が発生したのはこれが初めてなので、私にとっては非常に新しいものです。

このトピックのOPにはまったく同じ問題があることがわかりました: https://stackoverflow.com/questions/12292790/how-do-i-use-variables-in-sapi-tts

4

1 に答える 1

0

約2時間のしっかりとした調査の後、文字列をLPCWSTR形式に変換することに関するmsdnに関する記事を見つけました。コードは以下のとおりです。

std::wstring s2ws(const std::string& s)
{
    int len;
    int slength = (int)s.length() + 1;
    len = MultiByteToWideChar(CP_ACP, 0, s.c_str(), slength, 0, 0); 
    wchar_t* buf = new wchar_t[len];
    MultiByteToWideChar(CP_ACP, 0, s.c_str(), slength, buf, len);
    std::wstring r(buf);
    delete[] buf;
    return r;
}

次に、このコードをプロジェクトに含め、TTSエンジン初期化関数用にLPCWSTR Repeatという関数パラメーターを作成しました(変換された文字列をTTS関数で使用でき、エンジンが変換された文字列の内容を言うように) 。

static int TTS_Speak_Dialogue(LPCWSTR Repeat)
        {
            // Set Sapi5 voice properties
            ISpVoice * pVoice = NULL;

            if (FAILED(::CoInitialize(NULL)))
            return FALSE;

            // Create new instance of Sapi5 once initialized in COM 
            HRESULT hr = CoCreateInstance(CLSID_SpVoice, NULL, CLSCTX_ALL, IID_ISpVoice, (void **)&pVoice);

                if( SUCCEEDED( hr ) )
                {
                    hr = pVoice->Speak(Repeat, SPF_IS_XML, NULL);
                    pVoice->Release();
                    pVoice = NULL;
                }

            ::CoUninitialize();
            return TRUE;
        }

次に、TTSエンジンがそれを繰り返すことができるように、変換を管理し、ユーザー入力を管理する別の関数を作成しました。

static void convert_string() 
{
    // Declare a string type variable
    string UserInput;
    // Now get input from user
    cout << "Get the TTS to repeat Input : ";
    cin >> UserInput;

    // Convert string to LPCWSTR!
    std::wstring stemp = s2ws(UserInput);
    // UserInput string now converted to result
    LPCWSTR result = stemp.c_str();

    // Call the TTS engine function and use the converted string
    TTS_Speak_Dialogue(result);
}

私の答えが、私と同じ問題を抱えている人々に役立つことを願っています。

私の答えをもっと詳しく説明したと思いますが、睡眠が必要なので、心からお詫び申し上げます:-)。

于 2013-03-22T22:28:50.447 に答える