diff options
author | Michael Kolb <kolby@google.com> | 2010-09-15 14:55:05 -0700 |
---|---|---|
committer | Michael Kolb <kolby@google.com> | 2010-09-27 14:34:12 -0700 |
commit | 21ce4d295802db811873b46e7821abfa0540dab2 (patch) | |
tree | 38912d62ddc535c7039dd5be01cb846eff7dcb62 /src/com/android/browser/UrlInputView.java | |
parent | 6ed4dcae944c8188c7f240affeb8c437cbfd2090 (diff) | |
download | packages_apps_browser-21ce4d295802db811873b46e7821abfa0540dab2.zip packages_apps_browser-21ce4d295802db811873b46e7821abfa0540dab2.tar.gz packages_apps_browser-21ce4d295802db811873b46e7821abfa0540dab2.tar.bz2 |
new two column suggestion dropdown
http://b/issue?id=3039704
Change-Id: I8b32553682cc547c695d0089e6633ead77426869
Diffstat (limited to 'src/com/android/browser/UrlInputView.java')
-rw-r--r-- | src/com/android/browser/UrlInputView.java | 159 |
1 files changed, 50 insertions, 109 deletions
diff --git a/src/com/android/browser/UrlInputView.java b/src/com/android/browser/UrlInputView.java index 96a5980..8662f55 100644 --- a/src/com/android/browser/UrlInputView.java +++ b/src/com/android/browser/UrlInputView.java @@ -16,31 +16,18 @@ package com.android.browser; -import android.app.SearchManager; +import com.android.browser.SuggestionsAdapter.CompletionListener; + import android.content.ContentResolver; import android.content.Context; -import android.database.Cursor; -import android.graphics.Color; -import android.graphics.drawable.Drawable; -import android.text.Editable; -import android.text.SpannableStringBuilder; -import android.text.TextWatcher; -import android.text.style.BackgroundColorSpan; +import android.content.res.Configuration; import android.util.AttributeSet; -import android.util.Log; import android.view.ActionMode; import android.view.KeyEvent; -import android.view.LayoutInflater; import android.view.View; -import android.view.View.OnClickListener; import android.view.View.OnFocusChangeListener; -import android.view.ViewGroup; import android.view.inputmethod.InputMethodManager; import android.widget.AutoCompleteTextView; -import android.widget.CursorAdapter; -import android.widget.Filterable; -import android.widget.ImageButton; -import android.widget.ImageView; import android.widget.TextView; import android.widget.TextView.OnEditorActionListener; @@ -49,13 +36,14 @@ import android.widget.TextView.OnEditorActionListener; * handling suggestions */ public class UrlInputView extends AutoCompleteTextView - implements OnFocusChangeListener, OnClickListener, OnEditorActionListener { + implements OnFocusChangeListener, OnEditorActionListener, CompletionListener { private UrlInputListener mListener; private InputMethodManager mInputManager; private SuggestionsAdapter mAdapter; - private OnFocusChangeListener mWrappedFocusListener; + private View mContainer; + private boolean mLandscape; public UrlInputView(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); @@ -77,10 +65,36 @@ public class UrlInputView extends AutoCompleteTextView setOnEditorActionListener(this); super.setOnFocusChangeListener(this); final ContentResolver cr = mContext.getContentResolver(); - mAdapter = new SuggestionsAdapter(mContext, - BrowserProvider.getBookmarksSuggestions(cr, null)); + mAdapter = new SuggestionsAdapter(ctx, this); setAdapter(mAdapter); setSelectAllOnFocus(false); + onConfigurationChanged(ctx.getResources().getConfiguration()); + } + + void setContainer(View container) { + mContainer = container; + } + + @Override + protected void onConfigurationChanged(Configuration config) { + mLandscape = (config.orientation & + Configuration.ORIENTATION_LANDSCAPE) > 0; + if (isPopupShowing() && (getVisibility() == View.VISIBLE)) { + dismissDropDown(); + getFilter().filter(getText()); + } + } + + @Override + public void showDropDown() { + int width = mContainer.getWidth(); + if ((mAdapter.getLeftCount() == 0) || (mAdapter.getRightCount() == 0)) { + width = width / 2; + } + setDropDownWidth(width); + setDropDownHorizontalOffset(-getLeft()); + mAdapter.setLandscapeMode(mLandscape); + super.showDropDown(); } @Override @@ -99,7 +113,7 @@ public class UrlInputView extends AutoCompleteTextView finishInput(getText().toString()); return true; } - + @Override public void onFocusChange(View v, boolean hasFocus) { if (hasFocus) { @@ -112,19 +126,6 @@ public class UrlInputView extends AutoCompleteTextView } } - @Override - public void onClick(View view) { - if (view instanceof ImageButton) { - // user pressed edit search button - String text = mAdapter.getViewString((View)view.getParent()); - mListener.onEdit(text); - } else { - // user selected dropdown item - String url = mAdapter.getViewString(view); - finishInput(url); - } - } - public void setUrlInputListener(UrlInputListener listener) { mListener = listener; } @@ -144,6 +145,18 @@ public class UrlInputView extends AutoCompleteTextView } } + // Completion Listener + + @Override + public void onSearch(String search) { + mListener.onEdit(search); + } + + @Override + public void onSelect(String url) { + finishInput(url); + } + @Override public boolean onKeyPreIme(int keyCode, KeyEvent evt) { if (keyCode == KeyEvent.KEYCODE_BACK) { @@ -155,84 +168,12 @@ public class UrlInputView extends AutoCompleteTextView } interface UrlInputListener { - public void onDismiss(); - public void onAction(String text); - public void onEdit(String text); - } - - /** - * adapter used by suggestion dropdown - */ - class SuggestionsAdapter extends CursorAdapter implements Filterable { - - private Cursor mLastCursor; - private ContentResolver mContent; - private int mIndexText1; - private int mIndexText2; - private int mIndexIcon; - - public SuggestionsAdapter(Context context, Cursor c) { - super(context, c); - mContent = context.getContentResolver(); - mIndexText1 = c.getColumnIndex(SearchManager.SUGGEST_COLUMN_TEXT_1); - mIndexText2 = c.getColumnIndex(SearchManager.SUGGEST_COLUMN_TEXT_2_URL); - mIndexIcon = c.getColumnIndex(SearchManager.SUGGEST_COLUMN_ICON_1); - } - public String getViewString(View view) { - TextView tv2 = (TextView) view.findViewById(android.R.id.text2); - if (tv2.getText().length() > 0) { - return tv2.getText().toString(); - } else { - TextView tv1 = (TextView) view.findViewById(android.R.id.text1); - return tv1.getText().toString(); - } - } - - @Override - public View newView(Context context, Cursor cursor, ViewGroup parent) { - final LayoutInflater inflater = LayoutInflater.from(context); - final View view = inflater.inflate( - R.layout.url_dropdown_item, parent, false); - bindView(view, context, cursor); - return view; - } - - @Override - public void bindView(View view, Context context, Cursor cursor) { - TextView tv1 = (TextView) view.findViewById(android.R.id.text1); - TextView tv2 = (TextView) view.findViewById(android.R.id.text2); - ImageView ic1 = (ImageView) view.findViewById(R.id.icon1); - View ic2 = view.findViewById(R.id.icon2); - tv1.setText(cursor.getString(mIndexText1)); - String url = cursor.getString(mIndexText2); - tv2.setText((url != null) ? url : ""); - ic2.setOnClickListener(UrlInputView.this); - // assume an id - try { - int id = Integer.parseInt(cursor.getString(mIndexIcon)); - Drawable d = context.getResources().getDrawable(id); - ic1.setImageDrawable(d); - ic2.setVisibility((id == R.drawable.ic_search_category_suggest)? View.VISIBLE : View.GONE); - } catch (NumberFormatException nfx) { - } - view.setOnClickListener(UrlInputView.this); - } + public void onDismiss(); - @Override - public String convertToString(Cursor cursor) { - return cursor.getString(mIndexText1); - } + public void onAction(String text); - @Override - public Cursor runQueryOnBackgroundThread(CharSequence constraint) { - if (getFilterQueryProvider() != null) { - return getFilterQueryProvider().runQuery(constraint); - } - mLastCursor = BrowserProvider.getBookmarksSuggestions(mContent, - (constraint != null) ? constraint.toString() : null); - return mLastCursor; - } + public void onEdit(String text); } |