Merge "Rewrite dream settings."
This commit is contained in:
@@ -1,125 +0,0 @@
|
||||
/*
|
||||
* Copyright (C) 2017 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.dream;
|
||||
|
||||
import android.app.settings.SettingsEnums;
|
||||
import android.content.ComponentName;
|
||||
import android.content.Context;
|
||||
import android.graphics.drawable.Drawable;
|
||||
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.widget.RadioButtonPickerFragment;
|
||||
import com.android.settingslib.dream.DreamBackend;
|
||||
import com.android.settingslib.dream.DreamBackend.DreamInfo;
|
||||
import com.android.settingslib.widget.CandidateInfo;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
public final class CurrentDreamPicker extends RadioButtonPickerFragment {
|
||||
|
||||
private DreamBackend mBackend;
|
||||
|
||||
@Override
|
||||
public void onAttach(Context context) {
|
||||
super.onAttach(context);
|
||||
|
||||
mBackend = DreamBackend.getInstance(context);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected int getPreferenceScreenResId() {
|
||||
return R.xml.current_dream_settings;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getMetricsCategory() {
|
||||
return SettingsEnums.DREAM;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected boolean setDefaultKey(String key) {
|
||||
Map<String, ComponentName> componentNameMap = getDreamComponentsMap();
|
||||
if (componentNameMap.get(key) != null) {
|
||||
mBackend.setActiveDream(componentNameMap.get(key));
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected String getDefaultKey() {
|
||||
return mBackend.getActiveDream().flattenToString();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected List<? extends CandidateInfo> getCandidates() {
|
||||
final List<DreamCandidateInfo> candidates;
|
||||
candidates = mBackend.getDreamInfos().stream()
|
||||
.map(DreamCandidateInfo::new)
|
||||
.collect(Collectors.toList());
|
||||
|
||||
return candidates;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onSelectionPerformed(boolean success) {
|
||||
super.onSelectionPerformed(success);
|
||||
|
||||
getActivity().finish();
|
||||
}
|
||||
|
||||
private Map<String, ComponentName> getDreamComponentsMap() {
|
||||
Map<String, ComponentName> comps = new HashMap<>();
|
||||
mBackend.getDreamInfos()
|
||||
.forEach((info) ->
|
||||
comps.put(info.componentName.flattenToString(), info.componentName));
|
||||
|
||||
return comps;
|
||||
}
|
||||
|
||||
private static final class DreamCandidateInfo extends CandidateInfo {
|
||||
private final CharSequence name;
|
||||
private final Drawable icon;
|
||||
private final String key;
|
||||
|
||||
DreamCandidateInfo(DreamInfo info) {
|
||||
super(true);
|
||||
|
||||
name = info.caption;
|
||||
icon = info.icon;
|
||||
key = info.componentName.flattenToString();
|
||||
}
|
||||
|
||||
@Override
|
||||
public CharSequence loadLabel() {
|
||||
return name;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Drawable loadIcon() {
|
||||
return icon;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getKey() {
|
||||
return key;
|
||||
}
|
||||
}
|
||||
}
|
@@ -1,93 +0,0 @@
|
||||
/*
|
||||
* Copyright (C) 2017 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.dream;
|
||||
|
||||
import android.content.Context;
|
||||
|
||||
import androidx.preference.Preference;
|
||||
|
||||
import com.android.settings.Utils;
|
||||
import com.android.settings.core.BasePreferenceController;
|
||||
import com.android.settings.widget.GearPreference;
|
||||
import com.android.settingslib.RestrictedPreference;
|
||||
import com.android.settingslib.dream.DreamBackend;
|
||||
import com.android.settingslib.dream.DreamBackend.DreamInfo;
|
||||
|
||||
import java.util.Optional;
|
||||
|
||||
public class CurrentDreamPreferenceController extends BasePreferenceController {
|
||||
|
||||
private final DreamBackend mBackend;
|
||||
|
||||
public CurrentDreamPreferenceController(Context context, String key) {
|
||||
super(context, key);
|
||||
mBackend = DreamBackend.getInstance(context);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getAvailabilityStatus() {
|
||||
return mBackend.getDreamInfos().size() > 0 ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateState(Preference preference) {
|
||||
super.updateState(preference);
|
||||
setGearClickListenerForPreference(preference);
|
||||
setActiveDreamIcon(preference);
|
||||
}
|
||||
|
||||
@Override
|
||||
public CharSequence getSummary() {
|
||||
return mBackend.getActiveDreamName();
|
||||
}
|
||||
|
||||
private void setGearClickListenerForPreference(Preference preference) {
|
||||
if (!(preference instanceof GearPreference)) {
|
||||
return;
|
||||
}
|
||||
|
||||
final GearPreference gearPreference = (GearPreference) preference;
|
||||
final Optional<DreamInfo> info = getActiveDreamInfo();
|
||||
if (!info.isPresent() || info.get().settingsComponentName == null) {
|
||||
gearPreference.setOnGearClickListener(null);
|
||||
return;
|
||||
}
|
||||
gearPreference.setOnGearClickListener(gearPref -> launchScreenSaverSettings());
|
||||
}
|
||||
|
||||
private void launchScreenSaverSettings() {
|
||||
final Optional<DreamInfo> info = getActiveDreamInfo();
|
||||
if (!info.isPresent()) return;
|
||||
mBackend.launchSettings(mContext, info.get());
|
||||
}
|
||||
|
||||
private Optional<DreamInfo> getActiveDreamInfo() {
|
||||
return mBackend.getDreamInfos()
|
||||
.stream()
|
||||
.filter((info) -> info.isActive)
|
||||
.findFirst();
|
||||
}
|
||||
|
||||
private void setActiveDreamIcon(Preference preference) {
|
||||
if (!(preference instanceof GearPreference)) {
|
||||
return;
|
||||
}
|
||||
final GearPreference gearPref = (GearPreference) preference;
|
||||
gearPref.setIconSize(RestrictedPreference.ICON_SIZE_SMALL);
|
||||
gearPref.setIcon(Utils.getSafeIcon(mBackend.getActiveIcon()));
|
||||
}
|
||||
}
|
129
src/com/android/settings/dream/DreamPickerAdapter.java
Normal file
129
src/com/android/settings/dream/DreamPickerAdapter.java
Normal file
@@ -0,0 +1,129 @@
|
||||
/*
|
||||
* Copyright (C) 2022 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.dream;
|
||||
|
||||
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
import android.widget.Button;
|
||||
import android.widget.ImageView;
|
||||
import android.widget.TextView;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.recyclerview.widget.RecyclerView;
|
||||
|
||||
import com.android.settings.R;
|
||||
import com.android.settingslib.dream.DreamBackend.DreamInfo;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* RecyclerView adapter which displays list of available dreams for the user to select.
|
||||
*/
|
||||
class DreamPickerAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> {
|
||||
private final List<DreamInfo> mDreamInfoList;
|
||||
private final OnItemClickListener mItemClickListener;
|
||||
private final OnItemClickListener mOnDreamSelected = new OnItemClickListener() {
|
||||
@Override
|
||||
public void onItemClicked(DreamInfo dreamInfo) {
|
||||
if (mItemClickListener != null) {
|
||||
mItemClickListener.onItemClicked(dreamInfo);
|
||||
}
|
||||
mDreamInfoList.forEach(dream -> {
|
||||
if (dream != null) {
|
||||
dream.isActive = false;
|
||||
}
|
||||
});
|
||||
dreamInfo.isActive = true;
|
||||
notifyDataSetChanged();
|
||||
}
|
||||
};
|
||||
private final OnItemClickListener mOnCustomizeListener;
|
||||
|
||||
interface OnItemClickListener {
|
||||
void onItemClicked(DreamInfo dreamInfo);
|
||||
}
|
||||
|
||||
/**
|
||||
* View holder for each Dream service.
|
||||
*/
|
||||
private static class DreamViewHolder extends RecyclerView.ViewHolder {
|
||||
private final ImageView mIconView;
|
||||
private final TextView mTitleView;
|
||||
private final TextView mSummaryView;
|
||||
private final ImageView mPreviewView;
|
||||
private final Button mCustomizeButton;
|
||||
|
||||
DreamViewHolder(View view) {
|
||||
super(view);
|
||||
mPreviewView = view.findViewById(R.id.preview);
|
||||
mIconView = view.findViewById(R.id.icon);
|
||||
mTitleView = view.findViewById(R.id.title_text);
|
||||
mSummaryView = view.findViewById(R.id.summary_text);
|
||||
mCustomizeButton = view.findViewById(R.id.customize_button);
|
||||
}
|
||||
|
||||
/**
|
||||
* Bind the dream service view at the given position. Add details on the
|
||||
* dream's icon, name and description.
|
||||
*/
|
||||
public void bindView(DreamInfo dreamInfo, OnItemClickListener clickListener,
|
||||
OnItemClickListener customizeListener) {
|
||||
mIconView.setImageDrawable(dreamInfo.icon);
|
||||
mTitleView.setText(dreamInfo.caption);
|
||||
mPreviewView.setImageDrawable(dreamInfo.previewImage);
|
||||
mSummaryView.setText(dreamInfo.description);
|
||||
itemView.setActivated(dreamInfo.isActive);
|
||||
if (dreamInfo.isActive && dreamInfo.settingsComponentName != null) {
|
||||
mCustomizeButton.setVisibility(View.VISIBLE);
|
||||
mCustomizeButton.setOnClickListener(
|
||||
v -> customizeListener.onItemClicked(dreamInfo));
|
||||
} else {
|
||||
mCustomizeButton.setVisibility(View.GONE);
|
||||
}
|
||||
|
||||
itemView.setOnClickListener(v -> clickListener.onItemClicked(dreamInfo));
|
||||
}
|
||||
}
|
||||
|
||||
DreamPickerAdapter(List<DreamInfo> dreamInfos, OnItemClickListener clickListener,
|
||||
OnItemClickListener onCustomizeListener) {
|
||||
mDreamInfoList = dreamInfos;
|
||||
mItemClickListener = clickListener;
|
||||
mOnCustomizeListener = onCustomizeListener;
|
||||
}
|
||||
|
||||
@NonNull
|
||||
@Override
|
||||
public RecyclerView.ViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int viewType) {
|
||||
View view = LayoutInflater.from(viewGroup.getContext())
|
||||
.inflate(R.layout.dream_preference_layout, viewGroup, false);
|
||||
return new DreamViewHolder(view);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onBindViewHolder(@NonNull RecyclerView.ViewHolder viewHolder, int i) {
|
||||
((DreamViewHolder) viewHolder).bindView(mDreamInfoList.get(i), mOnDreamSelected,
|
||||
mOnCustomizeListener);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getItemCount() {
|
||||
return mDreamInfoList.size();
|
||||
}
|
||||
}
|
138
src/com/android/settings/dream/DreamPickerController.java
Normal file
138
src/com/android/settings/dream/DreamPickerController.java
Normal file
@@ -0,0 +1,138 @@
|
||||
/*
|
||||
* Copyright (C) 2022 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.dream;
|
||||
|
||||
import android.content.Context;
|
||||
import android.widget.Button;
|
||||
|
||||
import androidx.annotation.Nullable;
|
||||
import androidx.preference.Preference;
|
||||
import androidx.recyclerview.widget.GridLayoutManager;
|
||||
import androidx.recyclerview.widget.RecyclerView;
|
||||
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.core.BasePreferenceController;
|
||||
import com.android.settings.dream.DreamPickerAdapter.OnItemClickListener;
|
||||
import com.android.settingslib.dream.DreamBackend;
|
||||
import com.android.settingslib.widget.LayoutPreference;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* Controller for the dream picker where the user can select a screensaver.
|
||||
*/
|
||||
public class DreamPickerController extends BasePreferenceController {
|
||||
public static final String KEY = "dream_picker";
|
||||
|
||||
private final DreamBackend mBackend;
|
||||
private final List<DreamBackend.DreamInfo> mDreamInfos;
|
||||
private Button mPreviewButton;
|
||||
@Nullable
|
||||
private DreamBackend.DreamInfo mActiveDream;
|
||||
|
||||
private final OnItemClickListener mItemClickListener =
|
||||
new OnItemClickListener() {
|
||||
@Override
|
||||
public void onItemClicked(DreamBackend.DreamInfo dreamInfo) {
|
||||
mActiveDream = dreamInfo;
|
||||
mBackend.setActiveDream(
|
||||
mActiveDream == null ? null : mActiveDream.componentName);
|
||||
updatePreviewButtonState();
|
||||
}
|
||||
};
|
||||
|
||||
private final OnItemClickListener mCustomizeListener = new OnItemClickListener() {
|
||||
@Override
|
||||
public void onItemClicked(DreamBackend.DreamInfo dreamInfo) {
|
||||
mBackend.launchSettings(mContext, dreamInfo);
|
||||
}
|
||||
};
|
||||
|
||||
public DreamPickerController(Context context, String preferenceKey) {
|
||||
this(context, preferenceKey, DreamBackend.getInstance(context));
|
||||
}
|
||||
|
||||
public DreamPickerController(Context context, String preferenceKey, DreamBackend backend) {
|
||||
super(context, preferenceKey);
|
||||
mBackend = backend;
|
||||
mDreamInfos = mBackend.getDreamInfos();
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getPreferenceKey() {
|
||||
return KEY;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getAvailabilityStatus() {
|
||||
return mDreamInfos.size() > 0 ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateState(Preference preference) {
|
||||
super.updateState(preference);
|
||||
|
||||
mActiveDream = getActiveDreamInfo();
|
||||
|
||||
final DreamPickerAdapter adapter =
|
||||
new DreamPickerAdapter(mDreamInfos, mItemClickListener, mCustomizeListener);
|
||||
|
||||
final RecyclerView recyclerView =
|
||||
((LayoutPreference) preference).findViewById(R.id.dream_list);
|
||||
recyclerView.setLayoutManager(new AutoFitGridLayoutManager(mContext));
|
||||
recyclerView.setAdapter(adapter);
|
||||
|
||||
mPreviewButton = ((LayoutPreference) preference).findViewById(R.id.preview_button);
|
||||
mPreviewButton.setOnClickListener(v -> mBackend.preview(mActiveDream));
|
||||
updatePreviewButtonState();
|
||||
}
|
||||
|
||||
private void updatePreviewButtonState() {
|
||||
final boolean hasDream = mActiveDream != null;
|
||||
mPreviewButton.setClickable(hasDream);
|
||||
mPreviewButton.setEnabled(hasDream);
|
||||
}
|
||||
|
||||
@Nullable
|
||||
private DreamBackend.DreamInfo getActiveDreamInfo() {
|
||||
return mDreamInfos
|
||||
.stream()
|
||||
.filter(d -> d.isActive)
|
||||
.findFirst()
|
||||
.orElse(null);
|
||||
}
|
||||
|
||||
/** Grid layout manager that calculates the number of columns for the screen size. */
|
||||
private static final class AutoFitGridLayoutManager extends GridLayoutManager {
|
||||
private final float mColumnWidth;
|
||||
|
||||
AutoFitGridLayoutManager(Context context) {
|
||||
super(context, /* spanCount= */ 1);
|
||||
this.mColumnWidth = context
|
||||
.getResources()
|
||||
.getDimensionPixelSize(R.dimen.dream_item_min_column_width);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onLayoutChildren(RecyclerView.Recycler recycler, RecyclerView.State state) {
|
||||
final int totalSpace = getWidth() - getPaddingRight() - getPaddingLeft();
|
||||
final int spanCount = Math.max(1, (int) (totalSpace / mColumnWidth));
|
||||
setSpanCount(spanCount);
|
||||
super.onLayoutChildren(recycler, state);
|
||||
}
|
||||
}
|
||||
}
|
@@ -1,72 +0,0 @@
|
||||
/*
|
||||
* Copyright (C) 2017 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.dream;
|
||||
|
||||
import android.content.Context;
|
||||
import android.widget.Button;
|
||||
|
||||
import androidx.preference.Preference;
|
||||
import androidx.preference.PreferenceScreen;
|
||||
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.core.BasePreferenceController;
|
||||
import com.android.settings.dashboard.DashboardFragment;
|
||||
import com.android.settings.overlay.FeatureFactory;
|
||||
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
||||
import com.android.settingslib.dream.DreamBackend;
|
||||
import com.android.settingslib.widget.LayoutPreference;
|
||||
|
||||
/**
|
||||
* Controller that used to enable screen saver
|
||||
*/
|
||||
public class StartNowPreferenceController extends BasePreferenceController {
|
||||
|
||||
private final DreamBackend mBackend;
|
||||
private final MetricsFeatureProvider mMetricsFeatureProvider;
|
||||
|
||||
public StartNowPreferenceController(Context context, String preferenceKey) {
|
||||
super(context, preferenceKey);
|
||||
mBackend = DreamBackend.getInstance(context);
|
||||
mMetricsFeatureProvider = FeatureFactory.getFactory(context).getMetricsFeatureProvider();
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getAvailabilityStatus() {
|
||||
return AVAILABLE;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void displayPreference(PreferenceScreen screen) {
|
||||
super.displayPreference(screen);
|
||||
|
||||
final LayoutPreference pref = screen.findPreference(getPreferenceKey());
|
||||
final Button startButton = pref.findViewById(R.id.dream_start_now_button);
|
||||
startButton.setOnClickListener(v -> {
|
||||
mMetricsFeatureProvider.logClickedPreference(pref,
|
||||
pref.getExtras().getInt(DashboardFragment.CATEGORY));
|
||||
mBackend.startDreaming();
|
||||
});
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateState(Preference preference) {
|
||||
super.updateState(preference);
|
||||
final Button startButton = ((LayoutPreference) preference)
|
||||
.findViewById(R.id.dream_start_now_button);
|
||||
startButton.setEnabled(mBackend.getWhenToDreamSetting() != DreamBackend.NEVER);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user