我希望我能够清楚。
在我的应用程序中,我已将其设置为按下后退按钮激活谷歌的语音识别服务。在onActivityResult
中,它检查第一个单词是“call”还是“text”,并相应地继续说出其余的句子。具体来说,它类似于“text [contact name] message [message content]”,然后使用smsManager
发送它。但由于它可能会得到名称或消息错误,我希望它首先读出消息和人名,以确认我做得很好。
问题是,要确认或取消,我还想使用语音识别。如果在读出消息之后,用户说出类似发送的内容,那么它应该继续发送消息。所以,我需要知道的是如何/如果我可以在下面的代码中实现这个(newVoiceCommand
):
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
switch (requestCode) {
case RESULT_SPEECH: {
if (resultCode == RESULT_OK && null != data) {
s="";
text = data
.getStringArrayListExtra(RecognizerIntent.EXTRA_RESULTS);
decide = text.get(0).split("\\s");
for (int i=1; i<decide.length;i++) s= s+decide[i] + " ";
if (decide [0].equals("text")){
if (!s.equals("")){
msg = s.split(" message");
char[] stringArray = msg[0].toCharArray();
stringArray[0] = Character.toUpperCase(stringArray[0]);
msg[0] = new String(stringArray);
contact = get_Number (test(msg[0]));
Intent intent = getIntent();
finish();
startActivity(intent);
String temp = "Are you sure you want to send " + msg[1] + " to " + test(msg[0]);
speakOut (temp);
if (newVoiceCommand.equals("send")){
try {
SmsManager smsManager = SmsManager.getDefault();
out.append(contact);
smsManager.sendTextMessage(contact, null, msg[1], null, null);
Toast.makeText(getApplicationContext(), "SMS Sent! to "+msg[0] + " at " +contact,
Toast.LENGTH_LONG).show();
} catch (Exception e) {
Toast.makeText(getApplicationContext(),
"SMS faild, please try again later!",
Toast.LENGTH_LONG).show();
e.printStackTrace();
}
}
else if (newVoiceCommand.equals("no")) out.append("Not sending");
}
}
else if (decide[0].equals("call")){
out.append (s);
if (!s.equals("")) {
call (s);
}
}
}
break;
}
}
}
我目前的尝试:
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
switch (requestCode) {
case RESULT_SPEECH: {
if (resultCode == RESULT_OK && null != data) {
s="";
//Grab the speech results and save them in an arraylist
text = data
.getStringArrayListExtra(RecognizerIntent.EXTRA_RESULTS);
//Split each word into an array item
decide = text.get(0).split("\\s");
//Re-concatenate the words starting with the second word together
for (int i=1; i<decide.length;i++) s= s+decide[i] + " ";
//If the first word is "text", then send an SMS using the rest of the information spoken
if (decide [0].equals("text")){
if (!s.equals("")){
check (s);
Intent spIntent = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH);
spIntent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL, "en_US");
try {
startActivityForResult(spIntent, RESULT_SPEECH2);
} catch (ActivityNotFoundException a) {
Toast t = Toast.makeText(getApplicationContext(),
"Opps! Your device doesn't support Speech to Text",
Toast.LENGTH_SHORT);
t.show();
}
switch (requestCode) {
case RESULT_SPEECH2: {
if (resultCode == RESULT_OK && null != data) {
text2 = data.getStringArrayListExtra(RecognizerIntent.EXTRA_RESULTS);
s2 = "";
if (text2.get(0).equals("send")){
smsText (s);
}
else if (text2.get(0).equals("cancel")) return;
}
}
答案 0 :(得分:2)
简而言之,所有语音识别结果都将通过对onActivityResult
的异步调用来实现。您不会阻止并等待结果,因此您需要一种方法来确定识别是在响应命令还是在您收到结果时进行确认。
what the requestCode
parameter of Activity.startActivityForResult()
适用于:
有时您希望在活动结束时从结果中获取结果。 例如,您可以启动一个允许用户选择的活动 联系人列表中的人;当它结束时,它返回那个人 被选中了。要执行此操作,请使用标识该调用的第二个整数参数调用
startActivityForResult(Intent, int)
版本。该 结果将通过您的onActivityResult(int, int, Intent)
返回 方法
如果您在开始语音识别活动时对requestCode
使用两个不同的值(例如,定义private final static int REQUEST_SPEECH_COMMAND = 1, REQUEST_SPEECH_CONFIRMATION = 2
),则可以在onActivityResult
中做出不同的回应。请注意,您需要存储第一个语音识别的结果(操作,消息和收件人),以便第二次可以获得此信息。