Android自定义语音识别GUI对话框

时间:2014-04-15 18:28:01

标签: android user-interface speech-recognition

我试图自定义"对话框"在语音识别期间。 enter image description here

如果我理解正确,我需要使用SpeechRecognizer来自定义上图中的语音识别GUI。

这个How to get audio amplitude with speech recognizer?与我的问题类似,但是他要求使用onRmsChanged添加幅度指示器,因为他已经知道如何在识别发生时实现新的GUI,所以他的问题虽然有用,但比我在哪里更远。

是否存在任何现有的示例项目,这些项目解释了如何实现此类自定义UI。我查看了ApiDemo VoiceRecognition示例,但我仍然没有看到设置/更改UI的位置..

从开发文档中,我理解这需要在主UI线程上。 所以我的伪方法是创建一个SpeechDialogClass,一个扩展Dialog并实现RecognitionListener的对话框类。像这样的东西。 我会想象在方法的某个地方我会设置上下文,onRmsChanged处理等等。但是从那里我几乎失去了。

public class SpeechDialogClass extends Dialog implements RecognitionListener {

    public Activity c;
    public Dialog d;
    public ImageView mic, mic_amp;

    public SpeechDialogClass(Activity a) {
        super(a);
        // TODO Auto-generated constructor stub
        this.c = a;
    }

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        requestWindowFeature(Window.FEATURE_NO_TITLE);
        setContentView(R.layout.speech_dialog_kids);
        mic = (ImageView) findViewById(R.id.mic_icon);
        mic_amp = (ImageView) findViewById(R.id.speech_amplitude);

        // //So I would set some sort of listener to change the selector state
        // of mic_icon and the
        // /somewhere I would set the mic_amp to listen/ract to on onRmsChanged
        // public void onRmsChanged(float arg0)///
        // // and this is where Im lost///

    }

    public void onBeginningOfSpeech() {
        // TODO Auto-generated method stub
        setContentView(R.layout.speech_dialog_kids);
    }

    public void onBufferReceived(byte[] arg0) {
        // TODO Auto-generated method stub

    }

    public void onEndOfSpeech() {
        // TODO Auto-generated method stub

    }

    public void onError(int arg0) {
        // TODO Auto-generated method stub

    }

    public void onEvent(int arg0, Bundle arg1) {
        // TODO Auto-generated method stub

    }

    public void onPartialResults(Bundle arg0) {
        // TODO Auto-generated method stub

    }

    public void onReadyForSpeech(Bundle arg0) {
        // TODO Auto-generated method stub

    }

    public void onResults(Bundle arg0) {
        // TODO Auto-generated method stub

    }

    public void onRmsChanged(float arg0) {
        // TODO Auto-generated method stub
        // pseudo code//
        // mic_amp.doSomething(and a float);
    }

}

我的speech_dialiog_kids.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="150dp"
    android:background="#3E80B4"
    android:orientation="vertical" >

    <TextView
        android:id="@+id/txt_dia"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:layout_margin="10dp"
        android:text="Speak Text"
        android:textColor="@android:color/white"
        android:textSize="15dp"
        android:textStyle="bold" >
    </TextView>

    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:background="#3E80B4"
        android:orientation="horizontal" >

        <ImageView
            android:id="@+id/speech_amplitude"
            android:layout_width="78dp"
            android:layout_height="78dp"
            android:layout_marginTop="10dp"
            android:src="@drawable/amplitude_icon"
            android:visibility="visible" />

        <ImageView
            android:id="@+id/mic_icon"
            android:layout_width="68dp"
            android:layout_height="68dp"
            android:layout_marginLeft="-73dp"
            android:layout_marginTop="16dp"
            android:src="@drawable/small_right_grey_white"
            android:visibility="visible" />
    </LinearLayout>

</LinearLayout>

enter image description here

1 个答案:

答案 0 :(得分:1)

  

我想在方法的某个地方我会设置上下文,onRmsChanged处理等等。但是从那里我几乎失去了。

这样的事情:

public void onRmsChanged(float rms) {
    if (rms < limit1)
        mic_amp.setImageResource(1);
    else if (rms < limit2)
        mic_amp.setImageResource(2);
    else if (rms < limit3)
        mic_amp.setImageResource(3);
}

因此它会对有效值的变化产生影响。您可以根据rms级别更改图像。您可以更改各种ImageView方法来更改实际图像。

另一个问题是,onRmsChanged并不总是根据Android版本调用,因此实现此功能更加困难。那么最简单的方法就是保持原始对话框。