declare-styleable是给自定义控件添加自定义属性用的
1.首先,先写attrs.xml
<?xml version="1.0" encoding="utf-8"?> <resources> <declare-styleable name="TestAttr"> <attr name="name" format="reference" /> <attr name="age"> <flag name="child" value="10" /> <flag name="young" value="18" /> <flag name="oldman" value="60" /> </attr> <attr name="textSize" format="dimension" /> </declare-styleable> </resources>
reference指的是是从string.xml引用过来
flag是自己定义的,类似于 android:gravity="top"
dimension 指的是是从dimension.xml里引用过来的内容.注意,这里如果是dp那就会做像素转换 2.在布局文件里的写法
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:attrstest="http://schemas.android.com/apk/res/com.arlos.attrstest" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" >s <com.arlos.attrstest.MyTestView android:id="@+id/tvTest" android:layout_width="fill_parent" android:layout_height="wrap_content" attrstest:name="@string/myname" android:gravity="top" attrstest:age="young" attrstest:textSize="@dimen/aa" android:text="@string/hello" /> </LinearLayout>
2.1 先引用这个dtd
xmlns:attrstest="http://schemas.android.com/apk/res/com.arlos.attrstest"
attrstest是随便写的.后面的包名是你所在的项目的根包.也就是在manifest里的com.arlos.attrstest
2.2 在自定义的控件里写属性
3. 最后在控件的构造方法里取得这些值
public class MyTestView extends TextView { public MyTestView(Context context, AttributeSet attrs) { super(context, attrs); TypedArray tArray = context.obtainStyledAttributes(attrs, R.styleable.TestAttr); String name = tArray.getString(R.styleable.TestAttr_name); System.out.println("name = " + name); int age = tArray.getInt(R.styleable.TestAttr_age, 200); System.out.println("age = " + age); float demin = tArray.getDimension(R.styleable.TestAttr_textSize,0); System.out.println("demin = " + demin); tArray.recycle(); } }
自定义属性数据类型简介:
一、reference:参考指定Theme中资源ID。
1.定义:
1
2
3
|
<declare-styleable name="My">
<attr name="label" format="reference" >
</declare-styleable>
|
2.使用:
1
|
<Buttonzkx:label="@string/label" >
|
二、Color:颜色
1.定义:
1
2
3
|
<declare-styleable name="My">
<attr name="textColor" format="color" />
</declare-styleable>
|
2.使用:
1
|
<Button zkx:textColor="#ff0000"/>
|
三、boolean:布尔值
1.定义:
1
2
3
|
<declare-styleable name="My">
<attr name="isVisible" format="boolean" />
</declare-styleable>
|
2.使用:
1
|
<Button zkx:isVisible="false"/>
|
四、dimension:尺寸值
1.定义:
1
2
3
|
<declare-styleable name="My">
<attr name="myWidth" format="dimension" />
</declare-styleable>
|
2.使用:
1
|
<Button zkx:myWidth="100dip"/>
|
五、float:浮点型
1.定义:
1
2
3
|
<declare-styleable name="My">
<attr name="fromAlpha" format="float" />
</declare-styleable>
|
2.使用:
1
|
<alpha zkx:fromAlpha="0.3"/>
|
六、integer:整型
1.定义:
1
2
3
|
<declare-styleable name="My">
<attr name="frameDuration" format="integer" />
</declare-styleable>
|
2.使用:
1
|
<animated-rotate zkx:framesCount="22"/>
|
七、string:字符串
1.定义:
1
2
3
|
<declare-styleable name="My">
<attr name="Name" format="string" />
</declare-styleable>
|
2.使用:
1
|
<rotate zkx:pivotX="200%"/>
|
八、fraction:百分数
1.定义:
1
2
3
|
<declare-styleable name="My">
<attr name="pivotX" format="fraction" />
</declare-styleable>
|
2.使用:
1
|
<rotate zkx:Name="My name is zhang kun xiang"/>
|
九、enum:枚举
1.定义:
1
2
3
4
5
|
<declare-styleable name="My">
<attr name="language">
<enum name="English" value="1"/>
</attr>
</declare-styleable>
|
2.使用:
1
|
<Button zkx:language="English"/>
|
十、flag:位或运算
1.定义:
1
2
3
4
5
6
|
<declare-styleable name="My">
<attr name="windowSoftInputMode">
<flag name="stateUnspecified" value="1" />
<flag name = "adjustNothing" value = "0x30" />
</attr>
</declare-styleable>
|
2.使用:
1
|
<activity android:windowSoftInputMode="stateUnspecified | adjustNothing">
|
属性定义时可以指定多种类型值:
1
2
3
|
<declare-styleable name = "名称">
<attr name="background" format="reference|color" />
</declare-styleable>
|
使用:
1
|
<ImageView android:background = "@drawable/图片ID|#00FF00"/>
|
今天的文章declare-styleable的使用分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/31624.html