심플 테스트
layout
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<TextView
android:id="@+id/textView1"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:paddingBottom="4dip"
android:text="Click the button " />
<EditText
android:id="@+id/editText1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:ems="10" >
<requestFocus />
</EditText>
<Button android:id="@+id/speakButton"
android:layout_width="fill_parent"
android:onClick="speakButtonClicked"
android:layout_height="wrap_content"
android:text="Click here!" />
</LinearLayout>
code
import android.content.Intent;
import android.content.pm.PackageManager;
import android.content.pm.ResolveInfo;
import android.speech.RecognizerIntent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.text.Editable;
import android.text.TextWatcher;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity
{
EditText ed;
TextView tv;
private static final int REQUEST_CODE = 1234;
Button speak;@
Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
final Button speak = (Button) findViewById(R.id.speakButton);
ed = (EditText) this.findViewById(R.id.editText1);
tv = (TextView) this.findViewById(R.id.textView1);
// Disable button if no recognition service is present
PackageManager pm = getPackageManager();
List < ResolveInfo > activities = pm.queryIntentActivities(new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH), 0);
if (activities.size() == 0)
{
speak.setEnabled(false);
speak.setText("Recognizer not present");
}
ed.addTextChangedListener(new TextWatcher()
{@
Override
public void beforeTextChanged(CharSequence s, int start, int count, int after)
{
// TODO Auto-generated method stub
}@
Override
public void onTextChanged(CharSequence s, int start, int before, int count)
{
// TODO Auto-generated method stub
}@
Override
public void afterTextChanged(Editable s)
{
// TODO Auto-generated method stub
speak.setEnabled(false);
}
});
}
/**
* Handle the action of the button being clicked
*/
public void speakButtonClicked(View v)
{
startVoiceRecognitionActivity();
}
/**
* Fire an intent to start the voice recognition activity.
*/
private void startVoiceRecognitionActivity()
{
Intent intent = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH);
intent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL, RecognizerIntent.LANGUAGE_MODEL_FREE_FORM);
intent.putExtra(RecognizerIntent.EXTRA_PROMPT, "Voice searching...");
startActivityForResult(intent, REQUEST_CODE);
}
/**
* Handle the results from the voice recognition activity.
*/
@
Override
protected void onActivityResult(int requestCode, int resultCode, Intent data)
{
if (requestCode == REQUEST_CODE && resultCode == RESULT_OK)
{
// Populate the wordsList with the String values the recognition engine thought it heard
final ArrayList < String > matches = data.getStringArrayListExtra(RecognizerIntent.EXTRA_RESULTS);
if (!matches.isEmpty())
{
String Query = matches.get(0);
ed.setText(Query);
speak.setEnabled(false);
}
}
super.onActivityResult(requestCode, resultCode, data);
}
}
출처 : https://www.c-sharpcorner.com/article/create-voice-search-android-application-using-android-studio/
'android' 카테고리의 다른 글
| custom view tutorial 따라하기 1 (0) | 2018.07.12 |
|---|---|
| Simple voice search test2 (0) | 2018.07.11 |
| NDK API는 binder를 지원하지 않는다. (0) | 2018.07.03 |
| hidl simple example (4) | 2018.06.25 |
| android ir to android keycode mapping (0) | 2018.06.21 |