diff options
author | Leon Scroggins <scroggo@google.com> | 2011-01-06 20:25:54 -0500 |
---|---|---|
committer | Leon Scroggins <scroggo@google.com> | 2011-01-07 09:42:19 -0500 |
commit | dd13bad0ea5e01b6689a61145327febea4bfde8a (patch) | |
tree | 1f592081260ac01b3e71e248e282254150c69486 | |
parent | 2ab6d2509cc1d9d55a97935501689fe08f8baf0c (diff) | |
download | packages_apps_browser-dd13bad0ea5e01b6689a61145327febea4bfde8a.zip packages_apps_browser-dd13bad0ea5e01b6689a61145327febea4bfde8a.tar.gz packages_apps_browser-dd13bad0ea5e01b6689a61145327febea4bfde8a.tar.bz2 |
Use a spinner for the folder selector.
Bug:2953515
Change-Id: I6487330840e38cf1d03a2a9ffcecbc6e211a3c38
-rw-r--r-- | res/layout/add_to_option.xml (renamed from res/menu/folder_choice.xml) | 20 | ||||
-rw-r--r-- | res/layout/browser_add_bookmark.xml | 12 | ||||
-rw-r--r-- | src/com/android/browser/AddBookmarkPage.java | 101 | ||||
-rw-r--r-- | src/com/android/browser/addbookmark/FolderSpinner.java | 45 | ||||
-rw-r--r-- | src/com/android/browser/addbookmark/FolderSpinnerAdapter.java | 135 |
5 files changed, 247 insertions, 66 deletions
diff --git a/res/menu/folder_choice.xml b/res/layout/add_to_option.xml index c62e2f8..4cfa9f8 100644 --- a/res/menu/folder_choice.xml +++ b/res/layout/add_to_option.xml @@ -1,5 +1,5 @@ <?xml version="1.0" encoding="utf-8"?> -<!-- Copyright (C) 2010 The Android Open Source Project +<!-- Copyright (C) 2011 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. @@ -13,15 +13,9 @@ See the License for the specific language governing permissions and limitations under the License. --> - -<menu xmlns:android="http://schemas.android.com/apk/res/android"> - <item android:id="@+id/home_screen" - android:icon="@*android:drawable/ic_menu_home" - android:title="@string/add_to_homescreen_menu_option"/> - <item android:id="@+id/bookmarks" - android:icon="@drawable/ic_menu_bookmarks" - android:title="@string/add_to_bookmarks_menu_option"/> - <item android:id="@+id/other" - android:icon="@*android:drawable/ic_menu_archive" - android:title="@string/add_to_other_folder_menu_option"/> -</menu> +<TextView xmlns:android="http://schemas.android.com/apk/res/android" + android:layout_width="match_parent" + android:layout_height="wrap_content" + android:textAppearance="?android:attr/textAppearanceMedium" + android:gravity="center_vertical" + android:minHeight="?android:attr/listPreferredItemHeight" /> diff --git a/res/layout/browser_add_bookmark.xml b/res/layout/browser_add_bookmark.xml index 8adf4b6..e25f903 100644 --- a/res/layout/browser_add_bookmark.xml +++ b/res/layout/browser_add_bookmark.xml @@ -131,19 +131,15 @@ android:text="@string/containing_folder" android:textAppearance="?android:attr/textAppearanceMedium" /> - <TextView + <view class="com.android.browser.addbookmark.FolderSpinner" android:id="@+id/folder" android:layout_height="wrap_content" - android:layout_width="250dip" + android:layout_width="wrap_content" android:layout_marginRight="20dip" android:layout_marginLeft="20dip" + android:spinnerMode="dropdown" android:gravity="center_vertical" - android:singleLine="true" - android:ellipsize="start" - android:text="@string/bookmarks" - android:drawableLeft="@drawable/ic_menu_bookmarks" - android:layout_marginBottom="40dip" - android:textAppearance="?android:attr/textAppearanceMedium" /> + /> </TableRow> </TableLayout> diff --git a/src/com/android/browser/AddBookmarkPage.java b/src/com/android/browser/AddBookmarkPage.java index d3c147c..9d8c73c 100644 --- a/src/com/android/browser/AddBookmarkPage.java +++ b/src/com/android/browser/AddBookmarkPage.java @@ -17,6 +17,7 @@ package com.android.browser; import com.android.browser.provider.BrowserProvider2; +import com.android.browser.addbookmark.FolderSpinnerAdapter; import android.app.Activity; import android.app.LoaderManager; @@ -44,7 +45,6 @@ import android.text.TextUtils; import android.util.AttributeSet; import android.view.KeyEvent; import android.view.LayoutInflater; -import android.view.MenuItem; import android.view.View; import android.view.ViewGroup; import android.view.Window; @@ -55,7 +55,7 @@ import android.widget.AdapterView; import android.widget.CursorAdapter; import android.widget.EditText; import android.widget.ListView; -import android.widget.PopupMenu; +import android.widget.Spinner; import android.widget.TextView; import android.widget.Toast; @@ -66,7 +66,7 @@ import java.util.Stack; public class AddBookmarkPage extends Activity implements View.OnClickListener, TextView.OnEditorActionListener, AdapterView.OnItemClickListener, LoaderManager.LoaderCallbacks<Cursor>, - BreadCrumbView.Controller, PopupMenu.OnMenuItemClickListener { + BreadCrumbView.Controller, AdapterView.OnItemSelectedListener { public static final long DEFAULT_FOLDER_ID = -1; public static final String TOUCH_ICON_URL = "touch_icon_url"; @@ -94,7 +94,7 @@ public class AddBookmarkPage extends Activity private Bundle mMap; private String mTouchIconUrl; private String mOriginalUrl; - private TextView mFolder; + private Spinner mFolder; private View mDefaultView; private View mFolderSelector; private EditText mFolderNamer; @@ -112,7 +112,9 @@ public class AddBookmarkPage extends Activity private long mRootFolder; private TextView mTopLevelLabel; private Drawable mHeaderIcon; - + // We manually change the spinner's selection if the edited bookmark is not + // in the root folder. This makes sure our listener ignores this change. + private boolean mIgnoreSelectionChange; private static class Folder { String Name; long Id; @@ -198,11 +200,22 @@ public class AddBookmarkPage extends Activity if (data != null) { Folder folder = (Folder) data; mCurrentFolder = folder.Id; - int resource = mCurrentFolder == mRootFolder ? - R.drawable.ic_menu_bookmarks : - com.android.internal.R.drawable.ic_menu_archive; - Drawable drawable = getResources().getDrawable(resource); - updateFolderLabel(folder.Name, drawable); + if (mCurrentFolder == mRootFolder) { + // The Spinner changed to show "Other folder ..." Change + // it back to "Bookmarks", which is position 0 if we are + // editing a folder, 1 otherwise. + mFolder.setSelection(mEditingFolder ? 0 : 1); + } else { + ((TextView) mFolder.getSelectedView()).setText(folder.Name); + } + } + } else { + // The user canceled selecting a folder. Revert back to the earlier + // selection. + if (mSaveToHomeScreen) { + mFolder.setSelection(0); + } else { + mFolder.setSelection(mEditingFolder ? 0 : 1); } } } @@ -230,15 +243,6 @@ public class AddBookmarkPage extends Activity } else { finish(); } - } else if (v == mFolder) { - PopupMenu popup = new PopupMenu(this, mFolder); - popup.getMenuInflater().inflate(R.menu.folder_choice, - popup.getMenu()); - if (mEditingFolder) { - popup.getMenu().removeItem(R.id.home_screen); - } - popup.setOnMenuItemClickListener(this); - popup.show(); } else if (v == mAddNewFolder) { setShowFolderNamer(true); mFolderNamer.setText(R.string.new_folder); @@ -254,25 +258,32 @@ public class AddBookmarkPage extends Activity } @Override - public boolean onMenuItemClick(MenuItem item) { - switch(item.getItemId()) { - case R.id.bookmarks: + public void onItemSelected(AdapterView<?> parent, View view, int position, long id) { + if (mIgnoreSelectionChange) { + mIgnoreSelectionChange = false; + return; + } + // In response to the spinner changing. + int intId = (int) id; + switch (intId) { + case FolderSpinnerAdapter.ROOT_FOLDER: mCurrentFolder = mRootFolder; - updateFolderLabel(item.getTitle(), item.getIcon()); mSaveToHomeScreen = false; break; - case R.id.home_screen: + case FolderSpinnerAdapter.HOME_SCREEN: // Create a short cut to the home screen mSaveToHomeScreen = true; - updateFolderLabel(item.getTitle(), item.getIcon()); break; - case R.id.other: + case FolderSpinnerAdapter.OTHER_FOLDER: switchToFolderSelector(); break; default: - return false; + break; } - return true; + } + + @Override + public void onNothingSelected(AdapterView<?> parent) { } private void completeOrCancelFolderNaming(boolean cancel) { @@ -317,6 +328,8 @@ public class AddBookmarkPage extends Activity } private void switchToFolderSelector() { + // Set the list to the top in case it is scrolled. + mListView.setSelection(0); mDefaultView.setVisibility(View.GONE); mFolderSelector.setVisibility(View.VISIBLE); mCrumbHolder.setVisibility(View.VISIBLE); @@ -399,9 +412,7 @@ public class AddBookmarkPage extends Activity moveCursorToFolder(cursor, parent, idIndex); String name = cursor.getString(titleIndex); if (parent == mCurrentFolder) { - Drawable draw = getResources().getDrawable( - com.android.internal.R.drawable.ic_menu_archive); - updateFolderLabel(name, draw); + ((TextView) mFolder.getSelectedView()).setText(name); } folderStack.push(new Folder(name, parent)); parent = cursor.getLong(parentIndex); @@ -448,18 +459,6 @@ public class AddBookmarkPage extends Activity } } - /** - * Update the name and image to show where the bookmark will be added - * @param name Name of the location to save (folder name, bookmarks, or home - * screen. - * @param drawable Image to show corresponding to the save location. - */ - void updateFolderLabel(CharSequence name, Drawable drawable) { - mFolder.setText(name); - mFolder.setCompoundDrawablesWithIntrinsicBounds(drawable, null, null, - null); - } - @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { @@ -573,8 +572,15 @@ public class AddBookmarkPage extends Activity mCancelButton = findViewById(R.id.cancel); mCancelButton.setOnClickListener(this); - mFolder = (TextView) findViewById(R.id.folder); - mFolder.setOnClickListener(this); + mFolder = (Spinner) findViewById(R.id.folder); + mFolder.setAdapter(new FolderSpinnerAdapter(!mEditingFolder)); + if (!mEditingFolder) { + // Initially the "Bookmarks" folder should be showing, rather than + // the home screen. In the editing folder case, home screen is not + // an option, so "Bookmarks" folder is already at the top. + mFolder.setSelection(FolderSpinnerAdapter.ROOT_FOLDER); + } + mFolder.setOnItemSelectedListener(this); mDefaultView = findViewById(R.id.default_view); mFolderSelector = findViewById(R.id.folder_selector); @@ -609,6 +615,11 @@ public class AddBookmarkPage extends Activity if (mCurrentFolder != mRootFolder) { // Find all the folders manager.initLoader(LOADER_ID_ALL_FOLDERS, null, this); + // Since we're not in the root folder, change the selection to other + // folder now. The text will get changed once we select the correct + // folder. + mIgnoreSelectionChange = true; + mFolder.setSelection(mEditingFolder ? 1 : 2); } else { setShowBookmarkIcon(true); } diff --git a/src/com/android/browser/addbookmark/FolderSpinner.java b/src/com/android/browser/addbookmark/FolderSpinner.java new file mode 100644 index 0000000..789c1f1 --- /dev/null +++ b/src/com/android/browser/addbookmark/FolderSpinner.java @@ -0,0 +1,45 @@ +/* + * Copyright (C) 2011 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.browser.addbookmark; + +import android.content.Context; +import android.view.View; +import android.util.AttributeSet; +import android.widget.Spinner; + +/** + * Special Spinner class which calls onItemSelected even if the item selected + * was already selected. In that case, it passes null for the View. + */ +public class FolderSpinner extends Spinner { + public FolderSpinner(Context context, AttributeSet attrs) { + super(context, attrs); + } + + @Override + public void setSelection(int position) { + int oldPosition = getSelectedItemPosition(); + super.setSelection(position); + if (oldPosition == position) { + // Normally this is not called because the item did not actually + // change, but in this case, we still want it to be called. + long id = getAdapter().getItemId(position); + getOnItemSelectedListener().onItemSelected(this, null, position, id); + } + } +} + diff --git a/src/com/android/browser/addbookmark/FolderSpinnerAdapter.java b/src/com/android/browser/addbookmark/FolderSpinnerAdapter.java new file mode 100644 index 0000000..5c17bfa --- /dev/null +++ b/src/com/android/browser/addbookmark/FolderSpinnerAdapter.java @@ -0,0 +1,135 @@ +/* + * Copyright (C) 2011 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.browser.addbookmark; + +import com.android.browser.R; + +import android.content.Context; +import android.content.res.Resources; +import android.database.DataSetObserver; +import android.graphics.drawable.Drawable; +import android.view.LayoutInflater; +import android.view.View; +import android.view.ViewGroup; +import android.widget.Adapter; +import android.widget.SpinnerAdapter; +import android.widget.TextView; + +/** + * SpinnerAdapter used in the AddBookmarkPage to select where to save a + * bookmark/folder. + */ +public class FolderSpinnerAdapter implements SpinnerAdapter { + private boolean mIncludeHomeScreen; + + public static final int HOME_SCREEN = 0; + public static final int ROOT_FOLDER = 1; + public static final int OTHER_FOLDER = 2; + + public FolderSpinnerAdapter(boolean includeHomeScreen) { + mIncludeHomeScreen = includeHomeScreen; + } + + @Override + public View getDropDownView(int position, View convertView, ViewGroup parent) { + int labelResource; + int drawableResource; + if (!mIncludeHomeScreen) { + position++; + } + switch (position) { + case HOME_SCREEN: + labelResource = R.string.add_to_homescreen_menu_option; + drawableResource = com.android.internal.R.drawable.ic_menu_home; + break; + case ROOT_FOLDER: + labelResource = R.string.add_to_bookmarks_menu_option; + drawableResource = R.drawable.ic_menu_bookmarks; + break; + case OTHER_FOLDER: + labelResource = R.string.add_to_other_folder_menu_option; + drawableResource = com.android.internal.R.drawable.ic_menu_archive; + break; + default: + labelResource = 0; + drawableResource = 0; + // assert + break; + } + Context context = parent.getContext(); + LayoutInflater factory = LayoutInflater.from(context); + TextView textView = (TextView) factory.inflate(R.layout.add_to_option, null); + textView.setText(labelResource); + Drawable drawable = context.getResources().getDrawable(drawableResource); + textView.setCompoundDrawablesWithIntrinsicBounds(drawable, null, + null, null); + return textView; + } + + @Override + public void registerDataSetObserver(DataSetObserver observer) { + } + + @Override + public void unregisterDataSetObserver(DataSetObserver observer) { + } + + @Override + public int getCount() { + return mIncludeHomeScreen ? 3 : 2; + } + + @Override + public Object getItem(int position) { + return null; + } + + @Override + public long getItemId(int position) { + long id = position; + if (!mIncludeHomeScreen) { + id++; + } + return id; + } + + @Override + public boolean hasStableIds() { + return true; + } + + @Override + public View getView(int position, View convertView, ViewGroup parent) { + return getDropDownView(position, convertView, parent); + } + + @Override + public int getItemViewType(int position) { + // Never want to recycle views + return Adapter.IGNORE_ITEM_VIEW_TYPE; + } + + @Override + public int getViewTypeCount() { + return 1; + } + + @Override + public boolean isEmpty() { + return false; + } +} |