summaryrefslogtreecommitdiff
path: root/src/com/android/dreams/phototable/FlipperDreamSettings.java
diff options
context:
space:
mode:
authorChris Wren <cwren@android.com>2012-12-04 17:35:11 -0500
committerChris Wren <cwren@android.com>2012-12-10 10:48:47 -0500
commit2ccf92a79a2749a6fdaf5c1242f5d72de48ef111 (patch)
treef1cb3df449c936501913735d09da38ec8dd642b9 /src/com/android/dreams/phototable/FlipperDreamSettings.java
parent387363c426e097c358bd41367e0a8f4339fc8dc3 (diff)
downloadPhotoTable-2ccf92a79a2749a6fdaf5c1242f5d72de48ef111.tar.gz
Add 'select all' to photo dream settings.
Bug: 7269182 Change-Id: I78898bb9e76d6233487b4888e56f896f3c6ea72d
Diffstat (limited to 'src/com/android/dreams/phototable/FlipperDreamSettings.java')
-rw-r--r--src/com/android/dreams/phototable/FlipperDreamSettings.java56
1 files changed, 53 insertions, 3 deletions
diff --git a/src/com/android/dreams/phototable/FlipperDreamSettings.java b/src/com/android/dreams/phototable/FlipperDreamSettings.java
index 1252846..8e6fac4 100644
--- a/src/com/android/dreams/phototable/FlipperDreamSettings.java
+++ b/src/com/android/dreams/phototable/FlipperDreamSettings.java
@@ -16,9 +16,13 @@
package com.android.dreams.phototable;
import android.content.SharedPreferences;
+import android.database.DataSetObserver;
import android.app.ListActivity;
import android.os.AsyncTask;
import android.os.Bundle;
+import android.view.Menu;
+import android.view.MenuInflater;
+import android.view.MenuItem;
import android.view.View;
import android.widget.ListAdapter;
@@ -31,15 +35,20 @@ public class FlipperDreamSettings extends ListActivity {
private static final String TAG = "FlipperDreamSettings";
public static final String PREFS_NAME = FlipperDream.TAG;
+ protected SharedPreferences mSettings;
+
private PhotoSourcePlexor mPhotoSource;
- private ListAdapter mAdapter;
- private SharedPreferences mSettings;
+ private SectionedAlbumDataAdapter mAdapter;
+ private MenuItem mSelectAll;
@Override
protected void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
-
mSettings = getSharedPreferences(PREFS_NAME, 0);
+ init();
+ }
+
+ protected void init() {
mPhotoSource = new PhotoSourcePlexor(this, mSettings);
setContentView(R.layout.settingslist);
@@ -56,11 +65,52 @@ public class FlipperDreamSettings extends ListActivity {
@Override
public void onPostExecute(Void unused) {
+ mAdapter.registerDataSetObserver(new DataSetObserver () {
+ @Override
+ public void onChanged() {
+ updateActionItem();
+ }
+ @Override
+ public void onInvalidated() {
+ updateActionItem();
+ }
+ });
setListAdapter(mAdapter);
+ updateActionItem();
if (mAdapter.getCount() == 0) {
findViewById(android.R.id.empty).setVisibility(View.GONE);
}
}
}.execute();
}
+
+ @Override
+ public boolean onCreateOptionsMenu(Menu menu) {
+ MenuInflater inflater = getMenuInflater();
+ inflater.inflate(R.menu.photodream_settings_menu, menu);
+ mSelectAll = menu.findItem(R.id.photodream_menu_all);
+ updateActionItem();
+ return true;
+ }
+
+ @Override
+ public boolean onOptionsItemSelected(MenuItem item) {
+ switch (item.getItemId()) {
+ case R.id.photodream_menu_all:
+ mAdapter.selectAll(!mAdapter.areAllSelected());
+ return true;
+ default:
+ return super.onOptionsItemSelected(item);
+ }
+ }
+
+ private void updateActionItem() {
+ if (mAdapter != null && mSelectAll != null) {
+ if (mAdapter.areAllSelected()) {
+ mSelectAll.setTitle(R.string.photodream_select_none);
+ } else {
+ mSelectAll.setTitle(R.string.photodream_select_all);
+ }
+ }
+ }
}