diff options
-rw-r--r-- | res/drawable-hdpi/dream_info_bg_pressed.9.png | bin | 0 -> 180 bytes | |||
-rw-r--r-- | res/drawable-hdpi/dream_info_bg_unpressed.9.png | bin | 0 -> 176 bytes | |||
-rw-r--r-- | res/drawable-mdpi/dream_info_bg_pressed.9.png | bin | 0 -> 171 bytes | |||
-rw-r--r-- | res/drawable-mdpi/dream_info_bg_unpressed.9.png | bin | 0 -> 165 bytes | |||
-rw-r--r-- | res/drawable-xhdpi/dream_info_bg_pressed.9.png | bin | 0 -> 207 bytes | |||
-rw-r--r-- | res/drawable-xhdpi/dream_info_bg_upressed.9.png | bin | 0 -> 200 bytes | |||
-rw-r--r-- | res/drawable/dream_info_bg.xml | 22 | ||||
-rw-r--r-- | res/layout/dream_info_row.xml | 82 | ||||
-rw-r--r-- | res/layout/dream_picker_row.xml | 39 | ||||
-rw-r--r-- | res/values/strings.xml | 34 | ||||
-rw-r--r-- | src/com/android/settings/DisplaySettings.java | 12 | ||||
-rw-r--r-- | src/com/android/settings/DreamBackend.java | 204 | ||||
-rw-r--r-- | src/com/android/settings/DreamComponentPreference.java | 241 | ||||
-rw-r--r-- | src/com/android/settings/DreamSettings.java | 341 | ||||
-rw-r--r-- | src/com/android/settings/DreamTesterPreference.java | 51 |
15 files changed, 578 insertions, 448 deletions
diff --git a/res/drawable-hdpi/dream_info_bg_pressed.9.png b/res/drawable-hdpi/dream_info_bg_pressed.9.png Binary files differnew file mode 100644 index 0000000..6193822 --- /dev/null +++ b/res/drawable-hdpi/dream_info_bg_pressed.9.png diff --git a/res/drawable-hdpi/dream_info_bg_unpressed.9.png b/res/drawable-hdpi/dream_info_bg_unpressed.9.png Binary files differnew file mode 100644 index 0000000..6ebed8b --- /dev/null +++ b/res/drawable-hdpi/dream_info_bg_unpressed.9.png diff --git a/res/drawable-mdpi/dream_info_bg_pressed.9.png b/res/drawable-mdpi/dream_info_bg_pressed.9.png Binary files differnew file mode 100644 index 0000000..62d8622 --- /dev/null +++ b/res/drawable-mdpi/dream_info_bg_pressed.9.png diff --git a/res/drawable-mdpi/dream_info_bg_unpressed.9.png b/res/drawable-mdpi/dream_info_bg_unpressed.9.png Binary files differnew file mode 100644 index 0000000..aa239b3 --- /dev/null +++ b/res/drawable-mdpi/dream_info_bg_unpressed.9.png diff --git a/res/drawable-xhdpi/dream_info_bg_pressed.9.png b/res/drawable-xhdpi/dream_info_bg_pressed.9.png Binary files differnew file mode 100644 index 0000000..5c4da74 --- /dev/null +++ b/res/drawable-xhdpi/dream_info_bg_pressed.9.png diff --git a/res/drawable-xhdpi/dream_info_bg_upressed.9.png b/res/drawable-xhdpi/dream_info_bg_upressed.9.png Binary files differnew file mode 100644 index 0000000..bdf477b --- /dev/null +++ b/res/drawable-xhdpi/dream_info_bg_upressed.9.png diff --git a/res/drawable/dream_info_bg.xml b/res/drawable/dream_info_bg.xml new file mode 100644 index 0000000..7930170 --- /dev/null +++ b/res/drawable/dream_info_bg.xml @@ -0,0 +1,22 @@ +<?xml version="1.0" encoding="utf-8"?> +<!-- + Copyright (C) 2012 The Android Open Source Project + + 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. +--> +<selector xmlns:android="http://schemas.android.com/apk/res/android"> + + <item android:drawable="@drawable/dream_info_bg_pressed" android:state_pressed="true"/> + <item android:drawable="@drawable/dream_info_bg_unpressed" android:state_pressed="false"/> + +</selector>
\ No newline at end of file diff --git a/res/layout/dream_info_row.xml b/res/layout/dream_info_row.xml new file mode 100644 index 0000000..64c2653 --- /dev/null +++ b/res/layout/dream_info_row.xml @@ -0,0 +1,82 @@ +<!-- + Copyright (C) 2012 The Android Open Source Project + + 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. +--> +<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" + android:layout_width="match_parent" + android:layout_height="wrap_content" + android:background="@drawable/dream_info_bg" + android:orientation="vertical" > + + <RelativeLayout + android:layout_width="match_parent" + android:layout_height="wrap_content" > + + <ImageView + android:id="@android:id/icon" + android:layout_width="@android:dimen/app_icon_size" + android:layout_height="@android:dimen/app_icon_size" + android:layout_centerVertical="true" + android:layout_margin="8dp" + android:contentDescription="@null" + android:scaleType="fitCenter" /> + + <RadioButton + android:id="@android:id/button1" + android:layout_width="wrap_content" + android:layout_height="match_parent" + android:layout_alignParentRight="true" + android:layout_centerVertical="true" + android:layout_margin="8dp" + android:duplicateParentState="true" /> + + <TextView + android:id="@android:id/text1" + android:layout_width="match_parent" + android:layout_height="wrap_content" + android:layout_centerVertical="true" + android:layout_toLeftOf="@android:id/button1" + android:layout_toRightOf="@android:id/icon" + android:ellipsize="end" + android:fontFamily="sans-serif-light" + android:singleLine="true" + android:textAppearance="?android:attr/textAppearanceLarge" /> + </RelativeLayout> + + <RelativeLayout + android:id="@android:id/widget_frame" + android:layout_width="match_parent" + android:layout_height="wrap_content" > + + <LinearLayout + android:layout_width="match_parent" + android:layout_height="wrap_content" > + + <Button + android:id="@android:id/button2" + android:layout_width="wrap_content" + android:layout_height="wrap_content" + android:layout_weight="1" + android:text="@string/screensaver_settings_dream_settings" /> + + <Button + android:id="@android:id/button3" + android:layout_width="wrap_content" + android:layout_height="wrap_content" + android:layout_weight="1" + android:text="@string/screensaver_settings_dream_preview" /> + </LinearLayout> + </RelativeLayout> + +</LinearLayout>
\ No newline at end of file diff --git a/res/layout/dream_picker_row.xml b/res/layout/dream_picker_row.xml deleted file mode 100644 index b445cf4..0000000 --- a/res/layout/dream_picker_row.xml +++ /dev/null @@ -1,39 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- -/* -** Copyright 2011, The Android Open Source Project -** -** 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. -*/ ---> -<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" - android:layout_width="match_parent" - android:layout_height="wrap_content" - android:minHeight="?android:attr/listPreferredItemHeight" - android:paddingStart="2dip" - android:gravity="center_vertical"> - - <ImageView android:id="@+id/icon" - android:layout_width="@android:dimen/app_icon_size" - android:layout_height="@android:dimen/app_icon_size" - android:scaleType="fitCenter" - android:contentDescription="@null" /> - - <TextView android:id="@+id/title" - android:layout_width="match_parent" - android:layout_height="wrap_content" - android:textAppearance="?android:attr/textAppearanceLarge" - android:paddingStart="6dip" /> - -</LinearLayout> - diff --git a/res/values/strings.xml b/res/values/strings.xml index 4e1a8b1..7eef471 100644 --- a/res/values/strings.xml +++ b/res/values/strings.xml @@ -1702,29 +1702,25 @@ <!-- Display settings screen, trigger for screen saver options --> <string name="screensaver_settings_title">Dream</string> <!-- Display settings screen, summary fragment for screen saver options, activated on sleep or docked --> - <string name="screensaver_settings_summary_both">When docked or asleep and charging</string> + <string name="screensaver_settings_summary_either_long">When docked or asleep and charging</string> + <!-- Dream settings screen, dialog option, activated on sleep or docked --> + <string name="screensaver_settings_summary_either_short">Either</string> <!-- Display settings screen, summary fragment for screen saver options, activated on sleep --> - <string name="screensaver_settings_summary_sleep">When asleep and charging</string> + <string name="screensaver_settings_summary_sleep">While asleep and charging</string> <!-- Display settings screen, summary fragment for screen saver options, activated when docked --> - <string name="screensaver_settings_summary_dock">When docked</string> + <string name="screensaver_settings_summary_dock">While docked</string> <!-- Display settings screen, summary for screen saver options, screen saver is turned off --> <string name="screensaver_settings_summary_off">Disabled</string> - <!-- Screen saver settings, setting option name to select a module --> - <string name="screensaver_component_title">Selected dream</string> - <!-- Screen saver settings, setting option name to change activation timeout --> - <string name="screensaver_timeout_title">When to activate</string> - <!-- Screen saver settings, setting option summary to change activation timeout --> - <string name="screensaver_timeout_summary">After <xliff:g id="timeout_description">%1$s</xliff:g> spent idle</string> - <!-- Screen saver settings, setting option summary to change activation timeout, shown when disabled --> - <string name="screensaver_timeout_zero_summary">Never</string> - <!-- Screen saver settings, button allowing the user to test/try the current module --> - <string name="screensaver_test">Try it!</string> - <!-- Screen saver settings, checkbox allowing the screen saver to activate automatically when - the device sleeps --> - <string name="screensaver_activate_on_sleep_title">Start on sleep</string> - <!-- Screen saver settings, checkbox allowing the screen saver to activate automatically when - the device is docked --> - <string name="screensaver_activate_on_dock_title">Start when docked</string> + <!-- Dream settings screen, caption for when dreams are disabled --> + <string name="screensaver_settings_disabled_prompt">To control what happens when the phone is docked and/or sleeping, turn Dreams on.</string> + <!-- Dream settings screen, action label, start dreaming --> + <string name="screensaver_settings_start_dreaming">Start dreaming now</string> + <!-- Dream settings screen, action label, when to dream --> + <string name="screensaver_settings_when_to_dream">When to dream</string> + <!-- Dream settings screen, button label to launch dream settings --> + <string name="screensaver_settings_dream_settings">Settings</string> + <!-- Dream settings screen, button label to preview dream --> + <string name="screensaver_settings_dream_preview">Preview</string> <!-- Sound & display settings screen, setting option name to change whether the screen adjusts automatically based on lighting conditions --> <string name="automatic_brightness">Automatic brightness</string> <!-- [CHAR LIMIT=30] Sound & display settings screen, setting option name to change font size --> diff --git a/src/com/android/settings/DisplaySettings.java b/src/com/android/settings/DisplaySettings.java index c71f886..622d77e 100644 --- a/src/com/android/settings/DisplaySettings.java +++ b/src/com/android/settings/DisplaySettings.java @@ -232,13 +232,11 @@ public class DisplaySettings extends SettingsPreferenceFragment implements } private void updateScreenSaverSummary() { - boolean activatedOnSleep = DreamSettings.isScreenSaverActivatedOnSleep(getActivity()); - boolean activatedOnDock = DreamSettings.isScreenSaverActivatedOnDock(getActivity()); - mScreenSaverPreference.setSummary( - activatedOnSleep && activatedOnDock ? R.string.screensaver_settings_summary_both : - activatedOnSleep ? R.string.screensaver_settings_summary_sleep : - activatedOnDock ? R.string.screensaver_settings_summary_dock : - R.string.screensaver_settings_summary_off); + int summaryResId = DreamSettings.getSummaryResource(getActivity()); + if (summaryResId > 0) + mScreenSaverPreference.setSummary(summaryResId); + else + mScreenSaverPreference.setSummary(""); } private void updateAccelerometerRotationCheckbox() { diff --git a/src/com/android/settings/DreamBackend.java b/src/com/android/settings/DreamBackend.java new file mode 100644 index 0000000..0c8f80d --- /dev/null +++ b/src/com/android/settings/DreamBackend.java @@ -0,0 +1,204 @@ +/* + * Copyright (C) 2012 The Android Open Source Project + * + * 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 com.android.settings; + +import static android.provider.Settings.Secure.SCREENSAVER_ENABLED; +import static android.provider.Settings.Secure.SCREENSAVER_ACTIVATE_ON_DOCK; +import static android.provider.Settings.Secure.SCREENSAVER_ACTIVATE_ON_SLEEP; + +import android.content.ComponentName; +import android.content.Context; +import android.content.Intent; +import android.content.pm.PackageManager; +import android.content.pm.ResolveInfo; +import android.graphics.drawable.Drawable; +import android.os.RemoteException; +import android.os.ServiceManager; +import android.provider.Settings; +import android.service.dreams.Dream; +import android.service.dreams.IDreamManager; + +import java.util.ArrayList; +import java.util.Collections; +import java.util.Comparator; +import java.util.List; + +public class DreamBackend { + + public static class DreamInfo { + CharSequence caption; + Drawable icon; + boolean isActive; + public ComponentName componentName; + public ComponentName settingsComponentName; + } + + private final Context mContext; + private final IDreamManager mDreamManager; + private final DreamInfoComparator mComparator; + + public DreamBackend(Context context) { + mContext = context; + mDreamManager = IDreamManager.Stub.asInterface(ServiceManager.getService("dreams")); + mComparator = new DreamInfoComparator(getDefaultDream()); + } + + public List<DreamInfo> getDreamInfos() { + ComponentName activeDream = getActiveDream(); + PackageManager pm = mContext.getPackageManager(); + Intent dreamIntent = new Intent(Intent.ACTION_MAIN) + .addCategory("android.intent.category.DREAM"); + List<ResolveInfo> resolveInfos = pm.queryIntentServices(dreamIntent, + PackageManager.GET_META_DATA); + List<DreamInfo> dreamInfos = new ArrayList<DreamInfo>(resolveInfos.size()); + for (ResolveInfo resolveInfo : resolveInfos) { + if (resolveInfo.serviceInfo == null) + continue; + DreamInfo dreamInfo = new DreamInfo(); + dreamInfo.caption = resolveInfo.loadLabel(pm); + dreamInfo.icon = resolveInfo.loadIcon(pm); + dreamInfo.componentName = getDreamComponentName(resolveInfo); + dreamInfo.isActive = dreamInfo.componentName.equals(activeDream); + dreamInfo.settingsComponentName = getSettingsComponentName(resolveInfo); + dreamInfos.add(dreamInfo); + } + Collections.sort(dreamInfos, mComparator); + return dreamInfos; + } + + public ComponentName getDefaultDream() { + if (mDreamManager == null) + return null; + try { + return mDreamManager.getDefaultDreamComponent(); + } catch (RemoteException e) { + return null; + } + } + + public boolean isEnabled() { + return getBoolean(SCREENSAVER_ENABLED); + } + + public void setEnabled(boolean value) { + setBoolean(SCREENSAVER_ENABLED, value); + } + + public boolean isActivatedOnDock() { + return getBoolean(SCREENSAVER_ACTIVATE_ON_DOCK); + } + + public void setActivatedOnDock(boolean value) { + setBoolean(SCREENSAVER_ACTIVATE_ON_DOCK, value); + } + + public boolean isActivatedOnSleep() { + return getBoolean(SCREENSAVER_ACTIVATE_ON_SLEEP); + } + + public void setActivatedOnSleep(boolean value) { + setBoolean(SCREENSAVER_ACTIVATE_ON_SLEEP, value); + } + + private boolean getBoolean(String key) { + return Settings.Secure.getInt(mContext.getContentResolver(), key, 1) == 1; + } + + private void setBoolean(String key, boolean value) { + Settings.Secure.putInt(mContext.getContentResolver(), key, value ? 1 : 0); + } + + public void startDreamingNow() { + if (mDreamManager == null) + return; + try { + mDreamManager.dream(); + } catch (RemoteException e) { + } + } + + public void setActiveDream(ComponentName dream) { + if (mDreamManager == null) + return; + try { + ComponentName[] dreams = { dream }; + mDreamManager.setDreamComponents(dream == null ? null : dreams); + } catch (RemoteException e) { + // noop + } + } + + public ComponentName getActiveDream() { + if (mDreamManager == null) + return null; + try { + ComponentName[] dreams = mDreamManager.getDreamComponents(); + return dreams != null && dreams.length > 0 ? dreams[0] : null; + } catch (RemoteException e) { + return null; + } + } + + public void launchSettings(DreamInfo dreamInfo) { + if (dreamInfo == null || dreamInfo.settingsComponentName == null) + return; + mContext.startActivity(new Intent().setComponent(dreamInfo.settingsComponentName)); + } + + public void preview(DreamInfo dreamInfo) { + if (mDreamManager == null || dreamInfo == null || dreamInfo.componentName == null) + return; + try { + mDreamManager.testDream(dreamInfo.componentName); + } catch (RemoteException e) { + // noop + } + } + + private static ComponentName getDreamComponentName(ResolveInfo ri) { + if (ri == null || ri.serviceInfo == null) + return null; + return new ComponentName(ri.serviceInfo.packageName, ri.serviceInfo.name); + } + + private static ComponentName getSettingsComponentName(ResolveInfo ri) { + if (ri == null || ri.serviceInfo == null || ri.serviceInfo.metaData == null) + return null; + String cn = ri.serviceInfo.metaData.getString(Dream.METADATA_NAME_CONFIG_ACTIVITY); + return cn == null ? null : ComponentName.unflattenFromString(cn); + } + + private static class DreamInfoComparator implements Comparator<DreamInfo> { + private final ComponentName mDefaultDream; + + public DreamInfoComparator(ComponentName defaultDream) { + mDefaultDream = defaultDream; + } + + @Override + public int compare(DreamInfo lhs, DreamInfo rhs) { + return sortKey(lhs).compareTo(sortKey(rhs)); + } + + private String sortKey(DreamInfo di) { + StringBuilder sb = new StringBuilder(); + sb.append(di.componentName.equals(mDefaultDream) ? '0' : '1'); + sb.append(di.caption); + return sb.toString(); + } + } +} diff --git a/src/com/android/settings/DreamComponentPreference.java b/src/com/android/settings/DreamComponentPreference.java deleted file mode 100644 index ddde35d..0000000 --- a/src/com/android/settings/DreamComponentPreference.java +++ /dev/null @@ -1,241 +0,0 @@ -/* - * Copyright (C) 2011 The Android Open Source Project - * - * 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 com.android.settings; - -import static android.provider.Settings.Secure.SCREENSAVER_COMPONENTS; - -import android.app.AlertDialog; -import android.content.Context; -import android.content.ComponentName; -import android.content.ContentResolver; -import android.content.DialogInterface; -import android.content.Intent; -import android.content.pm.ActivityInfo; -import android.content.pm.ApplicationInfo; -import android.content.pm.ComponentInfo; -import android.content.pm.PackageManager; -import android.content.pm.ResolveInfo; -import android.content.res.Resources; -import android.os.Bundle; -import android.os.RemoteException; -import android.os.ServiceManager; -import android.preference.Preference; -import android.provider.Settings; -import android.service.dreams.IDreamManager; -import android.util.AttributeSet; -import android.util.Log; -import android.view.Gravity; -import android.view.LayoutInflater; -import android.view.View; -import android.view.ViewGroup; -import android.widget.ArrayAdapter; -import android.widget.ListView; -import android.widget.BaseAdapter; -import android.widget.ImageView; -import android.widget.ListAdapter; -import android.widget.TextView; - -import java.text.Collator; -import java.util.ArrayList; -import java.util.Collections; -import java.util.Comparator; -import java.util.List; - -public class DreamComponentPreference extends Preference { - private static final String TAG = "DreamComponentPreference"; - - private static final boolean SHOW_DOCK_APPS = false; - private static final boolean SHOW_DREAM_SERVICES = true; - private static final boolean SHOW_DREAM_ACTIVITIES = false; - - private final PackageManager pm; - private final ContentResolver resolver; - private final Collator sCollator = Collator.getInstance(); - - public DreamComponentPreference(Context context, AttributeSet attrs) { - super(context, attrs); - pm = getContext().getPackageManager(); - resolver = getContext().getContentResolver(); - - refreshFromSettings(); - } - - private void refreshFromSettings() { - ComponentName cn = null; - IDreamManager dm = IDreamManager.Stub.asInterface( - ServiceManager.getService("dreams")); - try { - ComponentName[] dreams = dm.getDreamComponents(); - if (dreams != null && dreams.length > 0) - cn = dreams[0]; - } catch (RemoteException ex) { } - - if (cn == null) { - setSummary("(unknown)"); - return; - } - - try { - setSummary(pm.getActivityInfo(cn, 0).loadLabel(pm)); - } catch (PackageManager.NameNotFoundException ex) { - try { - setSummary(pm.getServiceInfo(cn, 0).loadLabel(pm)); - } catch (PackageManager.NameNotFoundException ex2) { - setSummary("(unknown)"); - } - } - } - - // Group by package, then by name. - Comparator<ResolveInfo> sResolveInfoComparator = new Comparator<ResolveInfo>() { - @Override - public int compare(ResolveInfo a, ResolveInfo b) { - CharSequence sa, sb; - - ApplicationInfo aia = a.activityInfo != null ? a.activityInfo.applicationInfo : a.serviceInfo.applicationInfo; - ApplicationInfo aib = b.activityInfo != null ? b.activityInfo.applicationInfo : b.serviceInfo.applicationInfo; - - if (!aia.equals(aib)) { - sa = pm.getApplicationLabel(aia); - sb = pm.getApplicationLabel(aib); - } else { - sa = a.loadLabel(pm); - if (sa == null) { - sa = (a.activityInfo != null) ? a.activityInfo.name : a.serviceInfo.name; - } - sb = b.loadLabel(pm); - if (sb == null) { - sb = (b.activityInfo != null) ? b.activityInfo.name : b.serviceInfo.name; - } - } - return sCollator.compare(sa.toString(), sb.toString()); - } - }; - - public class DreamListAdapter extends BaseAdapter implements ListAdapter { - private ArrayList<ResolveInfo> results; - private final LayoutInflater inflater; - - public DreamListAdapter(Context context) { - Intent choosy = new Intent(Intent.ACTION_MAIN) - .addCategory("android.intent.category.DREAM"); - - inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE); - - results = new ArrayList<ResolveInfo>(); - - if (SHOW_DREAM_ACTIVITIES) { - results.addAll(pm.queryIntentActivities(choosy, PackageManager.GET_META_DATA)); - } - - if (SHOW_DREAM_SERVICES) { - results.addAll(pm.queryIntentServices(choosy, PackageManager.GET_META_DATA)); - } - - // Group by package - Collections.sort(results, sResolveInfoComparator); - - if (SHOW_DOCK_APPS) { - choosy = new Intent(Intent.ACTION_MAIN) - .addCategory(Intent.CATEGORY_DESK_DOCK); - - List<ResolveInfo> dockApps = pm.queryIntentActivities(choosy, 0); - for (ResolveInfo app : dockApps) { - // do not insert duplicate packages - int pos = Collections.binarySearch(results, app, sResolveInfoComparator); - if (pos < 0) { - results.add(-1-pos, app); - } - } - } - } - - @Override - public int getCount() { - return results.size(); - } - - @Override - public Object getItem(int position) { - return results.get(position); - } - - @Override - public long getItemId (int position) { - return (long) position; - } - - private CharSequence loadDescription(ResolveInfo ri) { - CharSequence desc = null; - if (ri != null) { - Bundle metaData = (ri.activityInfo != null) ? ri.activityInfo.metaData : ri.serviceInfo.metaData; - Log.d(TAG, "loadDescription: ri=" + ri + " metaData=" + metaData); - if (metaData != null) { - desc = metaData.getCharSequence("android.screensaver.description"); - Log.d(TAG, "loadDescription: desc=" + desc); - if (desc != null) { - desc = desc.toString().trim(); - } - } - } - return desc; - } - - @Override - public View getView(int position, View convertView, ViewGroup parent) { - View row = (convertView != null) - ? convertView - : inflater.inflate(R.layout.dream_picker_row, parent, false); - ResolveInfo ri = results.get(position); - ((TextView)row.findViewById(R.id.title)).setText(ri.loadLabel(pm)); - ((ImageView)row.findViewById(R.id.icon)).setImageDrawable(ri.loadIcon(pm)); - return row; - } - } - - @Override - protected void onClick() { - final DreamListAdapter list = new DreamListAdapter(getContext()); - AlertDialog alert = new AlertDialog.Builder(getContext()) - .setAdapter( - list, - new DialogInterface.OnClickListener() { - @Override - public void onClick(DialogInterface dialog, int which) { - ResolveInfo ri = (ResolveInfo)list.getItem(which); - String pn = (ri.activityInfo != null) ? ri.activityInfo.applicationInfo.packageName - : ri.serviceInfo.applicationInfo.packageName; - String n = (ri.activityInfo != null) ? ri.activityInfo.name : ri.serviceInfo.name; - ComponentName cn = new ComponentName(pn, n); - - setSummary(ri.loadLabel(pm)); - //getContext().startActivity(intent); - - IDreamManager dm = IDreamManager.Stub.asInterface( - ServiceManager.getService("dreams")); - try { - ComponentName[] dreams = { cn }; - dm.setDreamComponents(dreams); - } catch (RemoteException ex) { - // too bad, so sad, oh mom, oh dad - } - } - }) - .create(); - alert.show(); - } -} diff --git a/src/com/android/settings/DreamSettings.java b/src/com/android/settings/DreamSettings.java index 071e369..d2d470f 100644 --- a/src/com/android/settings/DreamSettings.java +++ b/src/com/android/settings/DreamSettings.java @@ -1,5 +1,5 @@ /* - * Copyright (C) 2010 The Android Open Source Project + * Copyright (C) 2012 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -16,136 +16,295 @@ package com.android.settings; -import static android.provider.Settings.Secure.SCREENSAVER_ENABLED; -import static android.provider.Settings.Secure.SCREENSAVER_ACTIVATE_ON_DOCK; -import static android.provider.Settings.Secure.SCREENSAVER_ACTIVATE_ON_SLEEP; - import android.app.ActionBar; import android.app.Activity; -import android.app.ActivityManagerNative; -import android.app.admin.DevicePolicyManager; -import android.content.ContentResolver; +import android.app.AlertDialog; +import android.app.Dialog; import android.content.Context; -import android.content.res.Configuration; -import android.database.ContentObserver; +import android.content.DialogInterface; +import android.graphics.Color; import android.os.Bundle; -import android.os.Handler; -import android.os.RemoteException; -import android.os.ServiceManager; -import android.preference.CheckBoxPreference; -import android.preference.ListPreference; -import android.preference.Preference; import android.preference.PreferenceActivity; -import android.preference.PreferenceScreen; -import android.provider.Settings; -import android.util.Log; import android.view.Gravity; -import android.view.IWindowManager; +import android.view.LayoutInflater; +import android.view.Menu; +import android.view.MenuInflater; +import android.view.MenuItem; +import android.view.MenuItem.OnMenuItemClickListener; +import android.view.MotionEvent; +import android.view.View; +import android.view.View.OnClickListener; +import android.view.View.OnTouchListener; +import android.view.ViewGroup; +import android.widget.ArrayAdapter; +import android.widget.Button; import android.widget.CompoundButton; +import android.widget.CompoundButton.OnCheckedChangeListener; +import android.widget.ImageView; +import android.widget.ListView; +import android.widget.RadioButton; import android.widget.Switch; +import android.widget.TextView; + +import com.android.settings.DreamBackend.DreamInfo; -import java.util.ArrayList; +import java.util.List; public class DreamSettings extends SettingsPreferenceFragment { - private static final String TAG = "DreamSettings"; + private static final int DIALOG_WHEN_TO_DREAM = 1; + private static final int DIVIDER_HEIGHT = 15; - private static final String KEY_ACTIVATE_ON_SLEEP = "activate_on_sleep"; - private static final String KEY_ACTIVATE_ON_DOCK = "activate_on_dock"; - private static final String KEY_COMPONENT = "screensaver_component"; - private static final String KEY_TEST = "test"; + private Context mContext; + private DreamBackend mBackend; + private DreamInfoAdapter mAdapter; + private Switch mSwitch; + private MenuItem[] mDependentMenuItems; + private boolean mRefreshing; - private static final int DEFAULT_SLEEP = 1; - private static final int DEFAULT_DOCK = 1; + @Override + public void onAttach(Activity activity) { + super.onAttach(activity); + mContext = activity; + } - private ActivationSetting mActivateOnSleep; - private ActivationSetting mActivateOnDock; + @Override + public void onCreate(Bundle icicle) { + super.onCreate(icicle); + Activity activity = getActivity(); - private Preference mComponentPref; - private Preference mTestPref; + mBackend = new DreamBackend(activity); + mSwitch = new Switch(activity); + mSwitch.setOnCheckedChangeListener(new OnCheckedChangeListener() { + @Override + public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) { + if (!mRefreshing) { + mBackend.setEnabled(isChecked); + refreshFromBackend(); + } + } + }); + if (activity instanceof PreferenceActivity) { + PreferenceActivity preferenceActivity = (PreferenceActivity) activity; + if (preferenceActivity.onIsHidingHeaders() || !preferenceActivity.onIsMultiPane()) { + final int padding = activity.getResources().getDimensionPixelSize( + R.dimen.action_bar_switch_padding); + mSwitch.setPadding(0, 0, padding, 0); + activity.getActionBar().setDisplayOptions(ActionBar.DISPLAY_SHOW_CUSTOM, + ActionBar.DISPLAY_SHOW_CUSTOM); + activity.getActionBar().setCustomView(mSwitch, new ActionBar.LayoutParams( + ActionBar.LayoutParams.WRAP_CONTENT, + ActionBar.LayoutParams.WRAP_CONTENT, + Gravity.CENTER_VERTICAL | Gravity.END)); + } + } + setHasOptionsMenu(true); + } @Override public void onActivityCreated(Bundle savedInstanceState) { super.onActivityCreated(savedInstanceState); - addPreferencesFromResource(R.xml.dream_settings); + ListView listView = getListView(); - mComponentPref = findPreference(KEY_COMPONENT); - mTestPref = findPreference(KEY_TEST); + TextView emptyView = (TextView) getView().findViewById(android.R.id.empty); + emptyView.setText(R.string.screensaver_settings_disabled_prompt); + listView.setEmptyView(emptyView); - mActivateOnSleep = new ActivationSetting(getActivity(), - SCREENSAVER_ACTIVATE_ON_SLEEP, DEFAULT_SLEEP, - (CheckBoxPreference) findPreference(KEY_ACTIVATE_ON_SLEEP)); - mActivateOnDock = new ActivationSetting(getActivity(), - SCREENSAVER_ACTIVATE_ON_DOCK, DEFAULT_DOCK, - (CheckBoxPreference) findPreference(KEY_ACTIVATE_ON_DOCK)); + mAdapter = new DreamInfoAdapter(mContext); + listView.setAdapter(mAdapter); + listView.setDivider(null); + listView.setDividerHeight(DIVIDER_HEIGHT); + listView.setBackgroundColor(Color.BLACK); + listView.setPadding(0, DIVIDER_HEIGHT, 0, DIVIDER_HEIGHT); + listView.setHeaderDividersEnabled(true); } - public static boolean isScreenSaverActivatedOnSleep(Context context) { - return 0 != Settings.Secure.getInt( - context.getContentResolver(), SCREENSAVER_ACTIVATE_ON_SLEEP, DEFAULT_SLEEP); + @Override + public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) { + boolean isEnabled = mBackend.isEnabled(); + + MenuItem whenToDream = createMenuItem(menu, + R.string.screensaver_settings_when_to_dream, + MenuItem.SHOW_AS_ACTION_NEVER, + isEnabled, + new Runnable() { + @Override + public void run() { + showDialog(DIALOG_WHEN_TO_DREAM); + }}); + + createMenuItem(menu, + R.string.help_label, + MenuItem.SHOW_AS_ACTION_NEVER, + true, + new Runnable() { + @Override + public void run() { + // TODO show help url + }}); + + MenuItem startDreaming = createMenuItem(menu, + R.string.screensaver_settings_start_dreaming, + MenuItem.SHOW_AS_ACTION_ALWAYS, + isEnabled, + new Runnable(){ + @Override + public void run() { + mBackend.startDreamingNow(); + }}); + + mDependentMenuItems = new MenuItem[] { whenToDream, startDreaming }; } - public static boolean isScreenSaverActivatedOnDock(Context context) { - return 0 != Settings.Secure.getInt( - context.getContentResolver(), SCREENSAVER_ACTIVATE_ON_DOCK, DEFAULT_DOCK); + private MenuItem createMenuItem(Menu menu, + int titleRes, int actionEnum, boolean isEnabled, final Runnable onClick) { + MenuItem item = menu.add(titleRes); + item.setShowAsAction(actionEnum); + item.setEnabled(isEnabled); + item.setOnMenuItemClickListener(new OnMenuItemClickListener() { + @Override + public boolean onMenuItemClick(MenuItem item) { + onClick.run(); + return true; + } + }); + return item; + } + + @Override + public Dialog onCreateDialog(int dialogId) { + if (dialogId == DIALOG_WHEN_TO_DREAM) + return createWhenToDreamDialog(); + return super.onCreateDialog(dialogId); + } + + private Dialog createWhenToDreamDialog() { + final CharSequence[] items = { + mContext.getString(R.string.screensaver_settings_summary_dock), + mContext.getString(R.string.screensaver_settings_summary_sleep), + mContext.getString(R.string.screensaver_settings_summary_either_short) + }; + + int initialSelection = mBackend.isActivatedOnDock() && mBackend.isActivatedOnSleep() ? 2 + : mBackend.isActivatedOnDock() ? 0 + : mBackend.isActivatedOnSleep() ? 1 + : -1; + + return new AlertDialog.Builder(mContext) + .setTitle(R.string.screensaver_settings_when_to_dream) + .setSingleChoiceItems(items, initialSelection, new DialogInterface.OnClickListener() { + public void onClick(DialogInterface dialog, int item) { + mBackend.setActivatedOnDock(item == 0 || item == 2); + mBackend.setActivatedOnSleep(item == 1 || item == 2); + } + }) + .create(); } @Override public void onResume() { - mActivateOnSleep.onResume(); - mActivateOnDock.onResume(); - refreshDependents(); super.onResume(); + refreshFromBackend(); } - @Override - public boolean onPreferenceTreeClick(PreferenceScreen preferenceScreen, Preference preference) { - mActivateOnSleep.onClick(preference); - mActivateOnDock.onClick(preference); - - // FIXME: infer enabled (until the next rev of the dream settings ui) - boolean enabled = mActivateOnSleep.isSelected() || mActivateOnDock.isSelected(); - Settings.Secure.putInt(getActivity().getContentResolver(), - SCREENSAVER_ENABLED, - enabled ? 1 : 0); - - refreshDependents(); - return super.onPreferenceTreeClick(preferenceScreen, preference); + public static int getSummaryResource(Context context) { + DreamBackend backend = new DreamBackend(context); + boolean isEnabled = backend.isEnabled(); + boolean activatedOnSleep = backend.isActivatedOnSleep(); + boolean activatedOnDock = backend.isActivatedOnDock(); + boolean activatedOnEither = activatedOnSleep && activatedOnDock; + return !isEnabled ? R.string.screensaver_settings_summary_off + : activatedOnEither ? R.string.screensaver_settings_summary_either_long + : activatedOnSleep ? R.string.screensaver_settings_summary_sleep + : activatedOnDock ? R.string.screensaver_settings_summary_dock + : 0; } - private void refreshDependents() { - boolean enabled = mActivateOnSleep.isSelected() || mActivateOnDock.isSelected(); - mComponentPref.setEnabled(enabled); - mTestPref.setEnabled(enabled); + private void refreshFromBackend() { + mRefreshing = true; + boolean dreamsEnabled = mBackend.isEnabled(); + if (mSwitch.isChecked() != dreamsEnabled) + mSwitch.setChecked(dreamsEnabled); + + mAdapter.clear(); + if (dreamsEnabled) { + List<DreamInfo> dreamInfos = mBackend.getDreamInfos(); + mAdapter.addAll(dreamInfos); + } + if (mDependentMenuItems != null) + for (MenuItem item : mDependentMenuItems) + item.setEnabled(dreamsEnabled); + mRefreshing = false; } - private static class ActivationSetting { - private final Context mContext; - private final String mName; - private final int mDefaultValue; - private final CheckBoxPreference mPref; - - ActivationSetting(Context context, String name, int defaultValue, CheckBoxPreference pref) { - mContext = context; - mName = name; - mDefaultValue = defaultValue; - mPref = pref; + private class DreamInfoAdapter extends ArrayAdapter<DreamInfo> { + private final LayoutInflater mInflater; + + public DreamInfoAdapter(Context context) { + super(context, 0); + mInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE); } - public boolean isSelected() { - return mPref.isChecked(); + + @Override + public View getView(int position, View convertView, ViewGroup parent) { + DreamInfo dreamInfo = getItem(position); + final View row = convertView != null ? convertView : createDreamInfoRow(parent); + row.setTag(dreamInfo); + + // bind icon + ((ImageView) row.findViewById(android.R.id.icon)).setImageDrawable(dreamInfo.icon); + + // bind caption + ((TextView) row.findViewById(android.R.id.text1)).setText(dreamInfo.caption); + + // bind radio button + ((RadioButton) row.findViewById(android.R.id.button1)).setChecked(dreamInfo.isActive); + ((RadioButton) row.findViewById(android.R.id.button1)).setOnTouchListener(new OnTouchListener() { + @Override + public boolean onTouch(View v, MotionEvent event) { + row.onTouchEvent(event); + return false; + }}); + + // bind button container + row.findViewById(android.R.id.widget_frame).setVisibility(dreamInfo.isActive ? View.VISIBLE : View.GONE); + + // bind settings button + ((Button) row.findViewById(android.R.id.button2)).setEnabled(dreamInfo.settingsComponentName != null); + ((Button) row.findViewById(android.R.id.button2)).setOnClickListener(new OnClickListener(){ + @Override + public void onClick(View v) { + mBackend.launchSettings((DreamInfo)row.getTag()); + }}); + + // bind preview button + ((Button) row.findViewById(android.R.id.button3)).setOnClickListener(new OnClickListener(){ + @Override + public void onClick(View v) { + mBackend.preview((DreamInfo)row.getTag()); + }}); + + return row; } - void onClick(Preference preference) { - if (preference == mPref) { - Settings.Secure.putInt(mContext.getContentResolver(), - mName, - mPref.isChecked() ? 1 : 0); - } + + private View createDreamInfoRow(ViewGroup parent) { + final View row = mInflater.inflate(R.layout.dream_info_row, parent, false); + row.setOnClickListener(new OnClickListener(){ + @Override + public void onClick(View v) { + v.setPressed(true); + activate((DreamInfo) row.getTag()); + }}); + return row; } - void onResume() { - boolean currentActivated = 0 != Settings.Secure.getInt(mContext.getContentResolver(), - mName, mDefaultValue); - mPref.setChecked(currentActivated); + + private void activate(DreamInfo dreamInfo) { + for (int i = 0; i < getCount(); i++) { + getItem(i).isActive = false; + } + dreamInfo.isActive = true; + mBackend.setActiveDream(dreamInfo.componentName); + notifyDataSetChanged(); } } - } diff --git a/src/com/android/settings/DreamTesterPreference.java b/src/com/android/settings/DreamTesterPreference.java deleted file mode 100644 index 1a22d64..0000000 --- a/src/com/android/settings/DreamTesterPreference.java +++ /dev/null @@ -1,51 +0,0 @@ -/* - * Copyright (C) 2011 The Android Open Source Project - * - * 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 com.android.settings; - -import android.content.ComponentName; -import android.content.Context; -import android.os.RemoteException; -import android.os.ServiceManager; -import android.preference.Preference; -import android.service.dreams.IDreamManager; -import android.util.AttributeSet; -import android.util.Log; - -public class DreamTesterPreference extends Preference { - private static final String TAG = "DreamTesterPreference"; - - public DreamTesterPreference(Context context, AttributeSet attrs) { - super(context, attrs); - } - - @Override - protected void onClick() { - IDreamManager dm = IDreamManager.Stub.asInterface(ServiceManager.getService("dreams")); - try { - ComponentName[] dreams = dm.getDreamComponents(); - if (dreams == null || dreams.length == 0) - return; - ComponentName cn = dreams[0]; - Log.v(TAG, "DreamComponent cn=" + cn); - dm.testDream(cn); - } catch (RemoteException ex) { - Log.w(TAG, "error testing dream", ex); - // too bad, so sad, oh mom, oh dad - } - } - -} |