diff options
Diffstat (limited to 'src/com/android/browser/addbookmark/FolderSpinner.java')
-rw-r--r-- | src/com/android/browser/addbookmark/FolderSpinner.java | 63 |
1 files changed, 55 insertions, 8 deletions
diff --git a/src/com/android/browser/addbookmark/FolderSpinner.java b/src/com/android/browser/addbookmark/FolderSpinner.java index 789c1f1..dd85cda 100644 --- a/src/com/android/browser/addbookmark/FolderSpinner.java +++ b/src/com/android/browser/addbookmark/FolderSpinner.java @@ -19,27 +19,74 @@ package com.android.browser.addbookmark; import android.content.Context; import android.view.View; import android.util.AttributeSet; +import android.widget.AdapterView; 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. + * Special Spinner class with its own callback for when the selection is set, which + * can be ignored by calling setSelectionIgnoringSelectionChange */ -public class FolderSpinner extends Spinner { +public class FolderSpinner extends Spinner + implements AdapterView.OnItemSelectedListener { + private OnSetSelectionListener mOnSetSelectionListener; + private boolean mFireSetSelection; + + /** + * Callback for knowing when the selection has been manually set. Does not + * get called until the selected view has changed. + */ + public interface OnSetSelectionListener { + public void onSetSelection(long id); + } + public FolderSpinner(Context context, AttributeSet attrs) { super(context, attrs); + super.setOnItemSelectedListener(this); + } + + @Override + public void setOnItemSelectedListener(AdapterView.OnItemSelectedListener l) { + // Disallow setting an OnItemSelectedListener, since it is used by us + // to fire onSetSelection. + throw new RuntimeException("Cannot set an OnItemSelectedListener on a FolderSpinner"); + } + + public void setOnSetSelectionListener(OnSetSelectionListener l) { + mOnSetSelectionListener = l; + } + + /** + * Call setSelection, without firing the callback + * @param position New position to select. + */ + public void setSelectionIgnoringSelectionChange(int position) { + super.setSelection(position); } @Override public void setSelection(int position) { + mFireSetSelection = true; 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); + if (mOnSetSelectionListener != null) { + if (oldPosition == position) { + long id = getAdapter().getItemId(position); + // Normally this is not called because the item did not actually + // change, but in this case, we still want it to be called. + onItemSelected(this, null, position, id); + } + } + } + + @Override + public void onItemSelected(AdapterView<?> parent, View view, int position, long id) { + if (mFireSetSelection) { + mOnSetSelectionListener.onSetSelection(id); + mFireSetSelection = false; } } + + @Override + public void onNothingSelected(AdapterView<?> parent) {} } |