현실감각 0% :: 'text to speech' 태그의 글 목록

컴퓨터 관련 2012. 10. 2. 11:46

C#에서 무료 TTS 사용하기



추석때 집구석에서 할짓없어 이것저것 만들어보다가 TTS가 필요하게 되어서 검색

그러다가 Microsoft사에서 제공하는 무료 TTS 발견!! 물론 License 뭐시기 하는 페이지가 있긴 하지만 뭐 개인용으로 쓸거니 안읽어봐도 무료일듯.

 

 

아참.. TTS를 검색하러 들어온 것이 아닌데 얼떨결에 이 포스트를 봐 버린 사람들에게 TTS를 설명하자면

 

TTS란??

'Text To Speech' 즉 문자열을 말소리로 바꾸어주는 시스템을 의미한다.

뭐 우리 실생활 주변에서 흔히 접할 수 있는데 꼭 예를 들자면..

각종 ATM이나 티켓 자판기를 사용할 때 일만 이천 오백 이십 원 입니다. 하는식으로 또박또박 말해주는 기계음 아가씨가 대표적인 예이고, 기차역에서 어색한 음색의 기계 아줌마(아가씨?)가 "12시 50분에 부산으로 가는 무궁화호 열차가 타는곳 2번, 2번으로 들어오고 있습니다." 하는 것도 TTS의 일종이라 할 수 있겠다.

 

 

 

욜리 쉬운 사용법 따라하기

 

우선 Microsoft사 공식 홈페이지 가서 아래 3개를 다운받는다.

 

 

  http://www.microsoft.com/en-us/download/details.aspx?id=27225 

 

  먼저 모든 컴퓨터에 설치해야 할 런타임 파일을 다운로드 후 설치

 

  당연한 거지만 이놈은 개발 PC 뿐만 아니라 배포 할 PC에도 설치해야 한다.

  License 파일은 가볍게 무시해주고(-_-;;) x64와 x86중에 자신의 컴퓨터에 맞는것을 설치.

  뭘 설치해야 할지 모르겠다면 그냥 x86 고고!~

 

  혹시 링크가 깨질것을 대비해서 아래 첨부

 

 SpeechPlatformRuntime.msi

 

 

 

 

  http://www.microsoft.com/en-us/download/details.aspx?id=27226

 

  두번째로 SDK 설치!!

  이놈은 개발 PC에만 설치하면 된다.

  위엣놈과 마찬가지로 여러가지 파일이 나오는데 x64 또는 x86 둘중 하나 선택해서 설치하면 끝.

  물론 런타임 버전과 동일하게 설치하는 센스는 필수

 

  이녀석도 혹시 링크가 깨질지 모르니 따로 첨부ㅎㅎ

 

 MicrosoftSpeechPlatformSDK.msi

 

 

 

 

 

  http://www.microsoft.com/en-us/download/details.aspx?id=27224

 

  마지막으로 설치할 녀석은 다국어지원 엔진!!

  KR로 검색하면 TELE와 Heami(혜미?)가 나오는데 입맛에 맞게 설치

  이녀석은 용량이 20메가 가까이 되는 관계로 따로 첨부를 못함..ㅠㅠ

 

 

 

아무튼 이 세개를 모두 다운받아 SDK, Runtime, 언어팩 순서대로 설치하고 Visual Studio를 실행!!

 

그담에 할 일은 새 프로젝트를 생성하거나 TTS 서비스가 필요한 프로젝트를 로드하고 그림과 같이 참조 추가(물론 누워서 떡먹기보다 쉬운 C# 참조추가를 못하는 사람은 없겠지만 혹시나 해서...ㅎㅎ)

 

 

 

 

솔루션 탐색기의 참조 항목에서

오른쪽 버튼을 누른 후 참조 추가 클릭.

 

 

 

 

참조 추가 다이얼로그가 나오면 찾아보기 탭을 클릭하고 dll이 설치된 경로

C:\Program Files (x86)\Microsoft SDKs\Speech\v11.0\Assembly

로 가서 Microsoft.Speech.dll 선택하고 확인을 누르면 참조 끝!!

 

 

 

자.. 이제 참조도 모두 끝났고 코딩할때 사용하기만 하면 된다.

간단한 사용법은...

 

우선 참조했어도 사용한다고 말 안해주면 가볍게 씹어버리는 C#님께서 까먹지 않도록

 

using Microsoft.Speech;
using Microsoft.Speech.Synthesis;

 

//이 두녀석 걸어주고..

 

 

SpeechSynthesizer ts = new SpeechSynthesizer();

 

//SpeechSynthesizer 인스턴스 선언해주고

 

 

 

ts.SelectVoice("Microsoft Server Speech Text to Speech Voice (ko-KR, Heami)");

 

//음성 이쁜 혜미씨 목소리로 손수 선택해주고..(물론 다른 음성을 받았으면 그 아가씨(?)로 바꿔줘야함)

 

 

 

ts.SetOutputToDefaultAudioDevice();

 

//아리따운 혜미씨 목소리가 흘러나올 사운드카드를 잡아줘야 하는데.. 잘 모르니까 그냥

//디폴트 오디오 디바이스 잡아주고..

 

 


ts.Speak("메롱?");

 

//인스턴스명.speak("출력하고자 할 문자열"); 과 같은 형식으로 문자열을 목소리로 출력할 수 있다.

 

 

 

이렇게 하면 엄마 목소리만큼이나 익숙한 이름모를 아주머니(이젠 이름을 알아버렸군.. 혜미씨!!)의 목소리로 텍스트를 또박또박 읽어준다.