androidx PreferenceDialogFragmentCompat 和 DialogPreference的配合应用

本文介绍了在升级到androidx后,如何使用PreferenceDialogFragmentCompat和DialogPreference配合实现数据持久化和UI绑定。文章详细阐述了两者的使用流程,包括点击Preference触发显示Dialog、事件传递、数据绑定以及关键方法的重写,特别是如何设置Dialog的属性。作者还分享了解决Dialog positiveButton启用问题的方法,并鼓励读者深入学习这一系列内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在升级替换使用 androidx DialogPreference 的时候,发现androidx 对DialogPreference进行了解耦,之前的数据持久化和Ui的绑定在DialogPreference中就能实现,而现在需要通过PreferenceDialogFragmentCompat和DialogPreference配合才能使用。

说实话对preference的应用在做这个升级之前我并没有遇见过,所以,只能摸索着去探索。

1.首先分析下这两个类要怎么使用

参考文档:https://medium.com/@JakobUlbrich/building-a-settings-screen-for-android-part-3-ae9793fd31ec

首先看一张图:

这张图是主要的架构图:(以一个设置页面为例子)

1.PreferenceDialogFragmentCompat:点击DialogPrecence的时候展示的 Dialog

2.Preference:显示在设置页面上的item,同时也是数据持久化的容器

3.PreferenceFragmentCompat:展示设置的主要Fragment

4.PreferenceManager:sharePreference(Preference)和PreferenceFragmentCompat的数据管理器,两个类共享这个Manager

主要的流程:

1.preference 点击--> 调用onclick方法

 protected void onClick() {
        getPreferenceManager().showDialog(this);
    }

这时候会通过PrefereceManager去调用 showDialog方法

   */
    public void showDialog(Preference preference) {
        if (mOnDisplayPreferenceDialogListener != null) {
            mOnDisplayPreferenceDialogListener.onDisplayPreferenceDialog(preference);
        }
    }

2.传递事件到Fragment:

通过listener传递出去,在这边我们很容易猜到 PreferenceFragmentCompat 实现了 DisplayPreferenceDialogListener

到时候事件通过监听传递到PreferenceFragmentCompat

3.PreferenceFragmentCompat 实现 display方法

   public void onStart() {
        super.onStart();
        mPreferenceManager.setOnPreferenceTreeClickListener(this);
        mPreferenceManager.setOnDisplayPreferenceDialogListener(this);
    }

 

    @Override
    public void onDisplayPreferenceDialog(Preference preference) {

        boolean handled = false;
        if (getCallbackFragment() instanceof OnPreferenceDisplayDialogCallback) {
            handled = ((OnPreferenceDisplayDialogCallback) getCallbackFragment())
                    .onPreferenceDisplayDialog(this, preference);
        }
        if (!handled && getActivity() instanceof OnPreferenceDisplayDialogCallback) {
            handled = ((OnPref
Android DialogPreference 是一个继承自 Preference 的对话框控件,用于在应用程序的设置界面中显示一个自定义的对话框,以便用户可以选择设置一些选项。 DialogPreference 可以用于显示任何自定义的对话框,包括日期选择器、时间选择器、颜色选择器、列表选择器等。 要创建自定义的 DialogPreference,您需要创建一个类,该类继承自 DialogPreference,并重写 onCreateDialogView() 方法以返回您的自定义视图。然后,您可以使用这个自定义的 DialogPreference 在你的应用程序设置中显示这个自定义视图。 以下是一个简单的示例代码,演示如何创建一个自定义的 DialogPreference: ```java public class MyDialogPreference extends DialogPreference { public MyDialogPreference(Context context, AttributeSet attrs) { super(context, attrs); } @Override protected View onCreateDialogView() { LayoutInflater inflater = (LayoutInflater) getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE); View view = inflater.inflate(R.layout.dialog_layout, null); // 在这里初始化自定义视图中的控件 return view; } } ``` 在这个示例中,我们创建了一个名为 MyDialogPreference 的自定义 DialogPreference,并在 onCreateDialogView() 方法中返回了一个自定义的视图。 在这个自定义的视图中,你可以添加任何你想要的控件逻辑。 接下来,在你的设置界面中使用这个自定义的 DialogPreference,只需在 XML 布局文件中将其添加为一个 Preference 对象: ```xml <PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android"> ... <com.example.MyDialogPreference android:key="my_dialog_preference" android:title="My Dialog Preference" android:summary="Click to open the dialog" /> ... </PreferenceScreen> ``` 这里我们使用了 Android 原生的 PreferenceScreen,将 MyDialogPreference 添加到应用程序的设置界面中。 请注意,我们在 XML 中为对话框设置了一个键(key),以便我们可以在代码中获取使用它。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值