要配置自定义控件的属性,需要使用declare-styleable
标签来定义属性集合,并在布局文件中使用这些属性。
首先,在res/values
目录下的attrs.xml
文件中定义属性集合,例如:
<resources>
<declare-styleable name="MyCustomView">
<attr name="textColor" format="color" />
<attr name="textSize" format="dimension" />
<attr name="showIcon" format="boolean" />
</declare-styleable>
</resources>
在这个例子中,我们定义了一个名为MyCustomView
的属性集合,并添加了三个属性:textColor
、textSize
和showIcon
。
然后,在自定义控件的布局文件中,可以使用这些属性。例如:
<com.example.MyCustomView
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:textColor="@android:color/black"
app:textSize="16sp"
app:showIcon="true" />
在这个例子中,我们使用了自定义控件MyCustomView
,并设置了三个属性的值:textColor
、textSize
和showIcon
。
最后,在自定义控件的代码中,可以通过obtainStyledAttributes
方法获取这些属性的值。例如:
public class MyCustomView extends View {
private int textColor;
private float textSize;
private boolean showIcon;
public MyCustomView(Context context, AttributeSet attrs) {
super(context, attrs);
TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.MyCustomView);
textColor = typedArray.getColor(R.styleable.MyCustomView_textColor, Color.BLACK);
textSize = typedArray.getDimension(R.styleable.MyCustomView_textSize, 16);
showIcon = typedArray.getBoolean(R.styleable.MyCustomView_showIcon, false);
typedArray.recycle();
}
}
在这个例子中,我们通过obtainStyledAttributes
方法获取了textColor
、textSize
和showIcon
属性的值,并存储在相应的成员变量中。
注意:在获取属性值后,需要及时调用recycle
方法回收TypedArray
对象,以避免内存泄漏。