19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/*
29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Copyright (C) 2006 The Android Open Source Project
39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
59066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you may not use this file except in compliance with the License.
69066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * You may obtain a copy of the License at
79066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
99066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * See the License for the specific language governing permissions and
149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * limitations under the License.
159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpackage android.widget;
189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/**
209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Extended {@link Adapter} that is the bridge between a {@link ListView}
219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * and the data that backs the list. Frequently that data comes from a Cursor,
229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * but that is not
239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * required. The ListView can display any data provided that it is wrapped in a
249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * ListAdapter.
259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic interface ListAdapter extends Adapter {
279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Are all items in this ListAdapter enabled?
309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * If yes it means all items are selectable and clickable.
319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return True if all items are enabled
339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public boolean areAllItemsEnabled();
359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Returns true if the item at the specified position is not a separator.
389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * (A separator is a non-selectable, non-clickable item).
399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param position Index of the item
419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return True if the item is not a separator
429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    boolean isEnabled(int position);
449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project}
45