单选可检查卡片视图

Tar*_*ofl 1 android material-design android-cardview material-components material-components-android

我已经按照https://medium.com/@AlbinPoignot/checkable-cardview-in-all-android-versions-7124ca6df1ab实现了一个可检查的 CardView

但是,我需要让用户只选择一个选项。澄清一下,如果一个已经被选中,并且用户选择了另一个,我需要取消选择上一个选项。

此外,我需要在返回选定的 CardView 时保持选中状态。

有人可以帮我完成这两项任务吗?下面是我的实现:


    public class CheckableCardView extends CardView implements Checkable {

        private static final int[] CHECKED_STATE_SET = {
                android.R.attr.state_checked
        };

        private boolean isChecked;
        private TextView itemText;

        public CheckableCardView(Context context) {
            super(context);
            init(null);
        }

        public CheckableCardView(Context context, AttributeSet attrs) {
            super(context, attrs);
            init(attrs);
        }

        public CheckableCardView(Context context, AttributeSet attrs, int defStyleAttr) {
            super(context, attrs, defStyleAttr);
            init(attrs);
        }

        private void init(AttributeSet attrs) {
            LayoutInflater.from(getContext()).inflate(R.layout.checkable_card_view, this, true);

            setClickable(true);
            setChecked(false);

            setCardBackgroundColor(ContextCompat.getColorStateList(getContext(), R.color.selector_card_view_background));

            if (attrs != null) {
                TypedArray ta = getContext().obtainStyledAttributes(attrs, R.styleable.CheckableCardView, 0, 0);
                try {
                    String text = ta.getString(R.styleable.CheckableCardView_card_text);
                    itemText = (TextView) findViewById(R.id.text);

                    if (text != null) {
                        setText(text);
                    }

                } finally {
                    ta.recycle();
                }
            }
        }

        public void setText(String text){
            itemText.setText(text);
        }

        @Override
        protected int[] onCreateDrawableState(int extraSpace) {
            final int[] drawableState = super.onCreateDrawableState(extraSpace + 1);
            if (isChecked()) {
                mergeDrawableStates(drawableState, CHECKED_STATE_SET);
            }
            return drawableState;
        }

        @Override
        public boolean performClick() {
            toggle();
            return super.performClick();
        }

        @Override
        public void setChecked(boolean checked) {
            this.isChecked = checked;
        }

        @Override
        public boolean isChecked() {
            return isChecked;
        }

        @Override
        public void toggle() {
            setChecked(!this.isChecked);
        }
    }

Run Code Online (Sandbox Code Playgroud)

Gab*_*tti 5

您还可以使用MaterialCard由提供材料的组件库
这张卡实现了Checkable默认接口。

只需使用android:checkablexml 中的属性:

   <com.google.android.material.card.MaterialCardView
        android:checkable="true"
        ..>
Run Code Online (Sandbox Code Playgroud)

setCheckable(true)在您的代码中。

切换到已检查状态的一种方法是:

final MaterialCardView cardView = findViewById(R.id.card);
cardView.setOnClickListener(new View.OnClickListener() {
  @Override public void onClick(View view) {
    //cardView.setChecked(!cardView.isChecked());
    cardView.toggle();
  }
});
Run Code Online (Sandbox Code Playgroud)

在此处输入图片说明在此处输入图片说明