一.自定义View的流程
1.属性设置
在styles.xml中设置控件属性,如果你想直接harcode可以忽略这步
<!--name为声明的"属性集合"名,可以随便取,但是最好是设置为跟我们的View一样的名称--> <declare-styleable name="MyView"> <!--声明我们的属性,名称为default_size,取值类型为尺寸类型(dp,px等)--> <attr name="default_size" format="dimension" /> </declare-styleable>
在这里关联的是View是MyView
2.创建自定义View,跟styles.xml配置保持一致
public class MyView extends View {
private int defalutSize;
public MyView(Context context) {
super(context);
}
public MyView(Context context, @Nullable AttributeSet attrs) {
super(context, attrs);
TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.MyView);
defalutSize = a.getDimensionPixelSize(R.styleable.MyView_default_size, 100); // 获取styles.xml配置的属性,R文件名称:R.styleable+属性集合名称+下划线+属性名称
a.recycle();
}
...
}
3.view的显示
假设我要在主界面显示我的view
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:hc="http://schemas.android.com/apk/res-auto" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:layout_width="wrap_content" android:layout_height="match_parent" android:text="sdasdasds"/> <com.example.qingge.drawviewtest.MyView android:layout_width="match_parent" android:layout_height="100dp" hc:default_size="100dp" /> </LinearLayout>