Switch Compat:onCheckedChanged

时间:2018-02-04 14:44:11

标签: android material-design switchcompat

我试图在我的Android应用中实现设置活动,用户可以在其中打开和关闭通知模式。为了达到这个目的,我使用Switch Compat。这是布局。这是我活动布局的一部分。

 <LinearLayout
    android:layout_width="match_parent"
    android:layout_height="50dp"
    android:orientation="horizontal"
    android:layout_marginStart="24dp"
    android:layout_marginTop="90dp"
    android:layout_marginEnd="16dp">

    <TextView
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:text="@string/notifications"
        android:layout_gravity="start|center"
        android:layout_weight="1"
        android:textSize="20sp"
        android:textStyle="bold"
        android:id="@+id/notifications"/>


    <android.support.v7.widget.SwitchCompat
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/notificationsSwitch"
        android:layout_gravity="end|center"
        android:theme="@style/SwitchTheme"/>

</LinearLayout>

这是响应交换机compat的功能。

SwitchCompat notificationsSwitch;
AlertDialog alertDialog;
AlertDialog.Builder builder;

 @Nullable
    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.activity_settings, container, false);
     notificationsSwitch = (SwitchCompat) view.findViewById(R.id.notificationsSwitch);

notificationsSwitch.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
            @Override
            public void onCheckedChanged(CompoundButton compoundButton, boolean b) {
                if (!b) {
                    builder = new AlertDialog.Builder(getActivity());
                    builder.setMessage("Are you sure that you want to turn the Notifications off");
                    builder.setPositiveButton("Turn off ", new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialogInterface, int i) {
                            notificationsSwitch.setChecked(false);
                        }
                    });
                    builder.setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialogInterface, int i) {
                            notificationsSwitch.setChecked(true);
                        }
                    });
                    alertDialog = builder.create();
                    alertDialog.show();
                    alertDialog.setCancelable(false);
                    alertDialog.setCanceledOnTouchOutside(false);
                    alertDialog.getButton(AlertDialog.BUTTON_POSITIVE).setTextColor(getResources().getColor(R.color.alertDialogPositiveButton));
                    alertDialog.getButton(AlertDialog.BUTTON_NEGATIVE).setTextColor(getResources().getColor(R.color.alertDialogNegativeButton));
                } else {
                    builder = new AlertDialog.Builder(getActivity());
                    builder.setMessage("Are you sure that you want to turn the Notifications on");
                    builder.setPositiveButton("Turn on ", new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialogInterface, int i) {
                            notificationsSwitch.setChecked(true);
                        }
                    });
                    builder.setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialogInterface, int i) {
                            notificationsSwitch.setChecked(false);
                        }
                    });
                    alertDialog = builder.create();
                    alertDialog.show();
                    alertDialog.setCancelable(false);
                    alertDialog.setCanceledOnTouchOutside(false);
                    alertDialog.getButton(AlertDialog.BUTTON_POSITIVE).setTextColor(getResources().getColor(R.color.alertDialogPositiveButton));
                    alertDialog.getButton(AlertDialog.BUTTON_NEGATIVE).setTextColor(getResources().getColor(R.color.alertDialogNegativeButton));
                }
            }
        });

我想做什么?

  • 正如我所说,这应该让用户能够打开和关闭通知。

有什么问题?

  • 除了一个bug之外,代码工作正常,而当用户想要为ex打开通知时,该错误就是。然后改变主意,然后在他将循环进入的对话框中单击取消。

为什么会这样?

  • 我已经取消了以这种方式工作,因此如果用户单击取消,则Switch Compat将返回之前的位置。但是因为我有该状态的方法所以它触发另一个状态并且用户处于循环中。

我尝试了什么?

  • 我尝试使用开关,但我无法通过布尔变量b。

  • 我也尝试使用flag变量,但我找不到逻辑。

有人知道我怎么能克服这一点。 提前谢谢。

4 个答案:

答案 0 :(得分:1)

您可以使用标志作为类属性,在对话框中单击选项时将设置为true,如IsFromDialog。

然后,在对话框中的Onclick函数内,设置 IsFromDialog = true;

最后,在onCheckChanged的开头你做了

如果(!b&amp;&amp;!IsFromDialog){ ... }

答案 1 :(得分:0)

当用户单击切换时,OnCheckChanged侦听器会被触发一次,然后当对话框将其更改回来时会再次触发,因此循环。请尝试使用OnTouchListener。

答案 2 :(得分:0)

您可以通过删除OnCheckedChangeListener,然后修改SwitchCompat的状态,然后重新添加OnCheckedChangeListener来解决此问题。这样,修改开关时没有任何东西在听。

如果稍微重构代码,这将更容易做到。首先,您应该将匿名侦听器提取到片段中的变量。换句话说,删除此位:

notificationsSwitch.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
    ...
});

并添加此内容(onCreateView()之外):

private CompoundButton.OnCheckedChangeListener listener = new CompoundButton.OnCheckedChangeListener() {
    ...
}

现在您已经完成了这项工作,您可以将其设置在onCreateView()内,如下所示:

notificationsSwitch = (SwitchCompat) view.findViewById(R.id.notificationsSwitch);
notificationsSwitch.setOnCheckedChangeListener(listener);

从这里开始,其余的很容易。进入所有四个正/负听众,并使它们看起来像这样:

notificationsSwitch.setOnCheckedChangeListener(null);
notificationsSwitch.setChecked(true);
notificationsSwitch.setOnCheckedChangeListener(listener);

答案 3 :(得分:0)

实现相同功能的最简单方法:

switchWIdget.setOnClickListener{view -> 
            val switchView = view as SwitchCompat
            when (switchView.isChecked) {
                false -> {
                    //do stuff for FALSE
                }
                true -> {
                   //do stuff for TRUE
                }
            }
        }