/*
* Copyright (C) 2010 Cyril Mottier (http://www.cyrilmottier.com)
*
* 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 greendroid.app;
import greendroid.util.Config;
import greendroid.widget.ActionBar;
import android.os.Handler;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup.LayoutParams;
import android.widget.AdapterView;
import android.widget.ListAdapter;
import android.widget.ListView;
import com.cyrilmottier.android.greendroid.R;
/**
* An equivalent to ListActivity that manages a ListView.
*
* @author Cyril Mottier
*/
public class GDListActivity extends GDActivity {
private static final String LOG_TAG = GDListActivity.class.getSimpleName();
private ListAdapter mAdapter;
private ListView mListView;
private View mEmptyView;
private Handler mHandler = new Handler();
private boolean mFinishedStart = false;
private Runnable mRequestFocus = new Runnable() {
public void run() {
mListView.focusableViewAvailable(mListView);
}
};
public GDListActivity() {
super();
}
public GDListActivity(ActionBar.Type actionBarType) {
super(actionBarType);
}
/**
* This method will be called when an item in the list is selected.
* Subclasses should override. Subclasses can call
* getListView().getItemAtPosition(position) if they need to access the data
* associated with the selected item.
*
* @param l The ListView where the click happened
* @param v The view that was clicked within the ListView
* @param position The position of the view in the list
* @param id The row id of the item that was clicked
*/
protected void onListItemClick(ListView l, View v, int position, long id) {
}
/**
* Set the currently selected list item to the specified position with the
* adapter's data
*
* @param position The position to select in the managed ListView
*/
public void setSelection(int position) {
mListView.setSelection(position);
}
/**
* Get the position of the currently selected list item.
*
* @return The position of the currently selected ListView item.
*/
public int getSelectedItemPosition() {
return mListView.getSelectedItemPosition();
}
/**
* Get the ListAdapter row ID of the currently selected list item.
*
* @return The identifier of the selected ListView item.
*/
public long getSelectedItemId() {
return mListView.getSelectedItemId();
}
/**
* Get the activity's ListView widget.
*
* @return The ListView managed by the current {@link GDListActivity}
*/
public ListView getListView() {
ensureLayout();
return mListView;
}
/**
* Get the ListAdapter associated with this activity's ListView.
*
* @return The ListAdapter currently associated to the underlying ListView
*/
public ListAdapter getListAdapter() {
return mAdapter;
}
/**
* Provides the Adapter for the ListView handled by this
* {@link GDListActivity}
*
* @param adapter The ListAdapter to set.
*/
public void setListAdapter(ListAdapter adapter) {
synchronized (this) {
ensureLayout();
mAdapter = adapter;
mListView.setAdapter(adapter);
}
}
@Override
public int createLayout() {
if (Config.GD_INFO_LOGS_ENABLED) {
Log.i(LOG_TAG, "No layout specified : creating the default layout");
}
switch (getActionBarType()) {
case Dashboard:
return R.layout.gd_list_content_dashboard;
case Empty:
return R.layout.gd_list_content_empty;
case Normal:
default:
return R.layout.gd_list_content_normal;
}
}
@Override
protected boolean verifyLayout() {
return super.verifyLayout() && mListView != null;
}
@Override
public void onPreContentChanged() {
super.onPreContentChanged();
mEmptyView = findViewById(android.R.id.empty);
mListView = (ListView) findViewById(android.R.id.list);
if (mListView == null) {
throw new RuntimeException("Your content must have a ListView whose id attribute is " + "'android.R.id.list'");
}
}
@Override
public void onPostContentChanged() {
super.onPostContentChanged();
if (mEmptyView != null) {
mListView.setEmptyView(mEmptyView);
}
mListView.setOnItemClickListener(mOnItemClickListener);
if (mFinishedStart) {
setListAdapter(mAdapter);
}
mHandler.post(mRequestFocus);
mFinishedStart = true;
}
@Override
public void setActionBarContentView(int resID) {
throwSetActionBarContentViewException();
}
@Override
public void setActionBarContentView(View view, LayoutParams params) {
throwSetActionBarContentViewException();
}
@Override
public void setActionBarContentView(View view) {
throwSetActionBarContentViewException();
}
private void throwSetActionBarContentViewException() {
throw new UnsupportedOperationException(
"The setActionBarContentView method is not supported for GDListActivity. In order to get a custom layout you must return a layout identifier in createLayout");
}
private AdapterView.OnItemClickListener mOnItemClickListener = new AdapterView.OnItemClickListener() {
public void onItemClick(AdapterView<?> parent, View v, int position, long id) {
onListItemClick((ListView) parent, v, position, id);
}
};
}