Remove ListView from preference_list_fragment.

As part of it, Use RecyclerView in PrintServiceSettingsFragment, which
still depends on the old preference_list_frag layout.

Also remove some unused pngs

Test: manual

Change-Id: I3189bd0dee5b6a74209eb1e707eb40427c96e312
This commit is contained in:
Fan Zhang
2018-07-17 09:11:59 -07:00
parent 2e246bb66c
commit fe93bd9c1e
49 changed files with 64 additions and 127 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 22 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 22 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 26 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 26 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 26 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 27 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 26 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 23 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 23 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 24 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 25 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 25 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 24 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 24 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 26 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 13 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 14 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 17 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 17 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 17 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 17 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 17 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 14 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 14 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 15 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 16 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 16 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 15 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 15 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 16 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 27 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 26 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 50 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 50 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 51 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 51 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 49 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 27 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 28 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 46 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 47 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 48 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 46 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 46 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 50 KiB

View File

@@ -1,37 +0,0 @@
<?xml version="1.0" encoding="utf-8"?>
<!--
/*
** Copyright 2008, 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.
*/
-->
<animation-list
xmlns:android="http://schemas.android.com/apk/res/android"
android:oneshot="false">
<item android:drawable="@drawable/lock_anim_0" android:duration="200" />
<item android:drawable="@drawable/lock_anim_1" android:duration="200" />
<item android:drawable="@drawable/lock_anim_2" android:duration="200" />
<item android:drawable="@drawable/lock_anim_3" android:duration="200" />
<item android:drawable="@drawable/lock_anim_4" android:duration="200" />
<item android:drawable="@drawable/lock_anim_5" android:duration="200" />
<item android:drawable="@drawable/lock_anim_6" android:duration="200" />
<item android:drawable="@drawable/lock_anim_7" android:duration="200" />
<item android:drawable="@drawable/lock_anim_8" android:duration="200" />
<item android:drawable="@drawable/lock_anim_9" android:duration="200" />
<item android:drawable="@drawable/lock_anim_10" android:duration="200" />
<item android:drawable="@drawable/lock_anim_11" android:duration="200" />
<item android:drawable="@drawable/lock_anim_12" android:duration="200" />
<item android:drawable="@drawable/lock_anim_13" android:duration="200" />
<item android:drawable="@drawable/lock_anim_14" android:duration="200" />
</animation-list>

View File

@@ -37,19 +37,6 @@
android:paddingStart="@dimen/settings_side_margin" android:paddingStart="@dimen/settings_side_margin"
android:paddingEnd="@dimen/settings_side_margin"> android:paddingEnd="@dimen/settings_side_margin">
<ListView android:id="@+id/backup_list"
style="@style/PreferenceFragmentListSinglePane"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingTop="@dimen/dashboard_padding_top"
android:paddingBottom="@dimen/dashboard_padding_bottom"
android:scrollbarStyle="@*android:integer/preference_fragment_scrollbarStyle"
android:clipToPadding="false"
android:drawSelectorOnTop="false"
android:elevation="@dimen/dashboard_category_elevation"
android:visibility="gone"
android:scrollbarAlwaysDrawVerticalTrack="true" />
<include layout="@layout/loading_container" /> <include layout="@layout/loading_container" />
</FrameLayout> </FrameLayout>
@@ -74,8 +61,7 @@
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_margin="5dip" android:layout_margin="5dip"
android:layout_alignParentStart="true" android:layout_alignParentStart="true"
android:text="@*android:string/back_button_label" android:text="@*android:string/back_button_label" />
/>
<LinearLayout <LinearLayout
android:orientation="horizontal" android:orientation="horizontal"
@@ -89,16 +75,14 @@
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_margin="5dip" android:layout_margin="5dip"
android:text="@*android:string/skip_button_label" android:text="@*android:string/skip_button_label"
android:visibility="gone" android:visibility="gone" />
/>
<Button android:id="@+id/next_button" <Button android:id="@+id/next_button"
style="?android:attr/buttonBarButtonStyle" style="?android:attr/buttonBarButtonStyle"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_margin="5dip" android:layout_margin="5dip"
android:text="@*android:string/next_button_label" android:text="@*android:string/next_button_label" />
/>
</LinearLayout> </LinearLayout>

View File

@@ -97,9 +97,6 @@
<dimen name="dashboard_category_padding_start">0dp</dimen> <dimen name="dashboard_category_padding_start">0dp</dimen>
<dimen name="dashboard_category_padding_end">0dp</dimen> <dimen name="dashboard_category_padding_end">0dp</dimen>
<!-- Dashboard category panel elevation -->
<dimen name="dashboard_category_elevation">2dp</dimen>
<!-- Dashboard tile minimum height --> <!-- Dashboard tile minimum height -->
<dimen name="dashboard_tile_minimum_height">72dp</dimen> <dimen name="dashboard_tile_minimum_height">72dp</dimen>

View File

@@ -22,9 +22,6 @@ import android.content.Context;
import android.content.Intent; import android.content.Intent;
import android.content.IntentSender.SendIntentException; import android.content.IntentSender.SendIntentException;
import android.content.pm.ResolveInfo; import android.content.pm.ResolveInfo;
import android.database.DataSetObserver;
import android.graphics.Color;
import android.graphics.drawable.ColorDrawable;
import android.graphics.drawable.Drawable; import android.graphics.drawable.Drawable;
import android.os.Bundle; import android.os.Bundle;
import android.print.PrintManager; import android.print.PrintManager;
@@ -44,13 +41,10 @@ import android.view.View;
import android.view.View.OnClickListener; import android.view.View.OnClickListener;
import android.view.ViewGroup; import android.view.ViewGroup;
import android.view.accessibility.AccessibilityManager; import android.view.accessibility.AccessibilityManager;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.Filter; import android.widget.Filter;
import android.widget.Filterable; import android.widget.Filterable;
import android.widget.ImageView; import android.widget.ImageView;
import android.widget.LinearLayout; import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.SearchView; import android.widget.SearchView;
import android.widget.Switch; import android.widget.Switch;
import android.widget.TextView; import android.widget.TextView;
@@ -67,8 +61,11 @@ import java.util.LinkedHashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import androidx.annotation.NonNull;
import androidx.loader.app.LoaderManager; import androidx.loader.app.LoaderManager;
import androidx.loader.content.Loader; import androidx.loader.content.Loader;
import androidx.recyclerview.widget.RecyclerView;
import androidx.recyclerview.widget.RecyclerView.AdapterDataObserver;
/** /**
* Fragment with print service settings. * Fragment with print service settings.
@@ -77,23 +74,18 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
implements SwitchBar.OnSwitchChangeListener, implements SwitchBar.OnSwitchChangeListener,
LoaderManager.LoaderCallbacks<List<PrintServiceInfo>> { LoaderManager.LoaderCallbacks<List<PrintServiceInfo>> {
private static final String LOG_TAG = "PrintServiceSettingsFragment"; private static final String LOG_TAG = "PrintServiceSettings";
private static final int LOADER_ID_PRINTERS_LOADER = 1; private static final int LOADER_ID_PRINTERS_LOADER = 1;
private static final int LOADER_ID_PRINT_SERVICE_LOADER = 2; private static final int LOADER_ID_PRINT_SERVICE_LOADER = 2;
private final DataSetObserver mDataObserver = new DataSetObserver() { private final AdapterDataObserver mDataObserver = new AdapterDataObserver() {
@Override @Override
public void onChanged() { public void onChanged() {
invalidateOptionsMenuIfNeeded(); invalidateOptionsMenuIfNeeded();
updateEmptyView(); updateEmptyView();
} }
@Override
public void onInvalidated() {
invalidateOptionsMenuIfNeeded();
}
private void invalidateOptionsMenuIfNeeded() { private void invalidateOptionsMenuIfNeeded() {
final int unfilteredItemCount = mPrintersAdapter.getUnfilteredCount(); final int unfilteredItemCount = mPrintersAdapter.getUnfilteredCount();
if ((mLastUnfilteredItemCount <= 0 && unfilteredItemCount > 0) if ((mLastUnfilteredItemCount <= 0 && unfilteredItemCount > 0)
@@ -173,8 +165,6 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
super.onViewCreated(view, savedInstanceState); super.onViewCreated(view, savedInstanceState);
initComponents(); initComponents();
updateUiForArguments(); updateUiForArguments();
getListView().setVisibility(View.GONE);
getBackupListView().setVisibility(View.VISIBLE);
} }
@Override @Override
@@ -189,15 +179,11 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
.setPrintServiceEnabled(mComponentName, enabled); .setPrintServiceEnabled(mComponentName, enabled);
} }
private ListView getBackupListView() {
return (ListView) getView().findViewById(R.id.backup_list);
}
private void updateEmptyView() { private void updateEmptyView() {
ViewGroup contentRoot = (ViewGroup) getListView().getParent(); ViewGroup contentRoot = (ViewGroup) getListView().getParent();
View emptyView = getBackupListView().getEmptyView(); View emptyView = getEmptyView();
if (!mToggleSwitch.isChecked()) { if (!mToggleSwitch.isChecked()) {
if (emptyView != null && emptyView.getId() != R.id.empty_print_state) { if (emptyView != null) {
contentRoot.removeView(emptyView); contentRoot.removeView(emptyView);
emptyView = null; emptyView = null;
} }
@@ -209,11 +195,10 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
TextView textView = (TextView) emptyView.findViewById(R.id.message); TextView textView = (TextView) emptyView.findViewById(R.id.message);
textView.setText(R.string.print_service_disabled); textView.setText(R.string.print_service_disabled);
contentRoot.addView(emptyView); contentRoot.addView(emptyView);
getBackupListView().setEmptyView(emptyView); setEmptyView(emptyView);
} }
} else if (mPrintersAdapter.getUnfilteredCount() <= 0) { } else if (mPrintersAdapter.getUnfilteredCount() <= 0) {
if (emptyView != null if (emptyView != null) {
&& emptyView.getId() != R.id.empty_printers_list_service_enabled) {
contentRoot.removeView(emptyView); contentRoot.removeView(emptyView);
emptyView = null; emptyView = null;
} }
@@ -221,10 +206,10 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
emptyView = getActivity().getLayoutInflater().inflate( emptyView = getActivity().getLayoutInflater().inflate(
R.layout.empty_printers_list_service_enabled, contentRoot, false); R.layout.empty_printers_list_service_enabled, contentRoot, false);
contentRoot.addView(emptyView); contentRoot.addView(emptyView);
getBackupListView().setEmptyView(emptyView); setEmptyView(emptyView);
} }
} else if (mPrintersAdapter.getCount() <= 0) { } else if (mPrintersAdapter.getItemCount() <= 0) {
if (emptyView != null && emptyView.getId() != R.id.empty_print_state) { if (emptyView != null) {
contentRoot.removeView(emptyView); contentRoot.removeView(emptyView);
emptyView = null; emptyView = null;
} }
@@ -236,7 +221,11 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
TextView textView = (TextView) emptyView.findViewById(R.id.message); TextView textView = (TextView) emptyView.findViewById(R.id.message);
textView.setText(R.string.print_no_printers_found); textView.setText(R.string.print_no_printers_found);
contentRoot.addView(emptyView); contentRoot.addView(emptyView);
getBackupListView().setEmptyView(emptyView); setEmptyView(emptyView);
}
} else if (mPrintersAdapter.getItemCount() > 0) {
if (emptyView != null) {
contentRoot.removeView(emptyView);
} }
} }
} }
@@ -254,7 +243,7 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
private void initComponents() { private void initComponents() {
mPrintersAdapter = new PrintersAdapter(); mPrintersAdapter = new PrintersAdapter();
mPrintersAdapter.registerDataSetObserver(mDataObserver); mPrintersAdapter.registerAdapterDataObserver(mDataObserver);
final SettingsActivity activity = (SettingsActivity) getActivity(); final SettingsActivity activity = (SettingsActivity) getActivity();
@@ -263,31 +252,12 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
mSwitchBar.show(); mSwitchBar.show();
mToggleSwitch = mSwitchBar.getSwitch(); mToggleSwitch = mSwitchBar.getSwitch();
mToggleSwitch.setOnBeforeCheckedChangeListener(new ToggleSwitch.OnBeforeCheckedChangeListener() { mToggleSwitch.setOnBeforeCheckedChangeListener((toggleSwitch, checked) -> {
@Override onPreferenceToggled(mPreferenceKey, checked);
public boolean onBeforeCheckedChanged(ToggleSwitch toggleSwitch, boolean checked) { return false;
onPreferenceToggled(mPreferenceKey, checked);
return false;
}
}); });
getBackupListView().setSelector(new ColorDrawable(Color.TRANSPARENT)); getListView().setAdapter(mPrintersAdapter);
getBackupListView().setAdapter(mPrintersAdapter);
getBackupListView().setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
PrinterInfo printer = (PrinterInfo) mPrintersAdapter.getItem(position);
if (printer.getInfoIntent() != null) {
try {
getActivity().startIntentSender(printer.getInfoIntent().getIntentSender(),
null, 0, 0, 0);
} catch (SendIntentException e) {
Log.e(LOG_TAG, "Could not execute info intent: %s", e);
}
}
}
});
} }
@@ -446,8 +416,17 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
} }
} }
private final class PrintersAdapter extends BaseAdapter public static class ViewHolder extends RecyclerView.ViewHolder {
public ViewHolder(@NonNull View itemView) {
super(itemView);
}
}
private final class PrintersAdapter extends RecyclerView.Adapter<ViewHolder>
implements LoaderManager.LoaderCallbacks<List<PrinterInfo>>, Filterable { implements LoaderManager.LoaderCallbacks<List<PrinterInfo>>, Filterable {
private final Object mLock = new Object(); private final Object mLock = new Object();
private final List<PrinterInfo> mPrinters = new ArrayList<PrinterInfo>(); private final List<PrinterInfo> mPrinters = new ArrayList<PrinterInfo>();
@@ -509,19 +488,19 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
} }
} }
notifyDataSetChanged(); notifyDataSetChanged();
} }
}; };
} }
@Override @Override
public int getCount() { public int getItemCount() {
synchronized (mLock) { synchronized (mLock) {
return mFilteredPrinters.size(); return mFilteredPrinters.size();
} }
} }
@Override private Object getItem(int position) {
public Object getItem(int position) {
synchronized (mLock) { synchronized (mLock) {
return mFilteredPrinters.get(position); return mFilteredPrinters.get(position);
} }
@@ -543,24 +522,27 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
return printer.getStatus() != PrinterInfo.STATUS_UNAVAILABLE; return printer.getStatus() != PrinterInfo.STATUS_UNAVAILABLE;
} }
@NonNull
@Override @Override
public View getView(int position, View convertView, ViewGroup parent) { public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
if (convertView == null) { final View view = LayoutInflater.from(parent.getContext())
convertView = getActivity().getLayoutInflater().inflate( .inflate(R.layout.printer_dropdown_item, parent, false);
R.layout.printer_dropdown_item, parent, false); return new ViewHolder(view);
} }
convertView.setEnabled(isActionable(position)); @Override
public void onBindViewHolder(@NonNull ViewHolder holder, int position) {
holder.itemView.setEnabled(isActionable(position));
final PrinterInfo printer = (PrinterInfo) getItem(position); final PrinterInfo printer = (PrinterInfo) getItem(position);
CharSequence title = printer.getName(); CharSequence title = printer.getName();
CharSequence subtitle = printer.getDescription(); CharSequence subtitle = printer.getDescription();
Drawable icon = printer.loadIcon(getActivity()); Drawable icon = printer.loadIcon(getActivity());
TextView titleView = (TextView) convertView.findViewById(R.id.title); TextView titleView = holder.itemView.findViewById(R.id.title);
titleView.setText(title); titleView.setText(title);
TextView subtitleView = (TextView) convertView.findViewById(R.id.subtitle); TextView subtitleView = holder.itemView.findViewById(R.id.subtitle);
if (!TextUtils.isEmpty(subtitle)) { if (!TextUtils.isEmpty(subtitle)) {
subtitleView.setText(subtitle); subtitleView.setText(subtitle);
subtitleView.setVisibility(View.VISIBLE); subtitleView.setVisibility(View.VISIBLE);
@@ -569,7 +551,7 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
subtitleView.setVisibility(View.GONE); subtitleView.setVisibility(View.GONE);
} }
LinearLayout moreInfoView = (LinearLayout) convertView.findViewById(R.id.more_info); LinearLayout moreInfoView = holder.itemView.findViewById(R.id.more_info);
if (printer.getInfoIntent() != null) { if (printer.getInfoIntent() != null) {
moreInfoView.setVisibility(View.VISIBLE); moreInfoView.setVisibility(View.VISIBLE);
moreInfoView.setOnClickListener(new OnClickListener() { moreInfoView.setOnClickListener(new OnClickListener() {
@@ -587,7 +569,7 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
moreInfoView.setVisibility(View.GONE); moreInfoView.setVisibility(View.GONE);
} }
ImageView iconView = (ImageView) convertView.findViewById(R.id.icon); ImageView iconView = holder.itemView.findViewById(R.id.icon);
if (icon != null) { if (icon != null) {
iconView.setVisibility(View.VISIBLE); iconView.setVisibility(View.VISIBLE);
if (!isActionable(position)) { if (!isActionable(position)) {
@@ -603,7 +585,18 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
iconView.setVisibility(View.GONE); iconView.setVisibility(View.GONE);
} }
return convertView; holder.itemView.setOnClickListener(v -> {
PrinterInfo pi = (PrinterInfo) getItem(position);
if (pi.getInfoIntent() != null) {
try {
getActivity().startIntentSender(pi.getInfoIntent().getIntentSender(),
null, 0, 0, 0);
} catch (SendIntentException e) {
Log.e(LOG_TAG, "Could not execute info intent: %s", e);
}
}
});
} }
@Override @Override
@@ -642,7 +635,7 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
mFilteredPrinters.clear(); mFilteredPrinters.clear();
mLastSearchString = null; mLastSearchString = null;
} }
notifyDataSetInvalidated(); notifyDataSetChanged();
} }
} }