Use Android PreferenceFragment instead of our own

This commit is contained in:
Sylvain Berfini 2019-03-21 14:38:46 +01:00
parent 3368158ea7
commit 21dc3402f4
4 changed files with 34 additions and 317 deletions

View file

@ -1532,6 +1532,7 @@ public class LinphoneActivity extends LinphoneGenericActivity
LinphoneActivity.instance().goToChatList();
return true;
case SETTINGS:
case ACCOUNT_SETTINGS:
case ABOUT:
hideTopBar(); // just in case
LinphoneActivity.instance().goToDialerFragment();

View file

@ -27,6 +27,7 @@ import android.preference.Preference;
import android.preference.Preference.OnPreferenceChangeListener;
import android.preference.Preference.OnPreferenceClickListener;
import android.preference.PreferenceCategory;
import android.preference.PreferenceFragment;
import android.view.WindowManager;
import java.util.ArrayList;
import java.util.List;
@ -44,7 +45,7 @@ import org.linphone.fragments.FragmentsAvailable;
import org.linphone.settings.LinphonePreferences.AccountBuilder;
import org.linphone.utils.LinphoneUtils;
public class AccountPreferencesFragment extends PreferencesListFragment
public class AccountPreferencesFragment extends PreferenceFragment
implements AccountCreatorListener {
private int mN;
private final OnPreferenceClickListener linkAccountListener =
@ -61,7 +62,7 @@ public class AccountPreferencesFragment extends PreferencesListFragment
}
};
private boolean mIsNewAccount = false;
private final LinphonePreferences mPrefs;
private LinphonePreferences mPrefs;
private final OnPreferenceChangeListener mAvpfRRIntervalChangedListener =
new OnPreferenceChangeListener() {
@Override
@ -312,11 +313,6 @@ public class AccountPreferencesFragment extends PreferencesListFragment
};
private AccountCreator mAccountCreator;
public AccountPreferencesFragment() {
super(R.xml.account_preferences);
mPrefs = LinphonePreferences.instance();
}
private static boolean isEditTextEmpty(String s) {
return s.equals(""); // really empty.
}
@ -333,7 +329,9 @@ public class AccountPreferencesFragment extends PreferencesListFragment
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
addPreferencesFromResource(R.xml.account_preferences);
mPrefs = LinphonePreferences.instance();
mN = getArguments().getInt("Account", 0);
if (mN == mPrefs.getAccountCount()) {
mIsNewAccount = true;

View file

@ -1,286 +0,0 @@
package org.linphone.settings;
/*
PreferencesListFragment.java
Copyright (C) 2017 Belledonne Communications, Grenoble, France
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
import android.annotation.SuppressLint;
import android.app.Activity;
import android.app.ListFragment;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.preference.Preference;
import android.preference.PreferenceGroup;
import android.preference.PreferenceManager;
import android.preference.PreferenceScreen;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.view.ViewParent;
import android.widget.ListView;
import android.widget.RelativeLayout;
import java.lang.reflect.Constructor;
import java.lang.reflect.Method;
import org.linphone.R;
import org.linphone.core.tools.Log;
@SuppressLint("ValidFragment")
public class PreferencesListFragment extends ListFragment {
/** The starting request code given out to preference framework. */
private static final int FIRST_REQUEST_CODE = 100;
private static final int MSG_BIND_PREFERENCES = 0;
private PreferenceManager mPreferenceManager;
private ListView mPreferencesList;
private final Handler mHandler =
new Handler() {
@Override
public void handleMessage(Message msg) {
switch (msg.what) {
case MSG_BIND_PREFERENCES:
bindPreferences();
break;
}
}
};
private int mXmlResID;
PreferencesListFragment(int xmlId) {
mXmlResID = xmlId;
}
// Must be provided
public PreferencesListFragment() {}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle b) {
// Hack to correctly display preferences
View view = inflater.inflate(R.layout.settings, null);
ViewParent p = mPreferencesList.getParent();
if (p != null) {
((ViewGroup) p).removeView(mPreferencesList);
}
RelativeLayout layout = view.findViewById(R.id.topLayout);
layout.addView(mPreferencesList);
postBindPreferences();
return view;
}
@Override
public void onDestroyView() {
super.onDestroyView();
ViewParent p = mPreferencesList.getParent();
if (p != null) {
((ViewGroup) p).removeView(mPreferencesList);
}
}
@Override
public void onCreate(Bundle bundle) {
super.onCreate(bundle);
if (bundle != null) {
mXmlResID = bundle.getInt("xml");
}
mPreferenceManager = onCreatePreferenceManager();
mPreferencesList =
(ListView)
LayoutInflater.from(getActivity())
.inflate(R.layout.preference_list_content, null);
mPreferencesList.setScrollBarStyle(View.SCROLLBARS_INSIDE_OVERLAY);
addPreferencesFromResource(mXmlResID);
postBindPreferences();
}
@Override
public void onStop() {
super.onStop();
try {
Method m = PreferenceManager.class.getDeclaredMethod("dispatchActivityStop");
m.setAccessible(true);
m.invoke(mPreferenceManager);
} catch (Exception e) {
Log.e("[PreferencesListFragment] onStop " + e);
}
}
@Override
public void onDestroy() {
super.onDestroy();
mPreferencesList = null;
try {
Method m = PreferenceManager.class.getDeclaredMethod("dispatchActivityDestroy");
m.setAccessible(true);
m.invoke(mPreferenceManager);
} catch (Exception e) {
Log.e("[PreferencesListFragment] onDestroy " + e);
}
}
@Override
public void onSaveInstanceState(Bundle outState) {
outState.putInt("xml", mXmlResID);
super.onSaveInstanceState(outState);
}
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
try {
Method m =
PreferenceManager.class.getDeclaredMethod(
"dispatchActivityResult", int.class, int.class, Intent.class);
m.setAccessible(true);
m.invoke(mPreferenceManager, requestCode, resultCode, data);
} catch (Exception e) {
Log.e("[PreferencesListFragment] onActivityResult " + e);
}
}
/**
* Posts a message to bind the preferences to the list view.
*
* <p>Binding late is preferred as any custom preference types created in {@link
* #onCreate(Bundle)} are able to have their views recycled.
*/
private void postBindPreferences() {
if (mHandler.hasMessages(MSG_BIND_PREFERENCES)) return;
mHandler.obtainMessage(MSG_BIND_PREFERENCES).sendToTarget();
}
private void bindPreferences() {
final PreferenceScreen preferenceScreen = getPreferenceScreen();
if (preferenceScreen != null && mPreferencesList != null) {
preferenceScreen.bind(mPreferencesList);
}
}
/**
* Creates the {@link PreferenceManager}.
*
* @return The {@link PreferenceManager} used by this activity.
*/
private PreferenceManager onCreatePreferenceManager() {
try {
Constructor<PreferenceManager> c =
PreferenceManager.class.getDeclaredConstructor(Activity.class, int.class);
c.setAccessible(true);
return c.newInstance(this.getActivity(), FIRST_REQUEST_CODE);
} catch (Exception e) {
Log.e("[PreferencesListFragment] onCreatePreferenceManager " + e);
return null;
}
}
/**
* Returns the {@link PreferenceManager} used by this activity.
*
* @return The {@link PreferenceManager}.
*/
PreferenceManager getPreferenceManager() {
return mPreferenceManager;
}
/**
* Gets the root of the preference hierarchy that this activity is showing.
*
* @return The {@link PreferenceScreen} that is the root of the preference hierarchy.
*/
PreferenceScreen getPreferenceScreen() {
try {
Method m = PreferenceManager.class.getDeclaredMethod("getPreferenceScreen");
m.setAccessible(true);
return (PreferenceScreen) m.invoke(mPreferenceManager);
} catch (Exception e) {
Log.e("[PreferencesListFragment] getPreferenceScreen " + e);
}
return null;
}
/**
* Sets the root of the preference hierarchy that this activity is showing.
*
* @param preferenceScreen The root {@link PreferenceScreen} of the preference hierarchy.
*/
private void setPreferenceScreen(PreferenceScreen preferenceScreen) {
try {
Method m =
PreferenceManager.class.getDeclaredMethod(
"setPreferences", PreferenceScreen.class);
m.setAccessible(true);
boolean result = (Boolean) m.invoke(mPreferenceManager, preferenceScreen);
if (result && preferenceScreen != null) {
postBindPreferences();
}
} catch (Exception e) {
Log.e("[PreferencesListFragment] setPreferenceScreen " + e);
}
}
/**
* Inflates the given XML resource and adds the preference hierarchy to the current preference
* hierarchy.
*
* @param preferencesResId The XML resource ID to inflate.
*/
private void addPreferencesFromResource(int preferencesResId) {
try {
Method m =
PreferenceManager.class.getDeclaredMethod(
"inflateFromResource",
Context.class,
int.class,
PreferenceScreen.class);
m.setAccessible(true);
PreferenceScreen prefScreen =
(PreferenceScreen)
m.invoke(
mPreferenceManager,
getActivity(),
preferencesResId,
getPreferenceScreen());
setPreferenceScreen(prefScreen);
} catch (Exception e) {
Log.e("[PreferencesListFragment] addPreferencesFromResource " + e);
}
}
/**
* Finds a {@link Preference} based on its key.
*
* @param key The key of the preference to retrieve.
* @return The {@link Preference} with the key, or null.
* @see PreferenceGroup#findPreference(CharSequence)
*/
Preference findPreference(CharSequence key) {
if (mPreferenceManager == null) {
Log.e("[PreferencesListFragment] PreferenceManager is null !");
return null;
}
return mPreferenceManager.findPreference(key);
}
}

View file

@ -29,6 +29,7 @@ import android.content.pm.PackageManager;
import android.media.AudioManager;
import android.net.Uri;
import android.os.Build;
import android.os.Bundle;
import android.os.Handler;
import android.preference.CheckBoxPreference;
import android.preference.EditTextPreference;
@ -37,6 +38,7 @@ import android.preference.Preference;
import android.preference.Preference.OnPreferenceChangeListener;
import android.preference.Preference.OnPreferenceClickListener;
import android.preference.PreferenceCategory;
import android.preference.PreferenceFragment;
import android.preference.PreferenceScreen;
import android.provider.Settings;
import java.io.File;
@ -65,7 +67,7 @@ import org.linphone.utils.DeviceUtils;
import org.linphone.utils.FileUtils;
import org.linphone.views.LedPreference;
public class SettingsFragment extends PreferencesListFragment {
public class SettingsFragment extends PreferenceFragment {
private LinphonePreferences mPrefs;
private final Handler mHandler = new Handler();
private CoreListenerStub mListener;
@ -79,8 +81,10 @@ public class SettingsFragment extends PreferencesListFragment {
}
};
public SettingsFragment() {
super(R.xml.preferences);
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
addPreferencesFromResource(R.xml.preferences);
}
private static void setListPreferenceValues(
@ -156,6 +160,27 @@ public class SettingsFragment extends PreferencesListFragment {
hideSettings();
}
@Override
public void onResume() {
super.onResume();
// Init the settings page interface
initAccounts();
if (LinphoneActivity.isInstanciated()) {
LinphoneActivity.instance().selectMenu(FragmentsAvailable.SETTINGS);
}
}
@Override
public void onPause() {
if (LinphoneActivity.isInstanciated() && LinphoneManager.isInstanciated()) {
if (LinphoneManager.getInstance().getEchoTesterStatus()) stopEchoTester();
LinphoneActivity.instance().hideTopBar();
}
super.onPause();
}
private void removePreviousPreferencesFile() {
SharedPreferences.Editor editor = getPreferenceManager().getSharedPreferences().edit();
editor.clear();
@ -1778,25 +1803,4 @@ public class SettingsFragment extends PreferencesListFragment {
}
});
}
@Override
public void onResume() {
super.onResume();
// Init the settings page interface
initAccounts();
if (LinphoneActivity.isInstanciated()) {
LinphoneActivity.instance().selectMenu(FragmentsAvailable.SETTINGS);
}
}
@Override
public void onPause() {
if (LinphoneActivity.isInstanciated() && LinphoneManager.isInstanciated()) {
if (LinphoneManager.getInstance().getEchoTesterStatus()) stopEchoTester();
LinphoneActivity.instance().hideTopBar();
}
super.onPause();
}
}