| /* |
| * Copyright (C) 2015 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. |
| */ |
| |
| package com.android.setupwizardlib.items; |
| |
| import android.content.Context; |
| import android.content.res.TypedArray; |
| import android.support.v7.widget.SwitchCompat; |
| import android.util.AttributeSet; |
| import android.view.View; |
| import android.widget.CompoundButton; |
| |
| import com.android.setupwizardlib.R; |
| |
| /** |
| * An item that is displayed with a switch, with methods to manipulate and listen to the checked |
| * state of the switch. Note that by default, only click on the switch will change the on-off state. |
| * To change the switch state when tapping on the text, use the click handlers of list view or |
| * RecyclerItemAdapter with {@link #toggle(View)}. |
| */ |
| public class SwitchItem extends Item implements CompoundButton.OnCheckedChangeListener { |
| |
| /** |
| * Listener for check state changes of this switch item. |
| */ |
| public interface OnCheckedChangeListener { |
| |
| /** |
| * Callback when checked state of a {@link SwitchItem} is changed. |
| * |
| * @see #setOnCheckedChangeListener(OnCheckedChangeListener) |
| */ |
| void onCheckedChange(SwitchItem item, boolean isChecked); |
| } |
| |
| private boolean mChecked = false; |
| private OnCheckedChangeListener mListener; |
| |
| /** |
| * Creates a default switch item. |
| */ |
| public SwitchItem() { |
| super(); |
| } |
| |
| /** |
| * Creates a switch item. This constructor is used for inflation from XML. |
| * |
| * @param context The context which this item is inflated in. |
| * @param attrs The XML attributes defined on the item. |
| */ |
| public SwitchItem(Context context, AttributeSet attrs) { |
| super(context, attrs); |
| final TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.SuwSwitchItem); |
| mChecked = a.getBoolean(R.styleable.SuwSwitchItem_android_checked, false); |
| a.recycle(); |
| } |
| |
| /** |
| * Sets whether this item should be checked. |
| */ |
| public void setChecked(boolean checked) { |
| if (mChecked != checked) { |
| mChecked = checked; |
| notifyItemChanged(); |
| if (mListener != null) { |
| mListener.onCheckedChange(this, checked); |
| } |
| } |
| } |
| |
| /** |
| * @return True if this switch item is currently checked. |
| */ |
| public boolean isChecked() { |
| return mChecked; |
| } |
| |
| @Override |
| protected int getDefaultLayoutResource() { |
| return R.layout.suw_items_switch; |
| } |
| |
| /** |
| * Toggle the checked state of the switch, without invalidating the entire item. |
| * |
| * @param view The root view of this item, typically from the argument of onItemClick. |
| */ |
| public void toggle(View view) { |
| mChecked = !mChecked; |
| final SwitchCompat switchView = (SwitchCompat) view.findViewById(R.id.suw_items_switch); |
| switchView.setChecked(mChecked); |
| } |
| |
| @Override |
| public void onBindView(View view) { |
| super.onBindView(view); |
| final SwitchCompat switchView = (SwitchCompat) view.findViewById(R.id.suw_items_switch); |
| switchView.setOnCheckedChangeListener(null); |
| switchView.setChecked(mChecked); |
| switchView.setOnCheckedChangeListener(this); |
| switchView.setEnabled(isEnabled()); |
| } |
| |
| /** |
| * Sets a listener to listen for changes in checked state. This listener is invoked in both |
| * user toggling the switch and calls to {@link #setChecked(boolean)}. |
| */ |
| public void setOnCheckedChangeListener(OnCheckedChangeListener listener) { |
| mListener = listener; |
| } |
| |
| @Override |
| public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) { |
| mChecked = isChecked; |
| if (mListener != null) { |
| mListener.onCheckedChange(this, isChecked); |
| } |
| } |
| } |