服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Android - Android自定义表格控件满足人们对视觉的需求

Android自定义表格控件满足人们对视觉的需求

2021-01-06 14:38Android开发网 Android

随着人们对视觉的需求,基本组件已无法满足人们求新求异的要求,于是我们常常会自定义组件,用来实现更美观的UI界面,接下来将介绍Android如何自定义表格控件,感兴趣的朋友可以了解下,或许对你学习自定义控件有所帮助

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, 129, 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, starty, (getwidth()/mcol)*i, getheight()-starty, paint);
}
// 画行分割线
for(int j=1;j<mrow;j++){
canvas.drawline(startx, (getheight()/mrow)*j, getwidth()-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自定义表格控件满足人们对视觉的需求

延伸 · 阅读

精彩推荐
  • AndroidAndroid CardView+ViewPager实现ViewPager翻页动画的方法

    Android CardView+ViewPager实现ViewPager翻页动画的方法

    本篇文章主要介绍了Android CardView+ViewPager实现ViewPager翻页动画的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    Abby代黎明9592022-03-02
  • AndroidAndroid中AsyncTask详细介绍

    Android中AsyncTask详细介绍

    这篇文章主要介绍了Android中AsyncTask详细介绍,AsyncTask是一个很常用的API,尤其异步处理数据并将数据应用到视图的操作场合,需要的朋友可以参考下...

    Android开发网7432021-03-11
  • Android汇总Android视频录制中常见问题

    汇总Android视频录制中常见问题

    这篇文章主要汇总了Android视频录制中常见问题,帮助大家更好地解决Android视频录制中常见的问题,需要的朋友可以参考下...

    yh_thu5192021-04-28
  • AndroidAndroid实现Service获取当前位置(GPS+基站)的方法

    Android实现Service获取当前位置(GPS+基站)的方法

    这篇文章主要介绍了Android实现Service获取当前位置(GPS+基站)的方法,较为详细的分析了Service基于GPS位置的技巧,具有一定参考借鉴价值,需要的朋友可以参考下...

    Ruthless8332021-03-31
  • AndroidAndroid编程解析XML方法详解(SAX,DOM与PULL)

    Android编程解析XML方法详解(SAX,DOM与PULL)

    这篇文章主要介绍了Android编程解析XML方法,结合实例形式详细分析了Android解析XML文件的常用方法与相关实现技巧,需要的朋友可以参考下...

    liuhe68810042021-05-03
  • AndroidAndroid程序设计之AIDL实例详解

    Android程序设计之AIDL实例详解

    这篇文章主要介绍了Android程序设计的AIDL,以一个完整实例的形式较为详细的讲述了AIDL的原理及实现方法,需要的朋友可以参考下...

    Android开发网4622021-03-09
  • AndroidAndroid实现固定屏幕显示的方法

    Android实现固定屏幕显示的方法

    这篇文章主要介绍了Android实现固定屏幕显示的方法,实例分析了Android屏幕固定显示所涉及的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下...

    鉴客6182021-03-27
  • AndroidAndroid界面效果UI开发资料汇总(附资料包)

    Android界面效果UI开发资料汇总(附资料包)

    android ui界面设计,友好的界面会提高用户体验度;同时也增强了android ui界面设计的难度,本文提供了一些常用开发资料(有下载哦)感兴趣的朋友可以了解下...

    Android开发网4652021-01-03