Gridview制作表格
来源:互联网 发布:诗词 知乎 编辑:程序博客网 时间:2024/05/01 13:07
最简单的方法
1.在GridView里设置一些属性
android:background="#000000" 背景色黑色
android:horizontalSpacing="1sp" 水平间距1sp
android:verticalSpacing="1sp" 垂直间距1sp
android:padding="1sp" 与里面的内容间隔1sp
2.在GridView的Adapter的布局里设置一些属性
android:background="#ffffff“
这样就实现表格的布局样式了
import hy.mingancai.tongqutang.R;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.util.AttributeSet;
import android.view.View;
import android.widget.GridView;
public class LineGridView extends GridView {
public LineGridView(Context context) {
super(context);
// TODO Auto-generated constructor stub
}
public LineGridView(Context context, AttributeSet attrs) {
super(context, attrs);
}
public LineGridView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}
@Override
protected void dispatchDraw(Canvas canvas) {
super.dispatchDraw(canvas);
// 第一个视图
View localView1 = getChildAt(0);
// 列数
int column = getWidth() / localView1.getWidth();
// 孩子数
int childCount = getChildCount();
Paint localPaint;
localPaint = new Paint();
localPaint.setStyle(Paint.Style.STROKE);
localPaint.setColor(getContext().getResources().getColor(R.color.main));
for (int i = 0; i < childCount; i++) {
View cellView = getChildAt(i);
if ((i + 1) % column == 0) {
canvas.drawLine(cellView.getLeft(), cellView.getBottom(), cellView.getRight(), cellView.getBottom(), localPaint);
} else if ((i + 1) > (childCount - (childCount % column))) {
canvas.drawLine(cellView.getRight(), cellView.getTop(), cellView.getRight(), cellView.getBottom(), localPaint);
} else {
canvas.drawLine(cellView.getRight(), cellView.getTop(), cellView.getRight(), cellView.getBottom(), localPaint);
canvas.drawLine(cellView.getLeft(), cellView.getBottom(), cellView.getRight(), cellView.getBottom(), localPaint);
}
}
if (childCount % column != 0) {
for (int j = 0; j < (column - childCount % column); j++) {
View lastView = getChildAt(childCount - 1);
canvas.drawLine(lastView.getRight() + lastView.getWidth() * j, lastView.getTop(), lastView.getRight() + lastView.getWidth() * j, lastView.getBottom(), localPaint);
}
}
}
}这样也可以,不过这个实现的效果是表格的最外层没线条
0 0
- Gridview制作表格
- 如何制作表格(三)——GridView + RecyclerView.GridLayoutManager
- Gridview鼠标经过变颜色的简单方法,GridView虚线表格的制作
- 表格制作
- 表格制作
- GridView多重表格
- GridView 关于表格设置
- GridView的表格用途
- GridView的表格用途
- C# gridview 列头画表格
- DEV GRIDVIEW 表格内嵌套表格
- 细线表格制作
- 网页表格制作 转
- 网页表格制作进阶
- 表格特效制作
- div 表格制作
- javaScript制作下拉表格
- javaScript制作下拉表格
- 多个activity共享相同的布局和控件
- JavaScript 点击事件小节
- Cocos2d-x初入学堂(17)-->打包成APK中文显示乱码
- BitmapFactory.Options.inSampleSize 的用法
- 疯狂猜歌实现(4)—— 实现文字待选框与已选文字框布局
- Gridview制作表格
- 数据库编码的问题
- Dos下的Sql Server操作
- JS数据类型之RegExp类型
- LoadRunner文件操作函数详解
- Meta-Object系统
- sublime插件
- Oracle BIEE (Business Intelligence) 11g 11.1.1.6.0 学习(3)创建一个简单的分析
- MobaXterm Windows下的终端软件