How to use Google Speech API from Codename One?

I want to record audio from the phone, and then send it to the google speech non-streaming API. I can record using Capture.captureAudio(), but then I do not know what is the audio encoding and the sample rate, since they are needed for the api request. How can I get the audio encoding and the sample rate, so that I can send them with my API request?


If you check the sources on Android it records in AMR-WB

        recorder.setAudioSource(MediaRecorder.AudioSource.MIC);
        recorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP);
        recorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_WB);
        recorder.setOutputFile(temp.getAbsolutePath());

Google speech API accepts AMR-WB if you properly set audio format.

Another problem is that file is recorded as AMR-WB in 3GPP container, so you need a custom code to extract audio data form 3GPP, you can find it here:

// #!AMRn
private static byte[] AMR_MAGIC_HEADER = {0x23, 0x21, 0x41, 0x4d, 0x52, 0x0a};


public byte[] convert3gpDataToAmr(byte[] data) {
    if (data == null) {
        return null;
    }

    ByteArrayInputStream bis = new ByteArrayInputStream(data);
    // read FileTypeHeader
    FileTypeBox ftypHeader = new FileTypeBox(bis);
    // You can check if it is correct here
    // read MediaDataHeader
    MediaDataBox mdatHeader = new MediaDataBox(bis);
    // You can check if it is correct here
    int rawAmrDataLength = mdatHeader.getDataLength();
    int fullAmrDataLength = AMR_MAGIC_HEADER.length + rawAmrDataLength;
    byte[] amrData = new byte[fullAmrDataLength];
    System.arraycopy(AMR_MAGIC_HEADER, 0, amrData, 0, AMR_MAGIC_HEADER.length);
    bis.read(amrData, AMR_MAGIC_HEADER.length, rawAmrDataLength);
    return amrData;
}

Also note that AMR-WB gives you slightly lower accuracy, so you might want to consider raw audio capture with more detailed API, not codenameone.

链接地址: http://www.djcxy.com/p/34456.html

上一篇: Google Cloud语音API可以直播电话音频吗?

下一篇: 如何使用Codename One的Google Speech API?