當前位置: 首頁>>代碼示例>>Java>>正文


Java AbsListView.CHOICE_MODE_NONE屬性代碼示例

本文整理匯總了Java中android.widget.AbsListView.CHOICE_MODE_NONE屬性的典型用法代碼示例。如果您正苦於以下問題:Java AbsListView.CHOICE_MODE_NONE屬性的具體用法?Java AbsListView.CHOICE_MODE_NONE怎麽用?Java AbsListView.CHOICE_MODE_NONE使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在android.widget.AbsListView的用法示例。


在下文中一共展示了AbsListView.CHOICE_MODE_NONE屬性的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: setAdapter

/**
 * {@inheritDoc}
 */
@Override
public void setAdapter(ListAdapter adapter) {
	if (adapter != null) {
		mAdapterHasStableIds = mAdapter.hasStableIds();
		if (mChoiceMode != AbsListView.CHOICE_MODE_NONE
				&& mAdapterHasStableIds && mCheckedIdStates == null) {
			mCheckedIdStates = new LongSparseArray<Integer>();
		}
	}

	if (mCheckStates != null) {
		mCheckStates.clear();
	}

	if (mCheckedIdStates != null) {
		mCheckedIdStates.clear();
	}
}
 
開發者ID:junchenChow,項目名稱:exciting-app,代碼行數:21,代碼來源:AbsHListView.java

示例2: getCheckedItemIds

/**
 * Returns the set of checked items ids. The result is only valid if the
 * choice mode has not been set to {@link #CHOICE_MODE_NONE} and the adapter
 * has stable IDs. ({@link ListAdapter#hasStableIds()} == {@code true})
 * 
 * @return A new array which contains the id of each checked item in the
 *         list.
 */
public long[] getCheckedItemIds() {
	if (mChoiceMode == AbsListView.CHOICE_MODE_NONE
			|| mCheckedIdStates == null || mAdapter == null) {
		return new long[0];
	}

	final LongSparseArray<Integer> idStates = mCheckedIdStates;
	final int count = idStates.size();
	final long[] ids = new long[count];

	for (int i = 0; i < count; i++) {
		ids[i] = idStates.keyAt(i);
	}

	return ids;
}
 
開發者ID:junchenChow,項目名稱:exciting-app,代碼行數:24,代碼來源:AbsHListView.java

示例3: getCheckItemIds

/**
 * Returns the set of checked items ids. The result is only valid if the
 * choice mode has not been set to {@link #CHOICE_MODE_NONE}.
 * 
 * @return A new array which contains the id of each checked item in the
 *         list.
 * 
 * @deprecated Use {@link #getCheckedItemIds()} instead.
 */
@Deprecated
public long[] getCheckItemIds() {
	// Use new behavior that correctly handles stable ID mapping.
	if (mAdapter != null && mAdapter.hasStableIds()) {
		return getCheckedItemIds();
	}

	// Old behavior was buggy, but would sort of work for adapters without
	// stable IDs.
	// Fall back to it to support legacy apps.
	if (mChoiceMode != AbsListView.CHOICE_MODE_NONE && mCheckStates != null && mAdapter != null) {
		final SparseArrayCompat<Boolean> states = mCheckStates;
		final int count = states.size();
		final long[] ids = new long[count];
		final ListAdapter adapter = mAdapter;

		int checkedCount = 0;
		for (int i = 0; i < count; i++) {
			if (states.valueAt(i)) {
				ids[checkedCount++] = adapter.getItemId(states.keyAt(i));
			}
		}

		// Trim array if needed. mCheckStates may contain false values
		// resulting in checkedCount being smaller than count.
		if (checkedCount == count) {
			return ids;
		} else {
			final long[] result = new long[checkedCount];
			System.arraycopy(ids, 0, result, 0, checkedCount);

			return result;
		}
	}
	return new long[0];
}
 
開發者ID:junchenChow,項目名稱:exciting-app,代碼行數:45,代碼來源:HListView.java

示例4: setChoiceMode

/**
 * Defines the choice behavior for the List. By default, Lists do not have
 * any choice behavior ({@link #CHOICE_MODE_NONE}). By setting the
 * choiceMode to {@link #CHOICE_MODE_SINGLE}, the List allows up to one item
 * to be in a chosen state. By setting the choiceMode to
 * {@link #CHOICE_MODE_MULTIPLE}, the list allows any number of items to be
 * chosen.
 * 
 * @param choiceMode
 *            One of {@link #CHOICE_MODE_NONE}, {@link #CHOICE_MODE_SINGLE},
 *            or {@link #CHOICE_MODE_MULTIPLE}
 */
@TargetApi(11)
public void setChoiceMode(int choiceMode) {
	mChoiceMode = choiceMode;

	if (android.os.Build.VERSION.SDK_INT >= 11) {
		if (mChoiceActionMode != null) {

			if (android.os.Build.VERSION.SDK_INT >= 11) {
				((ActionMode) mChoiceActionMode).finish();
			}
			mChoiceActionMode = null;
		}
	}

	if (mChoiceMode != AbsListView.CHOICE_MODE_NONE) {
		if (mCheckStates == null) {
			mCheckStates = new SparseArrayCompat<Boolean>();
		}
		if (mCheckedIdStates == null && mAdapter != null
				&& mAdapter.hasStableIds()) {
			mCheckedIdStates = new LongSparseArray<Integer>();
		}
		// Modal multi-choice mode only has choices when the mode is active.
		// Clear them.
		if (android.os.Build.VERSION.SDK_INT >= 11) {
			if (mChoiceMode == AbsListView.CHOICE_MODE_MULTIPLE_MODAL) {
				clearChoices();
				setLongClickable(true);
			}
		}
	}
}
 
開發者ID:junchenChow,項目名稱:exciting-app,代碼行數:44,代碼來源:AbsHListView.java

示例5: AbsHListView

public AbsHListView(Context context, AttributeSet attrs, int defStyle) {
	super(context, attrs, defStyle);

	if (LOG_ENABLED) {
		Log.i(LOG_TAG, "defStyle: " + defStyle);
	}

	initAbsListView();

	final Resources.Theme theme = context.getTheme();

	TypedArray array = theme.obtainStyledAttributes(attrs,
			R.styleable.AbsHListView, defStyle, 0);

	Drawable listSelector = null;
	boolean drawSelectorOnTop = false;
	boolean stackFromRight = false;
	boolean scrollingCacheEnabled = true;
	int transcriptMode = TRANSCRIPT_MODE_DISABLED;
	int color = 0;
	boolean smoothScrollbar = true;
	int choiceMode = AbsListView.CHOICE_MODE_NONE;

	if (null != array) {
		listSelector = array
				.getDrawable(R.styleable.AbsHListView_android_listSelector);
		drawSelectorOnTop = array.getBoolean(
				R.styleable.AbsHListView_android_drawSelectorOnTop, false);
		stackFromRight = array.getBoolean(
				R.styleable.AbsHListView_hlv_stackFromRight, false);
		scrollingCacheEnabled = array.getBoolean(
				R.styleable.AbsHListView_android_scrollingCache, true);
		transcriptMode = array.getInt(
				R.styleable.AbsHListView_hlv_transcriptMode,
				TRANSCRIPT_MODE_DISABLED);
		color = array.getColor(
				R.styleable.AbsHListView_android_cacheColorHint, 0);
		smoothScrollbar = array.getBoolean(
				R.styleable.AbsHListView_android_smoothScrollbar, true);
		choiceMode = array.getInt(
				R.styleable.AbsHListView_android_choiceMode,
				AbsListView.CHOICE_MODE_NONE);
		array.recycle();

		if (LOG_ENABLED) {
			////log.d(TAG, "listSelector: " + listSelector);
			////log.d(TAG, "drawSelectorOnTop: " + drawSelectorOnTop);
			////log.d(TAG, "stackFromRight: " + stackFromRight);
			////log.d(TAG, "scrollingCacheEnabled: " + scrollingCacheEnabled);
			////log.d(TAG, "transcriptMode: " + transcriptMode);
			////log.d(TAG, "smoothScrollbar: " + smoothScrollbar);
			////log.d(TAG, "choiceMode: " + choiceMode);
		}
	}

	if (listSelector != null) {
		setSelector(listSelector);
	}

	mDrawSelectorOnTop = drawSelectorOnTop;
	setStackFromRight(stackFromRight);
	setScrollingCacheEnabled(scrollingCacheEnabled);
	setTranscriptMode(transcriptMode);
	setCacheColorHint(color);
	setSmoothScrollbarEnabled(smoothScrollbar);
	setChoiceMode(choiceMode);
}
 
開發者ID:junchenChow,項目名稱:exciting-app,代碼行數:67,代碼來源:AbsHListView.java

示例6: isItemChecked

/**
 * Returns the checked state of the specified position. The result is only
 * valid if the choice mode has been set to {@link #CHOICE_MODE_SINGLE} or
 * {@link #CHOICE_MODE_MULTIPLE}.
 * 
 * @param position
 *            The item whose checked state to return
 * @return The item's checked state or <code>false</code> if choice mode is
 *         invalid
 * 
 * @see #setChoiceMode(int)
 */
public boolean isItemChecked(int position) {
	if (mChoiceMode != AbsListView.CHOICE_MODE_NONE && mCheckStates != null) {
		return mCheckStates.get(position, false);
	}

	return false;
}
 
開發者ID:junchenChow,項目名稱:exciting-app,代碼行數:19,代碼來源:AbsHListView.java

示例7: getCheckedItemPositions

/**
 * Returns the set of checked items in the list. The result is only valid if
 * the choice mode has not been set to {@link #CHOICE_MODE_NONE}.
 * 
 * @return A SparseBooleanArray which will return true for each call to
 *         get(int position) where position is a position in the list, or
 *         <code>null</code> if the choice mode is set to
 *         {@link #CHOICE_MODE_NONE}.
 */
public SparseArrayCompat<Boolean> getCheckedItemPositions() {
	if (mChoiceMode != AbsListView.CHOICE_MODE_NONE) {
		return mCheckStates;
	}
	return null;
}
 
開發者ID:junchenChow,項目名稱:exciting-app,代碼行數:15,代碼來源:AbsHListView.java


注:本文中的android.widget.AbsListView.CHOICE_MODE_NONE屬性示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。