资讯专栏INFORMATION COLUMN

自定义itemCheckView

loostudy / 480人阅读

极力推荐文章:欢迎收藏
Android 干货分享

阅读五分钟,每日十点,和您一起终身学习,这里是程序员Android

本篇文章主要介绍 Android 开发中的部分知识点,通过阅读本篇文章,您将收获以下内容:

自定义View类实现

自定义View标签

自定义View 布局

自定义View 选择器

自定义View 素材

Activity 引用 自定义view 控件

Activity使用自定义View

itemCheckView 主要用于自定义选中item,常用于Settings 模块中,实现效果如下:

1. 自定义View类实现
public class ItemCheckView extends RelativeLayout {
    // 每一个xml中的结点,都需要转换成java中的对象才可以去运行
    // 转换成一个对象,调用其构造方法,在调用构造方法的时候,去做xml--->view操作

    private static final String TAG = "ItemCheckView";
    private TextView tv_title;
    private TextView tv_des;
    private CheckBox cb_box;
    private static final String NAMESPACE = "http://schemas.android.com/apk/res/com.programandroid";
    private String mDesTitle;
    private String mDesOff;
    private String mDesOn;

    public ItemCheckView(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
        initAttrs(attrs);
        initUI(context);
    }

    public ItemCheckView(Context context, AttributeSet attrs) {
        super(context, attrs);
        initAttrs(attrs);
        initUI(context);
    }

    public ItemCheckView(Context context) {
        super(context);
        initUI(context);
    }

    // 多带带抽取出来的 xml--->view
    private void initUI(Context context) {
        View.inflate(context, R.layout.item_check_view, this);

        tv_title = (TextView) findViewById(R.id.tv_title);
        tv_des = (TextView) findViewById(R.id.tv_des);

        cb_box = (CheckBox) findViewById(R.id.cb_box);

        tv_title.setText(mDesTitle);
    }

    // checkbox是否选中的状态,就决定了当前条目是否开启版本更新检测
    // checbbox选中状态,和版本更新状态绑定

    /**
     * 当前条目的选中状态,是否开启更新的选中状态
     */
    public boolean isCheck() {
        // 是否要去更新,由checkbox选中状态决定 true选中 false未选中
        return cb_box.isChecked();
    }

    /**
     * @param isCheck
     *            传递一个选中未选中的状态变量(true 选中 false未选中)
     */
    public void setCheck(boolean isCheck) {
        cb_box.setChecked(isCheck);
        if (isCheck) {
            tv_des.setText(mDesOn);
        } else {
            tv_des.setText(mDesOff);
        }
    }

    /**
     * @param attrs
     *            包含了属性名称和属性值的set集合
     */
    private void initAttrs(AttributeSet attrs) {
        // 打印属性总个数
        /*
         * Log.i(tag, "attrs.getAttributeCount() = "+attrs.getAttributeCount());
         * for(int i=0;i
2. 自定义View标签
1.注意 :自定义 Android 命名空间

Android 命名空间`(xmlns:android="http://schemas.android.com/apk/res/android"
方法一样,想使用自定义view的属性,必须声明自定义view`的命名空间
(xmlns:programandroid="http://schemas.android.com/apk/res/com.programandroid")

2. 注意:自定义View 属性

自定义View 属性如下:

  programandroid:desOff="  不选中"
  programandroid:desOn="  选中"
  programandroid:desTitle=" WIFI " 

属性声明在res/values/attrs.xml中定义



    
        
        
        
    
3. 自定义View 布局



    

    

    

4. 自定义View 选择器

CheckBox 自定义样式




    
    
    

自定义 item选择器




    
    
    
    
    
    

5. 自定义View 素材

6.自定义view 在Activity中布局引用
    
7. Activity使用自定义View
    /**
     * 自定义InitItemCheckView Activity 调用
     */
    private void InitItemCheckView() {
        // TODO Auto-generated method stub
        final ItemCheckView mItemCheckView = (ItemCheckView) findViewById(R.id.custom_item_check_view);
        mItemCheckView.setCheck(false);

        mItemCheckView.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub

                // 1,获取当前条的原有状态
                boolean check = mItemCheckView.isCheck();
                // 2,对第一步获取的状态取反
                mItemCheckView.setCheck(!check);
                if (!check) {

                } else {

                }

            }
        });
    }

至此,本篇已结束,如有不对的地方,欢迎您的建议与指正。同时期待您的关注,感谢您的阅读,谢谢!

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/75873.html

相关文章

  • CSS 定义属性 - 入门

    摘要:变量的函数引用的自定义属性被称为变量。为此,可读性和可维护性是自定义属性最大的优势。自定义属性作用域在中,变量有作用域一说。因此,在选择器中声明的自定义属性,其作用域的范围是全局范围,也就是全局作用域。 引言   CSS语言是一种声明式语言,不像其他语言有变量、条件和逻辑等特性,因为这个原因,社区中有了各种CSS处理器语言,比如Sass、LESS和Stylus等。这些处理器语言引入了一...

    seanlook 评论0 收藏0
  • 定义元素探秘及构建可复用组件最佳实践

    摘要:若自定义元素标签名称不可用则摒弃。总之,自定义元素让开发者的代码更易理解和维护,并分割为小型,可复用及可封装的模块。被称为自定义元素接口,虽然现在仍然可用,但是已经被弃用并被认为是糟糕的实现。 原文请查阅这里,略有删减,本文采用知识共享署名 4.0 国际许可协议共享,BY Troland。 这是 JavaScript 工作原理第十九章。 概述 在 前述文章中,我们介绍了 Shadow ...

    CoorChice 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<