自定义属性TypedArray的使用步骤

应用场景:在自定义View时,除了使用Android系统自带的属性外,还可以通过定义自定义属性并完成引用。

使用步骤:

1、在项目地址:res/value下创建一个attr.xml文件,如下

<span style="font-size:18px;"><?xml version="1.0" encoding="utf-8"?>  
<resources>  
    <declare-styleable name="MyApp">  </span>
<span style="font-size:18px;"><span style="white-space:pre">	</span><attr name="mWidth" format="integer"/>
        <attr name="mTextSize" format="dimension"/>  
        <attr name="mColor" format="color"/>  
    </declare-styleable>  
</resources> </span>

     其中,<resource>是根标签,可以在里面定义若干个<declare-styleable>标签
   <declare-styleable name="MyApp">中name定义了变量的名称
   可以在<declare-styleable>标签内自定义多个属性
   如<attr name="mTextSize" format="dimension"/>,其属性的名称为"mTextSize",format指定了该属性类型为dimension,只能表示字体的大小。
其中,format还可以指定其他的类型比如;
reference   表示引用,参考某一资源ID
string   表示字符串
color   表示颜色值
dimension   表示尺寸值
boolean   表示布尔值
integer   表示整型值
float   表示浮点值
fraction   表示百分数
enum   表示枚举值
flag   表示位运算

2、在布局中引用自定义控件时就可以使用自定义的属性了,如
<com.eyu.attrtextdemo.MyApp  
        android:layout_height="wrap_content"  
        android:layout_width="wrap_content"  
        myapp:mTextSize="20sp"  
        myapp:mColor="#324243"/>
3、在自定义View中引用自定义属性,修改构造函数,
        TypedArray a = context.obtainStyledAttributes(attrs,R.styleable.MyView);      
        int textColor = a.getColor(R.styleable.MyView_myColor, 003344);  
        float textSize = a.getDimension(R.styleable.MyView_myTextSize, 33);  
        paint.setTextSize(textSize);  
        paint.setColor(textColor);  
        a.recycle();
其中,在调用结束后,一定要引用recycle()方法,避免对下一次的使用造成影响。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值