A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

1黑马币
本帖最后由 工善器 于 2016-1-24 18:18 编辑


类似于表格、网格线效果经常出现在企业的需求上,今天深圳校区的师生讨论了这个问题,分享出来给大家:


学生问题:
我需要做一个完全的表格,类似正常的excle表格,各个边框都是1px。
老师回答:

方案一:我建议是:使用美工做一个这样的图,文字写在上面。
但是这种方法的缺陷是不能实现动态效果。

方案二:可以采用tablelayout,但是这样的话,边框难以处理。
方案三:

GridView网格布局,默认情况下是没有网格线的

查找网上资料,找到了一种为GridView添加网格线的小技巧

实际上,该网格线是通过设置GridView各子项的间隔,并分别设置GridView背景色与子项背景色实现的。

实现方法

  • 设置GridView背景色,设置水平间方向间隔属性值android:horizontalSpacing和竖直方向间隔属性值android:verticalSpacing
  • 设置GridView子项背景色

可以采用gridview,布局(实现动态效果)
布局:
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <GridView xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:id="@+id/main_GridView"  
  4.     android:horizontalSpacing="2dp"  
  5.     android:verticalSpacing="2dp"  
  6.     android:stretchMode="columnWidth"  
  7.     android:numColumns="3"  
  8.     android:gravity="center"  
  9.     android:listSelector="@null"  
  10.     android:background="#000000"  
  11.     android:layout_width="fill_parent"  
  12.     android:layout_height="fill_parent">  
  13.    
  14. </GridView>
复制代码
acitivity代码:
  1. package com.example.wanggdemo;
  2. import android.app.Activity;  
  3. import android.content.Context;  
  4. import android.graphics.Color;  
  5. import android.os.Bundle;  
  6. import android.view.Gravity;  
  7. import android.view.View;  
  8. import android.view.ViewGroup;  
  9. import android.view.ViewGroup.LayoutParams;  
  10. import android.widget.AbsListView;  
  11. import android.widget.BaseAdapter;  
  12. import android.widget.GridView;  
  13. import android.widget.TextView;  
  14.    
  15. public class MainActivity extends Activity {  
  16.       
  17.     private GridView grid;  
  18.       
  19.     @Override  
  20.     public void onCreate(Bundle savedInstanceState) {  
  21.         super.onCreate(savedInstanceState);  
  22.         setContentView(R.layout.activity_main);  
  23.            
  24.         grid = (GridView) findViewById(R.id.main_GridView);  
  25.         grid.setAdapter(new GridViewAdapter(this));  
  26.     }  
  27.       
  28.     private class GridViewAdapter extends BaseAdapter {  
  29.            
  30.         private Context context;  
  31.            
复制代码


  1.         public GridViewAdapter(Context context) {  
  2.             this.context = context;  
  3.         }  
  4.            
  5.         int count = 100;  
  6.    
  7.         @Override  
  8.         public int getCount() {  
  9.             return count;  
  10.         }  
  11.    
  12.         @Override  
  13.         public Object getItem(int position) {  
  14.             return position;  
  15.         }  
  16.    
  17.         @Override  
  18.         public long getItemId(int position) {  
  19.             return position;  
  20.         }  
  21.    
  22.         @Override  
  23.         public View getView(int position, View convertView, ViewGroup parent) {  
  24.             TextView result = new TextView(context);  
  25.             result.setText("Item "+position);  
  26.             result.setTextColor(Color.BLACK);  
  27.             result.setTextSize(24);  
  28.             result.setLayoutParams(new AbsListView.LayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT)));  
  29.             result.setGravity(Gravity.CENTER);  
  30.             result.setBackgroundColor(Color.WHITE); //设置背景颜色  
  31.             return result;  
  32.         }  
  33.            
  34.     }  
  35. }
复制代码

实现的效果如下图示例:


深圳校区除了全国独有问答网,就业老师面试服务,还有更多神秘惊喜等着你,咨询热线:0755-66689855



972a606800573096e1225a0b896127ba.jpg (10.92 KB, 下载次数: 21)

972a606800573096e1225a0b896127ba.jpg

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马