500分!! SAPI中,怎么实现内存流的语音识别??? ( 积分: 200 )

  • 主题发起人 主题发起人 3304xfq
  • 开始时间 开始时间
3

3304xfq

Unregistered / Unconfirmed
GUEST, unregistred user!
OK的话,另开贴子给分,这里的100分用来给顶贴的人

Recognizer:=TSpInProcRecoContext.Create(self);
Recognizer.OnRecognition:=Recognition; //处理结果值的过程
CreateGrammar:=Recognizer.CreateGrammar(0);
recognizer.Recognizer.AudioInputStream:=SpFileStream1.DefaultInterface; //如果是文件就是SpFileStream1.DefaultInterface (SpFileStream1.open(fn,0,false);

Recognizer.EventInterests:= SREAllEvents;
CreateGrammar.DictationUnload;
CreateGrammar.DictationSetState(1)

这里是初始化的代码
------------------
//下面怎么处理SpMemoryStream1
var
f:TFileStream;
buff:array of byte;
begin
f:=TFilestream.creaet('c:/aa.wav',fmOpenRead); //本来应该是采集卡上来的PCM声音,不过这里可以wave文件模拟一下
f.read(buff[0],1024*1024);
SpMemoryStream1.write(buff);


不一定要用SpMemoryStream1的方法,网上找不到例子,我只是看sapi猜的,



SpeechLib_TLB:
C:/Program Files/Common Files/Microsoft Shared/Speech/sapi.dll
speechsdk从microsoft.com/speechsdk上下载



我主要是想处理采集卡上来的声音数据,进行识别(PCM格式)
 
http://msdn2.microsoft.com/en-us/library/ms717046.aspx
这是例子
AudioPlugIn.SetData(vData: OleVariant)

怎么把buff:array of byte的数据写进去?
即setdata(buff)

http://msdn2.microsoft.com/en-us/library/ms717046.aspx
这是VC的例子
VC中是自动转换的
在delphi中我试了,要么是输入数据没有反应,要么就提示拒绝存取
 
学习一下,可以交流一下.QQ 623464705
 
再不行,我要现金求购了,说真的!!
快帮我一下啊
 
后退
顶部