CheckedImageView

使用CheckedTextView可以解决带文字的checkbox的效果。

但是对于一个图片,我也需要checked属性。为了实现一些效果。例如下面的效果,点击眼睛密码变为隐藏显示。主要是后面的图片:点击有二态背景也有二态。


实现代码如下:使用ImageView实现Checkable接口。

package com.test.kwifi.widget;

import android.content.Context;
import android.util.AttributeSet;
import android.util.Log;
import android.view.View;
import android.widget.Checkable;
import android.widget.ImageView;

public class CheckedImageLayout extends ImageView implements Checkable{
	private static final String TAG = "CheckedImageLayout";
	private boolean isChecked = false;
	
	private static final int[] CHECKED_STATE_SET = {
        android.R.attr.state_checked
	};
	
	public CheckedImageLayout(Context context, AttributeSet attrs, int defStyle) {
		super(context, attrs, defStyle);
	}

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

	public CheckedImageLayout(Context context) {
		super(context);
	}

	public void setChecked(boolean check){
		isChecked = check;
		refreshDrawableState();
	}
	
	public boolean isChecked(){
		return isChecked;
	}
	
	public void toggle() {
        setChecked(!isChecked);
    }
	
	
	@Override
	public int[] onCreateDrawableState(int extraSpace) {
        final int[] drawableState = super.onCreateDrawableState(extraSpace + 1);
        if (isChecked()) {
            mergeDrawableStates(drawableState, CHECKED_STATE_SET);
        }
        return drawableState;
    }
}


使用:

         <com.test.kwifi.widget.CheckedImageLayout
            android:id="@+id/ctv_checktext"
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:layout_gravity="center_vertical"
            android:background="@drawable/eye_pwd_bg_selector"
            android:src="@drawable/share_pwdcheck_selector" />


eye_pwd_bg_selector为背景:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
    
    <!-- 选择时的图片 -->
    <item android:drawable="@drawable/eye_bg2" android:state_pressed="true"/>
    <item android:drawable="@drawable/eye_bg2" android:state_selected="true"/>

    <!-- 默认时的图片 --> 
    <item android:drawable="@drawable/eye_bg1"/>

</selector>

share_pwdcheck_selector
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
    
    <!-- 选择时的图片 -->
    <item android:drawable="@drawable/eye_bg2" android:state_pressed="true"/>
    <item android:drawable="@drawable/eye_bg2" android:state_selected="true"/>

    <!-- 默认时的图片 --> 
    <item android:drawable="@drawable/eye_bg1"/>

</selector>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值