| /* |
| * Copyright (C) 2014 The Android Open Source Project |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| package com.android.settings.utils; |
| |
| import android.app.Activity; |
| import android.app.VoiceInteractor.AbortVoiceRequest; |
| import android.app.VoiceInteractor.CompleteVoiceRequest; |
| import android.content.Intent; |
| import android.os.Bundle; |
| import android.util.Log; |
| |
| /** |
| * Activity for modifying a setting using the Voice Interaction API. This activity |
| * will only allow modifying the setting if the intent was sent using |
| * {@link android.service.voice.VoiceInteractionSession#startVoiceActivity startVoiceActivity} |
| * by the current Voice Interaction Service. |
| */ |
| abstract public class VoiceSettingsActivity extends Activity { |
| |
| private static final String TAG = "VoiceSettingsActivity"; |
| |
| @Override |
| public void onCreate(Bundle savedInstanceState) { |
| super.onCreate(savedInstanceState); |
| |
| if (isVoiceInteractionRoot()) { |
| // Only permit if this is a voice interaction. |
| if (onVoiceSettingInteraction(getIntent())) { |
| // If it's complete, finish. |
| finish(); |
| } |
| } else { |
| Log.v(TAG, "Cannot modify settings without voice interaction"); |
| finish(); |
| } |
| } |
| |
| /** |
| * Modify the setting as a voice interaction. Should return true if the |
| * voice interaction is complete or false if more interaction is required. |
| */ |
| abstract protected boolean onVoiceSettingInteraction(Intent intent); |
| |
| /** |
| * Send a notification that the interaction was successful. If {@param prompt} is |
| * not null, then it will be read to the user. |
| */ |
| protected void notifySuccess(CharSequence prompt) { |
| if (getVoiceInteractor() != null) { |
| getVoiceInteractor().submitRequest(new CompleteVoiceRequest(prompt, null) { |
| @Override |
| public void onCompleteResult(Bundle options) { |
| finish(); |
| } |
| }); |
| } |
| } |
| |
| /** |
| * Indicates when the setting could not be changed. |
| */ |
| protected void notifyFailure(CharSequence prompt) { |
| if (getVoiceInteractor() != null) { |
| getVoiceInteractor().submitRequest(new AbortVoiceRequest(prompt, null)); |
| } |
| } |
| } |