AndroID平台已经给我们提供了很多标准的组件,如:TextVIEw、EditVIEw、button、ImageVIEw、Menu等,还有许多布局控件,常见的有:absoluteLayout、linerLayout、relativeLayout、tableLayout等。但随着人们对视觉的需求,基本组件已无法满足人们求新求异的要求,于是我们常常会自定义组件,用来实现更美观的UI界面。
实现自定义控件通常有两种途径,一种是继承VIEw类,重写其中的重要方法,另一种是继承VIEwGroup类,通过重写父类中的有些方法,达到重新绘制组件的目的。最近做了一个自定义表格控件的练习,从中总结到一些经验。在这个练习中,我通过继承VIEwGroup类,重新绘制了用于呈现表格样式的容器组件,首先来看一下父类VIEwGroup。该类有三个构造方法:VIEwGroup(Context context)、VIEwGroup(Context context,AttributeSet attrs)、VIEwGroup(Context context,AttributeSet attrs,int defStyle),我们自定义的继承VIEwGroup的类需要实现它的至少一个构造方法。VIEwGroup中有几个方法非常重要,这几个方法更好的帮助我们实现自己的组件的布局与绘制。
1、onLayout方法
该方法用于在容器中如何摆放子控件,如果不重写该方法,子控件将无法在布局控件中得以展示,该方法有五个参数,用于设置子控件的上下左右四个边框的位置,还有一个标志位,这个方法也是子类必须实现的,因为该方法是个抽象方法。
2、addVIEw方法
该方法用于在容器组件中添加子控件
3、dispatchDraw方法
通过该方法,我们可以获取canvas对象,该对象允许我们在组件上画任意我们想要的图形,在这个表格控件中,我们可以在画布上上表格的外边框及表格线
4、getChildCount和getChildAt方法
这两个方法用于获取该容器控件中子控件的数目和位置,便于我们对子控件的排版和布局
5、onMeasure方法
这个方法是用来测量子控件大小的,它在onLayout方法之前被调用,测量了子控件的大小尺寸,然后可以绘制子控件在容器组件中的布局位置
下面直接给出代码示例,仅供参考
首先是表格控件的类:
复制代码 代码如下:
public class tableVIEw extends VIEwGroup{
private static final int STARTX = 0;// 起始X坐标
private static final int STARTY = 0;// 起始Y坐标
private static final int border = 2;// 表格边框宽度
private int mRow;// 行数
private int mCol;// 列数
public tableVIEw(Context context,AttributeSet attrs) {
super(context,attrs);
this.mRow = 3;// 默认行数为3
this.mCol = 3;// 默认列数为3
// 添加子控件
this.addOtherVIEw(context);
}
public tableVIEw(Context context,int row,int col) {
super(context);
if(row>20 || col>20){
this.mRow = 20;// 大于20行时,设置行数为20行
this.mCol = 20;// 大于20列时,设置列数为20列
}else if(row==0 || col==0){
this.mRow = 3;
this.mCol = 3;
}
else{
this.mRow = row;
this.mCol = col;
}
// 添加子控件
this.addOtherVIEw(context);
}
public voID addOtherVIEw(Context context){
int value = 1;
for(int i=1;i<=mRow;i++){
for(int j=1;j<=mCol;j++){
TextVIEw vIEw = new TextVIEw(context);
vIEw.setText(String.valueOf(value++));
vIEw.setTextcolor(color.rgb(79,129,189));
vIEw.setGravity(Gravity.CENTER);
if(i%2==0){
vIEw.setBackgroundcolor(color.rgb(219,238,243));
}else{
vIEw.setBackgroundcolor(color.rgb(235,241,221));
}
this.addVIEw(vIEw);
}
}
}
@OverrIDe
protected voID dispatchDraw(Canvas canvas) {
Paint paint = new Paint();
paint.setstrokeWIDth(border);
paint.setcolor(color.rgb(79,189));
paint.setStyle(Style.stroke);
// 绘制外部边框
canvas.drawRect(STARTX,STARTY,getWIDth()-STARTX,getHeight()-STARTY,paint);
// 画列分割线
for(int i=1;i<mCol;i++){
canvas.drawline((getWIDth()/mCol)*i,(getWIDth()/mCol)*i,paint);
}
// 画行分割线
for(int j=1;j<mRow;j++){
canvas.drawline(STARTX,(getHeight()/mRow)*j,paint);
}
super.dispatchDraw(canvas);
}
@OverrIDe
protected voID onLayout(boolean changed,int l,int t,int r,int b) {
int x = STARTX+border;
int y = STARTY+border;
int i = 0;
int count = getChildCount();
for(int j=0; j<count; j++){
VIEw child = getChildAt(j);
child.layout(x,y,x+getWIDth()/mCol-border*2,y+getHeight()/mRow-border*2);
if(i >=(mCol-1)){
i = 0;
x = STARTX+border;
y += getHeight()/mRow;
}else{
i++;
x += getWIDth()/mCol;
}
}
}
public voID setRow(int row){
this.mRow = row;
}
public voID setCol(int col){
this.mCol = col;
}
}
然后我们在Activity中使用我们的控件:
复制代码 代码如下:
public class MainActivity extends Activity implements OnClickListener{
private button btn;
private EditText row;
private EditText col;
@OverrIDe
protected voID onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentVIEw(R.layout.main);
btn = (button)findVIEwByID(R.ID.button1);
row = (EditText)findVIEwByID(R.ID.editRow);
col = (EditText)findVIEwByID(R.ID.editCol);
row.setError("请输入小于20的整数");
col.setError("请输入小于20的整数");
btn.setonClickListener(this);
}
@OverrIDe
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main,menu);
return true;
}
@OverrIDe
public voID onClick(VIEw v) {
Intent intent = new Intent();
Bundle bun = new Bundle();
if("".equals(row.getText().toString())){
Toast.makeText(this,"行数不能为空",Toast.LENGTH_SHORT).show();
return;
}else if("".equals(col.getText().toString())){
Toast.makeText(this,"列数不能为空",Toast.LENGTH_SHORT).show();
return;
}else{
int rowNum = Integer.parseInt(row.getText().toString());
int colNum = Integer.parseInt(col.getText().toString());
bun.putInt("row",rowNum);
bun.putInt("col",colNum);
intent.setClass(MainActivity.this,tableActivity.class);
intent.putExtras(bun);
startActivity(intent);
}
}
}
复制代码 代码如下:
public class tableActivity extends Activity{
@OverrIDe
protected voID onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Intent intent = this.getIntent();
Bundle bun = intent.getExtras();
int row = bun.getInt("row");
int col = bun.getInt("col");
tableVIEw table = new tableVIEw(this,row,col);
setContentVIEw(table);
}
}
效果图如下:
总结
以上是内存溢出为你收集整理的Android自定义表格控件满足人们对视觉的需求全部内容,希望文章能够帮你解决Android自定义表格控件满足人们对视觉的需求所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)