自定义控件之继承ViewGroup(使用纯代码)
继承ViewGroup是自定义控件的一般方法,根据需要选择需要继承的ViewGroup的子类,本章将使用纯代码添加控件,方式确实不直观,但是可以用来练习使用代码操作控件的方法,毕竟不是所有的代码都可以用xml文件代替。
案例介绍
这次的目的实现一个类似这样的组合控件,出现这种需求是因为需要在一个ListView中添加一个类似ListView的部分,但是数量很少,可以不需要使用ListView,而是使用动态添加控件的方式。
效果
要实现的效果
贴一下代码,主要内容在注释中
完全使用代码来写控件,没有xml布局,调试的时候是个大问题,写的代码往往不能实时的显示在预览界面。
public class SpecialItemView extends RelativeLayout {
private ImageView imgIcon;
private TextView txtTitle;
private TextView txtSubTitle;
private TextView txtNum;
private ImageButton ibArrow;
private ImageView ivLine;
/**
* 代码中new时使用
*
* @param context
*/
public SpecialItemView(Context context) {
this(context, null);
}
/**
* 在xml文件中使用
*
* @param context
* @param attrs
*/
public SpecialItemView(Context context, AttributeSet attrs) {
super(context, attrs);
init(context, attrs);
}
/**
* 初始化
*
* @param context
* @param attributeSet
*/
private void init(Context context, AttributeSet attributeSet) {
int width = context.getResources().getDisplayMetrics().widthPixels;
this.setPadding(6,10,6,10);
imgIcon = new ImageView(context);
RelativeLayout.LayoutParams layoutParams =
new LayoutParams((int) (width*0.2),(int) (width*0.2));
layoutParams.addRule(CENTER_VERTICAL);
imgIcon.setScaleType(ImageView.ScaleType.CENTER_CROP);
imgIcon.setLayoutParams(layoutParams);
imgIcon.setId(R.id.sp_item_icon);
imgIcon.setImageResource(R.mipmap.finding_zone_img);
addView(imgIcon);
layoutParams = new LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
layoutParams.leftMargin = 20;
layoutParams.addRule(ALIGN_TOP, R.id.sp_item_icon);
layoutParams.addRule(RIGHT_OF, R.id.sp_item_icon);
txtTitle.setText("标题");
txtTitle = new TextView(context);
txtTitle.setId(R.id.sp_item_title);
txtTitle.setTextSize(TypedValue.COMPLEX_UNIT_SP,18);
txtTitle.setTextColor(Color.BLACK);
txtTitle.setLayoutParams(layoutParams);
txtTitle.setSingleLine();
txtTitle.setEllipsize(TextUtils.TruncateAt.END);
addView(txtTitle);
txtSubTitle = new TextView(context);
txtSubTitle.setId(R.id.sp_item_subtitle);
layoutParams = new LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
layoutParams.addRule(CENTER_VERTICAL);
layoutParams.addRule(ALIGN_LEFT, R.id.sp_item_title);
txtSubTitle.setText("字标题");
txtSubTitle.setTextSize(TypedValue.COMPLEX_UNIT_SP, 16);
txtSubTitle.setTextColor(Color.GRAY);
txtSubTitle.setLayoutParams(layoutParams);
txtSubTitle.setPadding(0,0,16,0);
txtSubTitle.setSingleLine();
txtSubTitle.setEllipsize(TextUtils.TruncateAt.END);
addView(txtSubTitle);
txtNum = new TextView(context);
txtNum.setId(R.id.sp_item_subtitle);
layoutParams = new LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
layoutParams.addRule(ALIGN_LEFT, R.id.sp_item_title);
layoutParams.addRule(ALIGN_BOTTOM, R.id.sp_item_icon);
txtNum.setText("共有几张专辑");
txtNum.setTextSize(TypedValue.COMPLEX_UNIT_SP, 16);
txtNum.setTextColor(Color.GRAY);
txtNum.setLayoutParams(layoutParams);
txtNum.setSingleLine();
txtNum.setEllipsize(TextUtils.TruncateAt.END);
txtNum.setGravity(CENTER_VERTICAL);
Drawable leftD = ContextCompat.getDrawable(getContext(), R.mipmap.finding_album_img);
leftD.setBounds(0, 0, 20, 0);
txtNum.setCompoundDrawablesWithIntrinsicBounds(leftD, null, null, null);
txtNum.setId(R.id.sp_item_num);
addView(txtNum);
ibArrow = new ImageButton(context);
ibArrow.setId(R.id.sp_item_subtitle);
layoutParams = new LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
layoutParams.addRule(CENTER_VERTICAL);
layoutParams.addRule(ALIGN_PARENT_RIGHT);
layoutParams.rightMargin = 16;
ibArrow.setBackgroundResource(R.drawable.selector_more);
ibArrow.setLayoutParams(layoutParams);
addView(ibArrow);
ivLine = new ImageView(context);
layoutParams = new LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,1);
layoutParams.addRule(ALIGN_LEFT,R.id.sp_item_title);
layoutParams.addRule(BELOW,R.id.sp_item_num);
layoutParams.topMargin=10;
ivLine.setLayoutParams(layoutParams);
ivLine.setBackgroundResource(R.drawable.shape_line);
addView(ivLine);
}
public void setTitle(String txt){
txtTitle.setText(txt==null?"":txt);
}
public void setSubTitle(String txt){
txtSubTitle.setText(txt==null?"":txt);
}
public void setNum(String txt){
txtNum.setText(txt==null?"":txt);
}
public void setShowLine(int xx){
ivLine.setVisibility(xx);
}
public void setImg(String url){
Picasso.with(getContext()).load(url).into(imgIcon);
}
public ImageView getImgIcon(){
return imgIcon;
}
public ImageButton getImgArrow(){
return ibArrow;
}
private OnMoreClick onMoreClick;
public
//使用接口将ibArrow点击事件传递出去
public interface OnMoreClick{
void click();
}
}
在xml文件中使用
<com.march.himalayasfm.app.widgets.SpecialItemView
android:layout_width="match_parent"
android:layout_height="wrap_content"
/>
可以看到显示的效果
综上,就是继承RelativeLayout使用纯代码实习的自定义View.