diff options
-rw-r--r-- | res/drawable-hdpi/ic_voice_search_holo_dark.png | bin | 0 -> 961 bytes | |||
-rw-r--r-- | res/drawable-mdpi/ic_voice_search_holo_dark.png | bin | 0 -> 687 bytes | |||
-rw-r--r-- | res/drawable-xhdpi/ic_voice_search_holo_dark.png | bin | 0 -> 1239 bytes | |||
-rw-r--r-- | res/layout-sw600dp/title_bar_nav.xml | 9 | ||||
-rw-r--r-- | res/layout/title_bar_nav.xml | 9 | ||||
-rw-r--r-- | src/com/android/browser/BaseUi.java | 5 | ||||
-rw-r--r-- | src/com/android/browser/Controller.java | 34 | ||||
-rw-r--r-- | src/com/android/browser/NavigationBarBase.java | 21 | ||||
-rw-r--r-- | src/com/android/browser/NavigationBarPhone.java | 8 | ||||
-rw-r--r-- | src/com/android/browser/NavigationBarTablet.java | 33 | ||||
-rw-r--r-- | src/com/android/browser/UI.java | 1 | ||||
-rw-r--r-- | src/com/android/browser/UiController.java | 4 |
12 files changed, 109 insertions, 15 deletions
diff --git a/res/drawable-hdpi/ic_voice_search_holo_dark.png b/res/drawable-hdpi/ic_voice_search_holo_dark.png Binary files differnew file mode 100644 index 0000000..e79aa71 --- /dev/null +++ b/res/drawable-hdpi/ic_voice_search_holo_dark.png diff --git a/res/drawable-mdpi/ic_voice_search_holo_dark.png b/res/drawable-mdpi/ic_voice_search_holo_dark.png Binary files differnew file mode 100644 index 0000000..f809e52 --- /dev/null +++ b/res/drawable-mdpi/ic_voice_search_holo_dark.png diff --git a/res/drawable-xhdpi/ic_voice_search_holo_dark.png b/res/drawable-xhdpi/ic_voice_search_holo_dark.png Binary files differnew file mode 100644 index 0000000..02876b7 --- /dev/null +++ b/res/drawable-xhdpi/ic_voice_search_holo_dark.png diff --git a/res/layout-sw600dp/title_bar_nav.xml b/res/layout-sw600dp/title_bar_nav.xml index 651474a..a6b8a32 100644 --- a/res/layout-sw600dp/title_bar_nav.xml +++ b/res/layout-sw600dp/title_bar_nav.xml @@ -98,7 +98,14 @@ android:layout_height="match_parent" android:contentDescription="@string/accessibility_button_clear" style="@style/HoloButton" /> - </LinearLayout> + <ImageButton + android:id="@+id/voice" + android:src="@drawable/ic_voice_search_holo_dark" + android:layout_width="wrap_content" + android:layout_height="match_parent" + android:contentDescription="@string/accessibility_button_voice" + style="@style/HoloButton" /> + </LinearLayout> <ImageButton android:id="@+id/search" android:src="@drawable/ic_search_holo_dark" diff --git a/res/layout/title_bar_nav.xml b/res/layout/title_bar_nav.xml index 31e47bc..15568c3 100644 --- a/res/layout/title_bar_nav.xml +++ b/res/layout/title_bar_nav.xml @@ -89,6 +89,15 @@ style="@style/Suggestions" android:background="@null" /> <ImageView + android:id="@+id/voice" + android:layout_width="wrap_content" + android:layout_height="match_parent" + android:paddingRight="4dip" + android:contentDescription="@string/accessibility_button_voice" + android:src="@drawable/ic_voice_search_holo_dark" + style="@style/HoloButton" + android:visibility="gone" /> + <ImageView android:id="@+id/clear" android:layout_width="wrap_content" android:layout_height="match_parent" diff --git a/src/com/android/browser/BaseUi.java b/src/com/android/browser/BaseUi.java index cfe9a53..c749465 100644 --- a/src/com/android/browser/BaseUi.java +++ b/src/com/android/browser/BaseUi.java @@ -870,4 +870,9 @@ public abstract class BaseUi implements UI { return mBlockFocusAnimations; } + @Override + public void onVoiceResult(String result) { + mNavigationBar.onVoiceResult(result); + } + } diff --git a/src/com/android/browser/Controller.java b/src/com/android/browser/Controller.java index d733160..ebfd56f 100644 --- a/src/com/android/browser/Controller.java +++ b/src/com/android/browser/Controller.java @@ -52,6 +52,7 @@ import android.provider.BrowserContract; import android.provider.BrowserContract.Images; import android.provider.ContactsContract; import android.provider.ContactsContract.Intents.Insert; +import android.speech.RecognizerIntent; import android.text.TextUtils; import android.util.Log; import android.util.Patterns; @@ -129,6 +130,7 @@ public class Controller final static int PREFERENCES_PAGE = 3; final static int FILE_SELECTED = 4; final static int AUTOFILL_SETUP = 5; + final static int VOICE_RESULT = 6; private final static int WAKELOCK_TIMEOUT = 5 * 60 * 1000; // 5 minutes @@ -216,6 +218,8 @@ public class Controller private boolean mBlockEvents; + private String mVoiceResult; + public Controller(Activity browser) { mActivity = browser; mSettings = BrowserSettings.getInstance(); @@ -700,6 +704,10 @@ public class Controller mNetworkHandler.onResume(); WebView.enablePlatformNotifications(); NfcHandler.register(mActivity, this); + if (mVoiceResult != null) { + mUi.onVoiceResult(mVoiceResult); + mVoiceResult = null; + } } private void releaseWakeLock() { @@ -1190,6 +1198,15 @@ public class Controller } } break; + case VOICE_RESULT: + if (resultCode == Activity.RESULT_OK && intent != null) { + ArrayList<String> results = intent.getStringArrayListExtra( + RecognizerIntent.EXTRA_RESULTS); + if (results.size() >= 1) { + mVoiceResult = results.get(0); + } + } + break; default: break; } @@ -2822,6 +2839,23 @@ public class Controller } @Override + public boolean supportsVoice() { + PackageManager pm = mActivity.getPackageManager(); + List activities = pm.queryIntentActivities(new Intent( + RecognizerIntent.ACTION_RECOGNIZE_SPEECH), 0); + return activities.size() != 0; + } + + @Override + public void startVoiceRecognizer() { + Intent voice = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH); + voice.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL, + RecognizerIntent.LANGUAGE_MODEL_FREE_FORM); + voice.putExtra(RecognizerIntent.EXTRA_MAX_RESULTS, 1); + mActivity.startActivityForResult(voice, VOICE_RESULT); + } + + @Override public void setBlockEvents(boolean block) { mBlockEvents = block; } diff --git a/src/com/android/browser/NavigationBarBase.java b/src/com/android/browser/NavigationBarBase.java index 37b11c8..7f100ff 100644 --- a/src/com/android/browser/NavigationBarBase.java +++ b/src/com/android/browser/NavigationBarBase.java @@ -21,7 +21,6 @@ import android.content.Intent; import android.graphics.Bitmap; import android.graphics.drawable.Drawable; import android.os.Bundle; -import android.speech.RecognizerResultsIntent; import android.text.Editable; import android.text.TextWatcher; import android.util.AttributeSet; @@ -35,8 +34,6 @@ import android.widget.LinearLayout; import com.android.browser.UrlInputView.UrlInputListener; -import java.util.List; - public class NavigationBarBase extends LinearLayout implements OnClickListener, UrlInputListener, OnFocusChangeListener, TextWatcher { @@ -129,7 +126,10 @@ public class NavigationBarBase extends LinearLayout implements } void stopEditingUrl() { - mUrlInput.clearFocus(); + WebView currentTopWebView = mUiController.getCurrentTopWebView(); + if (currentTopWebView != null) { + currentTopWebView.requestFocus(); + } } void setDisplayTitle(String title) { @@ -156,10 +156,7 @@ public class NavigationBarBase extends LinearLayout implements */ @Override public void onAction(String text, String extra, String source) { - WebView currentTopWebView = mUiController.getCurrentTopWebView(); - if (currentTopWebView != null) { - currentTopWebView.requestFocus(); - } + stopEditingUrl(); if (UrlInputView.TYPED.equals(source)) { String url = UrlUtils.smartUrlFilter(text, false); Tab t = mBaseUi.getActiveTab(); @@ -220,7 +217,7 @@ public class NavigationBarBase extends LinearLayout implements public boolean dispatchKeyEventPreIme(KeyEvent evt) { if (evt.getKeyCode() == KeyEvent.KEYCODE_BACK) { // catch back key in order to do slightly more cleanup than usual - mUrlInput.clearFocus(); + stopEditingUrl(); return true; } return super.dispatchKeyEventPreIme(evt); @@ -260,6 +257,11 @@ public class NavigationBarBase extends LinearLayout implements public void onTabDataChanged(Tab tab) { } + public void onVoiceResult(String s) { + startEditingUrl(true, true); + onCopySuggestion(s); + } + @Override public void beforeTextChanged(CharSequence s, int start, int count, int after) { } @@ -268,4 +270,5 @@ public class NavigationBarBase extends LinearLayout implements @Override public void afterTextChanged(Editable s) { } + } diff --git a/src/com/android/browser/NavigationBarPhone.java b/src/com/android/browser/NavigationBarPhone.java index 2517d62..c3930d3 100644 --- a/src/com/android/browser/NavigationBarPhone.java +++ b/src/com/android/browser/NavigationBarPhone.java @@ -38,6 +38,7 @@ public class NavigationBarPhone extends NavigationBarBase implements private ImageView mStopButton; private ImageView mMagnify; private ImageView mClearButton; + private ImageView mVoiceButton; private Drawable mStopDrawable; private Drawable mRefreshDrawable; private String mStopDescription; @@ -71,6 +72,8 @@ public class NavigationBarPhone extends NavigationBarBase implements mStopButton.setOnClickListener(this); mClearButton = (ImageView) findViewById(R.id.clear); mClearButton.setOnClickListener(this); + mVoiceButton = (ImageView) findViewById(R.id.voice); + mVoiceButton.setOnClickListener(this); mMagnify = (ImageView) findViewById(R.id.magnify); mTabSwitcher = findViewById(R.id.tab_switcher); mTabSwitcher.setOnClickListener(this); @@ -154,6 +157,8 @@ public class NavigationBarPhone extends NavigationBarBase implements mUrlInput.setText(""); } else if (mComboIcon == v) { mUiController.showPageInfo(); + } else if (mVoiceButton == v) { + mUiController.startVoiceRecognizer(); } else { super.onClick(v); } @@ -215,6 +220,7 @@ public class NavigationBarPhone extends NavigationBarBase implements mComboIcon.setVisibility(View.VISIBLE); mStopButton.setVisibility(View.GONE); mClearButton.setVisibility(View.GONE); + mVoiceButton.setVisibility(View.GONE); mMagnify.setVisibility(View.GONE); mTabSwitcher.setVisibility(View.VISIBLE); mTitleContainer.setBackgroundDrawable(null); @@ -224,6 +230,7 @@ public class NavigationBarPhone extends NavigationBarBase implements mComboIcon.setVisibility(View.GONE); mStopButton.setVisibility(View.VISIBLE); mClearButton.setVisibility(View.GONE); + mVoiceButton.setVisibility(View.VISIBLE); mMagnify.setVisibility(View.GONE); mTabSwitcher.setVisibility(View.GONE); mMore.setVisibility(View.GONE); @@ -233,6 +240,7 @@ public class NavigationBarPhone extends NavigationBarBase implements mComboIcon.setVisibility(View.GONE); mStopButton.setVisibility(View.GONE); mClearButton.setVisibility(View.VISIBLE); + mVoiceButton.setVisibility(View.GONE); mMagnify.setVisibility(View.VISIBLE); mTabSwitcher.setVisibility(View.GONE); mMore.setVisibility(View.GONE); diff --git a/src/com/android/browser/NavigationBarTablet.java b/src/com/android/browser/NavigationBarTablet.java index 426174b..79c8de6 100644 --- a/src/com/android/browser/NavigationBarTablet.java +++ b/src/com/android/browser/NavigationBarTablet.java @@ -32,10 +32,9 @@ import android.widget.ImageButton; import android.widget.ImageView; import com.android.browser.UI.ComboViews; +import com.android.browser.UrlInputView.StateListener; -import java.util.List; - -public class NavigationBarTablet extends NavigationBarBase { +public class NavigationBarTablet extends NavigationBarBase implements StateListener { private Drawable mStopDrawable; private Drawable mReloadDrawable; @@ -51,6 +50,7 @@ public class NavigationBarTablet extends NavigationBarBase { private ImageView mStopButton; private View mAllButton; private View mClearButton; + private View mVoiceButton; private View mNavButtons; private Drawable mFocusDrawable; private Drawable mUnfocusDrawable; @@ -99,6 +99,7 @@ public class NavigationBarTablet extends NavigationBarBase { mStopButton = (ImageView) findViewById(R.id.stop); mSearchButton = (ImageView) findViewById(R.id.search); mClearButton = findViewById(R.id.clear); + mVoiceButton = findViewById(R.id.voice); mUrlContainer = findViewById(R.id.urlbar_focused); mBackButton.setOnClickListener(this); mForwardButton.setOnClickListener(this); @@ -107,7 +108,9 @@ public class NavigationBarTablet extends NavigationBarBase { mStopButton.setOnClickListener(this); mSearchButton.setOnClickListener(this); mClearButton.setOnClickListener(this); + mVoiceButton.setOnClickListener(this); mUrlInput.setContainer(mUrlContainer); + mUrlInput.setStateListener(this); } public void onConfigurationChanged(Configuration config) { @@ -176,6 +179,8 @@ public class NavigationBarTablet extends NavigationBarBase { stopOrRefresh(); } else if (mClearButton == v) { clearOrClose(); + } else if (mVoiceButton == v) { + mUiController.startVoiceRecognizer(); } else { super.onClick(v); } @@ -217,14 +222,12 @@ public class NavigationBarTablet extends NavigationBarBase { } mSearchButton.setVisibility(View.GONE); mStar.setVisibility(View.GONE); - mClearButton.setVisibility(View.VISIBLE); mUrlIcon.setImageResource(R.drawable.ic_search_holo_dark); } else { if (mHideNavButtons) { showNavButtons(); } showHideStar(mUiController.getCurrentTab()); - mClearButton.setVisibility(View.GONE); if (mTitleBar.useQuickControls()) { mSearchButton.setVisibility(View.GONE); } else { @@ -289,6 +292,7 @@ public class NavigationBarTablet extends NavigationBarBase { mAnimation.cancel(); } mNavButtons.setVisibility(View.VISIBLE); + mNavButtons.setTranslationX(0); if (!mBaseUi.blockFocusAnimations()) { int awidth = mNavButtons.getMeasuredWidth(); Animator anim1 = ObjectAnimator.ofFloat(mNavButtons, @@ -316,4 +320,23 @@ public class NavigationBarTablet extends NavigationBarBase { } } + @Override + public void onStateChanged(int state) { + switch(state) { + case STATE_NORMAL: + mClearButton.setVisibility(View.GONE); + mVoiceButton.setVisibility(View.GONE); + + break; + case STATE_HIGHLIGHTED: + mClearButton.setVisibility(View.GONE); + mVoiceButton.setVisibility(View.VISIBLE); + break; + case STATE_EDITED: + mClearButton.setVisibility(View.VISIBLE); + mVoiceButton.setVisibility(View.GONE); + break; + } + } + } diff --git a/src/com/android/browser/UI.java b/src/com/android/browser/UI.java index 96f6640..677c3d3 100644 --- a/src/com/android/browser/UI.java +++ b/src/com/android/browser/UI.java @@ -148,4 +148,5 @@ public interface UI { boolean blockFocusAnimations(); + void onVoiceResult(String result); } diff --git a/src/com/android/browser/UiController.java b/src/com/android/browser/UiController.java index a2946a7..683e473 100644 --- a/src/com/android/browser/UiController.java +++ b/src/com/android/browser/UiController.java @@ -109,4 +109,8 @@ public interface UiController { BrowserSettings getSettings(); + boolean supportsVoice(); + + void startVoiceRecognizer(); + } |