পছন্দসই বিভাগের মধ্যে অগ্রাধিকার পরিবর্তনের জন্য কীভাবে শুনবেন?


95

এখানে বর্ণিত হিসাবে , আমি পছন্দের ফ্রেমটি সাবক্লাসিং করছি এবং এটি একটি ক্রিয়াকলাপের মধ্যে প্রদর্শিত করছি। সেই দস্তাবেজটি এখানে কীভাবে অগ্রাধিকার পরিবর্তনের জন্য শোনার তা ব্যাখ্যা করে তবে কেবলমাত্র আপনি সাবক্লাস পছন্দঅ্যাক্টিভিটি। যেহেতু আমি এটি করছি না, তাই আমি কীভাবে পছন্দগুলি পরিবর্তনের জন্য শুনব?

আমি আমার পছন্দের ফ্রেমে OnSharedPreferencesChangeListener বাস্তবায়নের চেষ্টা করেছি কিন্তু এটি কাজ করে বলে মনে হয় না ( onSharedPreferenceChangedকখনই ডাকা হবে বলে মনে হয় না)।

এটি এখন পর্যন্ত আমার কোড:

সেটিংসঅ্যাক্টিভিটি.জভা

public class SettingsActivity extends Activity
{
    @Override
    protected void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);

        // Display the fragment as the main content.
        getFragmentManager().beginTransaction().replace(android.R.id.content, new SettingsFragment()).commit();
    }
}

সেটিংসফ্রেগমেন্ট.জভা

public class SettingsFragment extends PreferenceFragment implements OnSharedPreferenceChangeListener
{
    public static final String KEY_PREF_EXERCISES = "pref_number_of_exercises";

    @Override
    public void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);

        // Load the preferences from an XML resource
        addPreferencesFromResource(R.xml.preferences);
    }

    @Override
    public void onSharedPreferenceChanged(SharedPreferences sharedPreferences, String key)
    {
        //IT NEVER GETS IN HERE!
        if (key.equals(KEY_PREF_EXERCISES))
        {
            // Set summary to be the user-description for the selected value
            Preference exercisesPref = findPreference(key);
            exercisesPref.setSummary(sharedPreferences.getString(key, ""));
        }
    }
}

ferences.xml

<?xml version="1.0" encoding="utf-8"?>
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android" >

    <EditTextPreference
        android:defaultValue="15"
        android:enabled="true"
        android:key="pref_number_of_exercises"
        android:numeric="integer"
        android:title="Number of exercises" />

</PreferenceScreen>

এছাড়াও, অগ্রাধিকারের পরিবর্তনগুলি শোনার জন্য এমনকি অগ্রাধিকারের স্থানটি কি সঠিক জায়গা বা ক্রিয়াকলাপের মধ্যে আমার করা উচিত?


4
আপনার শেষ প্রশ্নটিতে এটি আপনার নকশার কাঠামোর উপর নির্ভর করে। একটি এমভিসি বা এমভিপি পদ্ধতির ব্যবহার অ্যান্ড্রয়েডের সাথে করা শক্ত কিন্তু আমি আমার সমস্ত ক্রিয়াকলাপটি ক্রিয়াকলাপে (নিয়ন্ত্রণকারী) অংশটিকে হোস্টিংয়ে রাখতে দেওয়ার চেষ্টা করি এবং খণ্ডটি কেবলমাত্র ইউআই হতে হবে (দেখুন / উপস্থাপক)
জন শেলি

উত্তর:


153

আমি বিশ্বাস করি আপনি শুধু রেজিস্টার / নিবন্ধন মুক্ত প্রয়োজন Listenerআপনার PreferenceFragmentএবং এটি কাজ করবে।

@Override
public void onResume() {
    super.onResume();
    getPreferenceManager().getSharedPreferences().registerOnSharedPreferenceChangeListener(this);

}

@Override
public void onPause() {
    getPreferenceManager().getSharedPreferences().unregisterOnSharedPreferenceChangeListener(this);
    super.onPause();
}

আপনি যা করতে চান তার উপর নির্ভর করে আপনার কোনও শ্রোতা ব্যবহার করার প্রয়োজন নেই। পছন্দগুলিতে পরিবর্তনগুলি SharedPreferencesস্বয়ংক্রিয়ভাবে প্রতিশ্রুতিবদ্ধ ।


আহ আমি দেখি. ওই কাজগুলো. তবে আমি কি getPreferenceManager(যেমন আপনি কাজ করেছেন) এর মাধ্যমে ভাগ করা পছন্দগুলি পেয়ে যাব নাকি getPreferenceScreen? পার্থক্য কি?
XåpplI'-I0llwlg'I -

সত্য কথা বলতে গেলে আমি নিশ্চিত নই যে আসল পার্থক্যটি কী, সম্ভবত অন্য কেউ এটি নিয়ে বিবেচনা করতে পারে, এটি অন্য একটি প্রশ্নের পক্ষেও ভাল বিষয় হতে পারে।
পূর্ববর্তী

4
ঠিক আছে, এখানে এই প্রশ্নের একটি উত্তর। দেখে মনে হচ্ছে কোনও কার্যকরী পার্থক্য নেই, তবে getPreferenceManagerএটি সাধারণত পছন্দসই বিকল্প।
XåpplI'-I0llwlg'I -

যখন প্রথমবারের জন্য সেটিংস-পছন্দটি তৈরি করা হয়, সঞ্চিত পছন্দসই মান অনুযায়ী সংক্ষিপ্তসারটি সেট করা হয় না। কিভাবে সমাধান করবেন ??
srv_sud

4
@ এসআরভি_সুড মানে keyপ্যারামিটারটি কী হওয়া উচিত? এই চেষ্টা করিনি, আপনি নীচের গানারের উত্তরে একটি উদাহরণ আছে: onSharedPreferenceChanged(null, "")। এটি আপনার প্রয়োজনের জন্য উপযুক্ত নাও হতে পারে। সম্ভবত আপনার পছন্দগুলির পছন্দগুলিতে পুনরুক্তি করা উচিত যা আপডেট দরকার
জোসে_জিডি

25

পূর্বে সমাধানটি ভালভাবে কাজ করে, আপনি এখানে Android v11 এর জন্য পুরো পছন্দ ক্রিয়াকলাপটি দেখতে পাবেন:

import android.app.Activity;
import android.content.SharedPreferences;
import android.content.SharedPreferences.OnSharedPreferenceChangeListener;
import android.os.Bundle;
import android.preference.ListPreference;
import android.preference.PreferenceFragment;

public class UserPreferencesV11 extends Activity  {

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    // Display the fragment as the main content.
    getFragmentManager().beginTransaction().replace(android.R.id.content,
            new PrefsFragment()).commit();
}

public static class PrefsFragment extends PreferenceFragment implements OnSharedPreferenceChangeListener {

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        // Load the preferences from an XML resource
        addPreferencesFromResource(R.xml.preferences);

        // set texts correctly
        onSharedPreferenceChanged(null, "");

    }

    @Override
    public void onResume() {
        super.onResume();
        // Set up a listener whenever a key changes
        getPreferenceScreen().getSharedPreferences().registerOnSharedPreferenceChangeListener(this);
    }

    @Override
    public void onPause() {
        super.onPause();
        // Set up a listener whenever a key changes
        getPreferenceScreen().getSharedPreferences().unregisterOnSharedPreferenceChangeListener(this);
    }

    @Override
    public void onSharedPreferenceChanged(SharedPreferences sharedPreferences, String key) {
        // just update all
        ListPreference lp = (ListPreference) findPreference(PREF_YOUR_KEY);
        lp.setSummary("dummy"); // required or will not update
        lp.setSummary(getString(R.string.pref_yourKey) + ": %s");

    }
}
}

স্থির শ্রেণিতে এটি নেই!
জোসেফ

আপনি কি এ সম্পর্কে বিস্তারিত বলতে পারেন? আপনি যে "এটি" উল্লেখ করছেন তা আমার কাছে একেবারেই নেই। উত্তরটি 7 বছরের পুরানো। অ্যান্ড্রয়েড অনেক পরিবর্তন হয়েছে।
গুনার বার্নস্টেইন

পাবলিক স্ট্যাটিক ক্লাস প্রেফসফ্র্যাগমেন্টটি একটি স্ট্যাটিক ক্লাস ঘোষণা করে এবং তারপরে এটিকে নিজেরাই রেফারেন্স করতে ব্যবহার করে। তবে এটি সম্ভব নয়, আপনি এটি একটি স্ট্যাটিক শ্রেণীর মধ্যে ব্যবহার করতে পারবেন না।
জোসেফ 4'20

আপনি কি জাভাতে স্থির অভ্যন্তর শ্রেণীর ধারণাটি বুঝতে পেরেছিলেন? একটি স্ট্যাটিক নেস্টেড বর্গটি তার বাইরের শ্রেণিকে তাত্ক্ষণিক না করেই ইনস্ট্যান্ট করা যেতে পারে। 'এটি' ব্যবহার করা পুরোপুরি ঠিক আছে। এটি সি # নয়!
গুনার বার্নস্টেইন

আমি নিশ্চিত নই, তবে আমি অ্যান্ড্রয়েড স্টুডিওতে কোডটি চেষ্টা করেছি এবং এটিতে এটির অভিযোগ রয়েছে: "getPreferencesScreen ()। GetSharedPreferences ()। ਰਜਿਸਟਰঅনশ্রেডপ্রেফারেন্সেনচারজলিস্টার (এটি);"; কোডটি সংকলনের জন্য আমাকে পুনরায় লিখতে হয়েছিল।
জোসেফ

16

অন্য সমস্ত উত্তর সঠিক। তবে আমি এই বিকল্পটি আরও ভাল পছন্দ করি কারণ আপনার সাথে সাথে পছন্দসই উদাহরণ রয়েছে যা পরিবর্তনের কারণ হয়ে দাঁড়িয়েছে caused

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    Preference pref = findPreference(getString(R.string.key_of_pref));        
    pref.setOnPreferenceChangeListener(new Preference.OnPreferenceChangeListener() {
        @Override
        public boolean onPreferenceChange(Preference preference, Object newValue) {
            // do whatever you want with new value

            // true to update the state of the Preference with the new value
            // in case you want to disallow the change return false
            return true;
        }
    });
}

সঠিক, যদিও আপনি onSharedPreferenceChanged ()পছন্দের উদাহরণটি সহজেই অ্যাক্সেস করতে পারেন findPreference(key)SharedPreferencesনিবন্ধকরণ / নিবন্ধভুক্ত জিনিসটির কারণে উপায়টি পছন্দ করা যেতে পারে ?
জোসে_জিডি

2

এটি আমার জন্য পছন্দের ফ্রেম.অনক্রিট () থেকে কাজ করেছে

OnSharedPreferenceChangeListener listener = 
    new SharedPreferences.OnSharedPreferenceChangeListener()
    {
        public void onSharedPreferenceChanged(SharedPreferences prefs, String key)
        {
         showDialog();
        }
    };

1

এটি করার একটি উপায় এবং কোনও সম্ভাব্য মেমরি ফাঁস এড়াতে এখানে:

@Override
public void onCreatePreferences(Bundle savedInstanceState, String rootKey) {
    addPreferencesFromResource(R.xml.pref_movies);

    SharedPreferences sharedPreferences = getPreferenceScreen().getSharedPreferences(); 

    //starts live change listener
    sharedPreferences.registerOnSharedPreferenceChangeListener(this);
}

@Override
public void onDestroyView () {
    super.onDestroyView(); 
//Unregisters listener here
    PreferenceManager.getDefaultSharedPreferences(getContext())
            .unregisterOnSharedPreferenceChangeListener(this);
}

0

আর একটি সম্পূর্ণ উদাহরণ যাতে আপনি সম্পূর্ণ ছবিটি দেখতে পান।

public class SettingsActivity extends AppCompatPreferenceActivity {


    /**
     * A preference value change listener that updates the preference's summary
     * to reflect its new value.
     */
    private static Preference.OnPreferenceChangeListener
            sBindPreferenceSummaryToValueListener =
            new Preference.OnPreferenceChangeListener() {

                @Override
                public boolean onPreferenceChange(Preference preference, Object value) {
                    String stringValue = value.toString();

                    if (preference instanceof ListPreference) {
                        // For list preferences, look up the correct display value in
                        // the preference's 'entries' list.
                        ListPreference listPreference = (ListPreference) preference;
                        int index = listPreference.findIndexOfValue(stringValue);

                        // Set the summary to reflect the new value.
                        preference.setSummary(
                                index >= 0
                                        ? listPreference.getEntries()[index]
                                        : null);

                    } else if (preference instanceof RingtonePreference) {
                        // For ringtone preferences, look up the correct display value
                        // using RingtoneManager.
                        if (TextUtils.isEmpty(stringValue)) {
                            // Empty values correspond to 'silent' (no ringtone).
                            preference.setSummary(R.string.pref_ringtone_silent);
                        } else {
                            Ringtone ringtone = RingtoneManager.getRingtone(
                                    preference.getContext(), Uri.parse(stringValue));
                            if (ringtone == null) {
                                // Clear the summary if there was a lookup error.
                                preference.setSummary(null);
                            } else {
                                // Set the summary to reflect the new ringtone display
                                // name.
                                String name = ringtone.getTitle(preference.getContext());
                                preference.setSummary(name);
                            }
                        }

                    } else {
                        // For all other preferences, set the summary to the value's
                        // simple string representation.
                        preference.setSummary(stringValue);
                    }
                    return true;
                }
            };

    /**
     * Helper method to determine if the device has an extra-large screen. For
     * example, 10" tablets are extra-large.
     */
    private static boolean isXLargeTablet(Context context) {
        return (context.getResources().getConfiguration().screenLayout
                & Configuration.SCREENLAYOUT_SIZE_MASK) >= Configuration.SCREENLAYOUT_SIZE_XLARGE;
    }

    /**
     * Binds a preference's summary to its value. More specifically, when the
     * preference's value is changed, its summary (line of text below the
     * preference title) is updated to reflect the value. The summary is also
     * immediately updated upon calling this method. The exact display format is
     * dependent on the type of preference.
     *
     * @see #sBindPreferenceSummaryToValueListener
     */
    private static void bindPreferenceSummaryToValue(Preference preference) {
        // Set the listener to watch for value changes.
        preference.setOnPreferenceChangeListener(sBindPreferenceSummaryToValueListener);

        // Trigger the listener immediately with the preference's current value.
        sBindPreferenceSummaryToValueListener.onPreferenceChange(preference,
                PreferenceManager
                        .getDefaultSharedPreferences(preference.getContext())
                        .getString(preference.getKey(), ""));
    }

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setupActionBar();
    }

    /**
     * Set up the {@link android.app.ActionBar}, if the API is available.
     */
    private void setupActionBar() {
        ActionBar actionBar = getSupportActionBar();
        if (actionBar != null) {
            // Show the Up button in the action bar.
            actionBar.setDisplayHomeAsUpEnabled(true);
        }
    }

    @Override
    public boolean onMenuItemSelected(int featureId, MenuItem item) {
        int id = item.getItemId();
        if (id == android.R.id.home) {
            if (!super.onMenuItemSelected(featureId, item)) {
                NavUtils.navigateUpFromSameTask(this);
            }
            return true;
        }
        return super.onMenuItemSelected(featureId, item);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public boolean onIsMultiPane() {
        return isXLargeTablet(this);
    }

    /**
     * {@inheritDoc}
     */
    @Override
    @TargetApi(Build.VERSION_CODES.HONEYCOMB)
    public void onBuildHeaders(List<Header> target) {
        loadHeadersFromResource(R.xml.pref_headers, target);
    }

    /**
     * This method stops fragment injection in malicious applications.
     * Make sure to deny any unknown fragments here.
     */
    protected boolean isValidFragment(String fragmentName) {
        return PreferenceFragment.class.getName().equals(fragmentName)
                || GPSLocationPreferenceFragment.class.getName().equals(fragmentName)
                || DataSyncPreferenceFragment.class.getName().equals(fragmentName)
                || NotificationPreferenceFragment.class.getName().equals(fragmentName);
    }

    ////////////////// NEW PREFERENCES ////////////////////////////

    @TargetApi(Build.VERSION_CODES.HONEYCOMB)
    public static class GPSLocationPreferenceFragment extends PreferenceFragment {

        Preference prefGPSServerAddr, prefGPSASDID, prefIsGPSSwitch;

        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            addPreferencesFromResource(R.xml.pref_gps_location);
            setHasOptionsMenu(true);

            // Bind the summaries of EditText/List/Dialog/Ringtone preferences
            // to their values. When their values change, their summaries are
            // updated to reflect the new value, per the Android Design
            // guidelines.

            bindPreferenceSummaryToValue(findPreference("gpsServer_Addr"));
            bindPreferenceSummaryToValue(findPreference("gpsASD_ID"));


            prefGPSServerAddr = findPreference("gpsServer_Addr");
            prefGPSServerAddr.setOnPreferenceChangeListener(new Preference.OnPreferenceChangeListener() {
                @Override
                public boolean onPreferenceChange(Preference preference, Object newValue) {

                    try {
                        // do whatever you want with new value

                    }
                    catch (Exception ex)
                    {
                        Log.e("Preferences", ex.getMessage());
                    }

                    // true to update the state of the Preference with the new value
                    // in case you want to disallow the change return false
                    return true;
                }
            });

            prefGPSASDID = findPreference("gpsASD_ID");
            prefGPSASDID.setOnPreferenceChangeListener(new Preference.OnPreferenceChangeListener() {
                @Override
                public boolean onPreferenceChange(Preference preference, Object newValue) {

                    try {
                        // do whatever you want with new value

                    }
                    catch (Exception ex)
                    {
                        Log.e("Preferences", ex.getMessage());
                    }

                    // true to update the state of the Preference with the new value
                    // in case you want to disallow the change return false
                    return true;
                }
            });

            prefIsGPSSwitch = findPreference("isGPS_Switch");
            prefIsGPSSwitch.setOnPreferenceChangeListener(new Preference.OnPreferenceChangeListener() {
                @Override
                public boolean onPreferenceChange(Preference preference, Object newValue) {

                    try {
                        // do whatever you want with new value

                    }
                    catch (Exception ex)
                    {
                        Log.e("Preferences", ex.getMessage());
                    }

                    // true to update the state of the Preference with the new value
                    // in case you want to disallow the change return false
                    return true;
                }
            });
        }

        @Override
        public boolean onOptionsItemSelected(MenuItem item) {
            int id = item.getItemId();
            if (id == android.R.id.home) {
                boolean tabletSize = getResources().getBoolean(R.bool.isTablet);
                if (tabletSize) {
                    startActivity(new Intent(getActivity(), MainActivity.class));
                } else {
                    startActivity(new Intent(getActivity(), SettingsActivity.class));
                }
                return true;
            }
            return super.onOptionsItemSelected(item);
        }
    }

    ///////////////////////////////////////////////////////////////

    /**
     * This fragment shows notification preferences only. It is used when the
     * activity is showing a two-pane settings UI.
     */
    @TargetApi(Build.VERSION_CODES.HONEYCOMB)
    public static class NotificationPreferenceFragment extends PreferenceFragment {
        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            addPreferencesFromResource(R.xml.pref_notification);
            setHasOptionsMenu(true);

            // Bind the summaries of EditText/List/Dialog/Ringtone preferences
            // to their values. When their values change, their summaries are
            // updated to reflect the new value, per the Android Design
            // guidelines.
            bindPreferenceSummaryToValue(findPreference("notifications_new_message_ringtone"));
        }

        @Override
        public boolean onOptionsItemSelected(MenuItem item) {
            int id = item.getItemId();
            if (id == android.R.id.home) {
                boolean tabletSize = getResources().getBoolean(R.bool.isTablet);
                if (tabletSize) {
                    startActivity(new Intent(getActivity(), MainActivity.class));
                } else {
                    startActivity(new Intent(getActivity(), SettingsActivity.class));
                }
                return true;
            }
            return super.onOptionsItemSelected(item);
        }
    }

    /**
     * This fragment shows data and sync preferences only. It is used when the
     * activity is showing a two-pane settings UI.
     */
    @TargetApi(Build.VERSION_CODES.HONEYCOMB)
    public static class DataSyncPreferenceFragment extends PreferenceFragment {
        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            addPreferencesFromResource(R.xml.pref_data_sync);
            setHasOptionsMenu(true);

            // Bind the summaries of EditText/List/Dialog/Ringtone preferences
            // to their values. When their values change, their summaries are
            // updated to reflect the new value, per the Android Design
            // guidelines.
            bindPreferenceSummaryToValue(findPreference("sync_frequency"));
        }

        @Override
        public boolean onOptionsItemSelected(MenuItem item) {
            int id = item.getItemId();
            if (id == android.R.id.home) {
                boolean tabletSize = getResources().getBoolean(R.bool.isTablet);
                if (tabletSize) {
                    startActivity(new Intent(getActivity(), MainActivity.class));
                } else {
                    startActivity(new Intent(getActivity(), SettingsActivity.class));
                }
                return true;
            }
            return super.onOptionsItemSelected(item);
        }
    }
}

0

আমি সম্প্রতি একসঙ্গে আমার নিজের নির্বাণ সমাপ্ত PreferenceScreenব্যবহার Preferences API, তাই আমি ভাবলাম আমার নিজের পূর্ণ উদাহরণ ভূমিকা পালন করবে .. এই আপডেট অন্তর্ভুক্ত Summaryনতুন / পরিবর্তিত মান, সেইসাথে শুনছেন এবং পরিবর্তন প্রতিক্রিয়া।

পুনশ্চ. আপনার শেষ প্রশ্নের উত্তর করার জন্য: জন্য ডিফল্ট মান দেখাতে Summaryপ্রাথমিক সৃষ্টি উপরে PreferenceScreen(মূল্য কোন পরিবর্তন করার পূর্বে), আপনি পারে শুধু সেট android:summaryআপনার পছন্দসই মান, ভিতর থেকে preferences.xmlসরাসরি ফাইল - এবং তারপর, সেখানে মানটির পরিবর্তন , এটি নীচে আমার উদাহরণে থাকা কোডটি ব্যবহার করে স্বয়ংক্রিয়ভাবে আপডেট হবে। ব্যক্তিগতভাবে , আমি Preferenceআমার প্রাথমিক হিসাবে এর একটি সংক্ষিপ্ত ব্যাখ্যা ব্যবহার করিSummaryআমার মধ্যে সেট preferences.xml, এবং তারপর একবার মূল্য নেই প্রথমবারের পরিবর্তিত পেতে, এটি সহজভাবে হিসাবে বর্তমান মূল্য প্রদর্শন করবে Summaryসেই সময় থেকে ..

যাহাই হউক না কেন , এখানে আমার পূর্ণ উদাহরণ:

SettingsFragment.java

public class SettingsFragment extends PreferenceFragment {

public static final String PREF_NOTIFICATION_MODE = "pref_notificationMode";
private SharedPreferences.OnSharedPreferenceChangeListener preferenceChangeListener;

@Override
public void onCreate (@Nullable Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    addPreferencesFromResource(R.xml.preferences);

    final SharedPreferences getPrefs = PreferenceManager.getDefaultSharedPreferences(this.getActivity());

    preferenceChangeListener = new SharedPreferences.OnSharedPreferenceChangeListener() {
        @Override
        public void onSharedPreferenceChanged(SharedPreferences sharedPreferences, String key) {

            if (key.equals(PREF_NOTIFICATION_MODE)) {
                Preference notifModePref = findPreference(key);
                notifModePref.setSummary(sharedPreferences.getString(key, ""));

                //  DO SOMETHING ELSE HERE WHEN (PREF_NOTIFICATION_MODE) IS CHANGED
            }
        }
    };
}

@Override
public void onResume() {
    super.onResume();

    getPreferenceScreen().getSharedPreferences().registerOnSharedPreferenceChangeListener(preferenceChangeListener);

    Preference notifModePref = findPreference(PREF_NOTIFICATION_MODE);
    notifModePref.setSummary(getPreferenceScreen().getSharedPreferences().getString(PREF_NOTIFICATION_MODE, ""));

}

@Override
public void onPause() {
    getPreferenceScreen().getSharedPreferences().unregisterOnSharedPreferenceChangeListener(preferenceChangeListener);

    super.onPause();
}
}


আশা করি এটা কাজে লাগবে!
যে কোনও ইতিবাচক প্রতিক্রিয়াটি অনেক প্রশংসা করা হয়েছে, কারণ আমি স্ট্যাকওভারফ্লোতে মোটামুটি নতুন;)
শুভ কোডিং!


ইন onPause, super.onPause()শ্রোতা নিবন্ধভুক্ত হওয়ার আগে বা পরে ডাকা উচিত ? একটি পার্থক্য আছে কি? আমি উভয়কেই অসংখ্য উদাহরণে দেখেছি
ব্রায়ান ডাব্লু

@ ব্রায়ানওয়ালশ আমি উভয় পদ্ধতির উদাহরণও দেখেছি .. আমি মনে করব কল করার আগে লিস্টারনারকে নিবন্ধন করা এটি super.onPause();সম্পর্কে সবচেয়ে ভাল উপায়।
স্টুডিও

0

আপনার onResume()পদ্ধতিতে আপনাকে নির্দিষ্ট প্রেফারেন্স ক্লাসটি বিলম্বিত করতে হবে । আমার ক্ষেত্রে আমি ব্যবহার করছিলেন SwitchPreferenceবর্গ, তাই কোড হবে like- SettingsActivity.class

public static class PrivacyPreferenceFragment extends PreferenceFragment
{
    public SwitchPreference switchPreference;

    @Override
    public void onResume() {
        super.onResume();
        switchPreference = (SwitchPreference) findPreference("privacy_notice_check");
    }

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        addPreferencesFromResource(R.xml.pref_privacy);
        setHasOptionsMenu(true);

    }

তারপরে আপনি যে ক্রিয়াকলাপটিতে PrefernceFragmentমানটি ব্যবহার করতে চান সেখানে SharedPreferenceমানগুলি কল করতে এবং এটি ট্রিগার করতে কেবল অবজেক্টটি ব্যবহার করুন ।


0

যদি আপনি কেবল অ্যান্ড্রয়েডক্স পছন্দ লাইব্রেরিটি ব্যবহার করে ( সরকারী নির্দেশিকা দেখুন ) এবং সংক্ষিপ্তসারটি আপডেট করতে চান তবে আপনার লেআউট xML- এ নিম্নলিখিত বৈশিষ্ট্য যুক্ত করা যথেষ্ট হবে:

<EditTextPreference
    ...
    app:useSimpleSummaryProvider="true" />

0

পছন্দ ফ্রেমক্যাম্প্যাট সহ কোটলিনে সমাধান

https://developer.android.com/references/androidx/preferences/PreferencesFraamentCompat

PrefChange যখন শুনুন

class SettingsFragment : PreferenceFragmentCompat() {

    override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) {
        setPreferencesFromResource(R.xml.root_preferences, rootKey)
        val prefListener =
            OnSharedPreferenceChangeListener { prefs, key ->
                val valueChanged = preferenceManager.sharedPreferences.getString(key,key)
                when(valueChanged){
                    getString(R.string.value_lang_en) -> applyLang(valueChanged)
                    getString(R.string.value_lang_th) -> applyLang(valueChanged)
                }
            }
        preferenceManager.
        sharedPreferences.
        registerOnSharedPreferenceChangeListener(prefListener)
    }
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.