1. 创建一个activity,命名为:GridViewActivity,如下:

public class GridViewActivity extends AppCompatActivity {
    private static final String TAG  = "GridViewActivity";
    private GridView gv_planet;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_grid_view);
        ArrayList<Planet> planetList = Planet.getDefaultList();
        PlanetGridAdapter adapter = new PlanetGridAdapter(this, planetList);
        gv_planet = findViewById(R.id.gv_planet);
        gv_planet.setAdapter(adapter);
        gv_planet.setOnItemClickListener(adapter);
        gv_planet.setOnItemLongClickListener(adapter);
        initDividerSpinner();
    }

    private void initDividerSpinner() {
        ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, R.layout.item_select, dividerArr);
        Spinner sp = findViewById(R.id.sp_grid);
        sp.setPrompt("请选择分割线显示方式");
        sp.setAdapter(adapter);
        sp.setOnItemSelectedListener(new DividerSelectedListener());
    }

    private String[] dividerArr = {
            "不显示分隔线",
            "只显示内部分隔线(NO_STRETCH)",
            "只显示内部分隔线(COLUMN_WIDTH)",
            "只显示内部分隔线(STRETCH_SPACING)",
            "只显示内部分隔线(SPACING_UNIFORM)",
            "显示全部分隔线(看我用padding大法)"
    };

    class DividerSelectedListener implements AdapterView.OnItemSelectedListener {

        @Override
        public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
            int dividerPad = Utils.dip2px(GridViewActivity.this, 5);
            gv_planet.setBackgroundColor(Color.RED);
            gv_planet.setHorizontalSpacing(dividerPad);
            gv_planet.setVerticalSpacing(dividerPad);
            gv_planet.setStretchMode(GridView.STRETCH_COLUMN_WIDTH);
            gv_planet.setColumnWidth(Utils.dip2px(GridViewActivity.this, 120)); // 设置每列宽度为120dp
            gv_planet.setPadding(0, 0, 0, 0);
            switch (position) {
                case 0: {
                    gv_planet.setBackgroundColor(Color.WHITE);
                    gv_planet.setHorizontalSpacing(0);
                    gv_planet.setVerticalSpacing(0);
                }
                    break;

                case 1:
                    gv_planet.setStretchMode(GridView.NO_STRETCH); // 不拉伸
                    break;

                case 2:
                    gv_planet.setStretchMode(GridView.STRETCH_COLUMN_WIDTH); // 有剩余空间,拉伸列宽
                    break;

                case 3:
                    gv_planet.setStretchMode(GridView.STRETCH_SPACING); // 有剩余空间,列宽不变,空间给每列间的空隙
                    break;

                case 4:
                    gv_planet.setStretchMode(GridView.STRETCH_SPACING_UNIFORM); // 有剩余空间,列宽不变,空间给每列左右的空隙
                    break;

                case 5:
                    gv_planet.setPadding(dividerPad, dividerPad, dividerPad, dividerPad);
                    break;
            }
        }

        @Override
        public void onNothingSelected(AdapterView<?> parent) {

        }
    }
}

2. GridViewActivity对应的布局文件为:activity_grid_view,如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:padding="10dp"
    android:orientation="vertical">

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="40dp">

        <TextView
            android:id="@+id/tv_type"
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:gravity="center"
            android:text="分割线显示"
            android:textColor="@color/black"
            android:textSize="17sp" />

        <Spinner
            android:id="@+id/sp_grid"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:spinnerMode="dialog"
            android:layout_toRightOf="@id/tv_type" />
    </RelativeLayout>

    <GridView
        android:id="@+id/gv_planet"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:horizontalSpacing="5dp"
        android:verticalSpacing="5dp"
        android:numColumns="2"
        android:stretchMode="columnWidth"
        android:background="@color/orange"/>

</LinearLayout>

3. 创建一个适配器命名为PlanetGridAdapter ,继承于 BaseAdapter,如下:

public class PlanetGridAdapter extends BaseAdapter implements AdapterView.OnItemLongClickListener, AdapterView.OnItemClickListener {
    private Context mContext;
    private ArrayList<Planet> mPlanetList;

    public PlanetGridAdapter(Context context, ArrayList<Planet> arrayList) {
        mContext = context;
        mPlanetList = arrayList;
    }

    @Override
    public int getCount() {
        return mPlanetList.size();
    }

    @Override
    public Object getItem(int position) {
        return mPlanetList.get(position);
    }

    @Override
    public long getItemId(int position) {
        return position;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        ViewHolder holder;
        if (convertView == null) {
            holder = new ViewHolder();
            convertView = LayoutInflater.from(mContext).inflate(R.layout.item_grid, null);
            holder.tv_name = convertView.findViewById(R.id.tv_name);
            holder.iv_icon = convertView.findViewById(R.id.iv_icon);
            holder.tv_desc = convertView.findViewById(R.id.tv_desc);
            convertView.setTag(holder);
        } else {
            holder = (ViewHolder)convertView.getTag();
        }
        setModel(holder, mPlanetList.get(position));
        return convertView;
    }

    private void setModel(ViewHolder holder, Planet info) {
        holder.tv_name.setText(info.name);
        holder.iv_icon.setImageResource(info.image);
        holder.tv_desc.setText(info.desc);
    }

    @Override
    public boolean onItemLongClick(AdapterView<?> parent, View view, int position, long id) {
        ToastUtil.showToast(mContext, String.format("您长按了第%d个行星,她的名字是%s",position + 1,mPlanetList.get(position).name));
        return true;
    }

    @Override
    public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
        ToastUtil.showToast(mContext, String.format("您点击了第%d个行星,她的名字是%s",position + 1,mPlanetList.get(position).name));
    }

    final class ViewHolder {
        TextView tv_name;
        ImageView iv_icon;
        TextView tv_desc;
    }

}

4. PlanetGridAdapter 中用到的布局文件为:item_grid,如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:background="@color/white"
    android:layout_height="match_parent">

    <TextView
        android:id="@+id/tv_name"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="水星"
        android:gravity="center"
        android:textSize="20sp"
        android:textColor="@color/black" />

    <ImageView
        android:id="@+id/iv_icon"
        android:layout_width="match_parent"
        android:layout_height="100dp"
        android:src="@drawable/shuixing"
        android:scaleType="fitCenter" />

    <TextView
        android:id="@+id/tv_desc"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="我是一个小水星"
        android:textColor="@color/contentGray"
        android:textSize="13sp" />

</LinearLayout>

5. PlanetGridAdapter 中用到的模型为Planet,如下:

public class Planet {
    public int image;
    public String name;
    public String desc;

    public Planet(int image, String name, String desc) {
        this.image = image;
        this.name = name;
        this.desc = desc;
    }

    private static int[] iconArray = {R.drawable.shuixing, R.drawable.jinxing, R.drawable.diqiu,
            R.drawable.huoxing, R.drawable.muxing, R.drawable.tuxing};
    private static String[] nameArray = {"水星", "金星", "地球", "火星", "木星", "土星"};
    private static String[] descArray = {
            "水星是太阳系八大行星最内侧也是最小的一颗行星,也是离太阳最近的行星",
            "金星是太阳系八大行星之一,排行第二,距离太阳0.725天文单位",
            "地球是太阳系八大行星之一,排行第三,也是太阳系中直径、质量和密度最大的类地行星,距离太阳1.5亿公里",
            "火星是太阳系八大行星之一,排行第四,属于类地行星,直径约为地球的53%",
            "木星是太阳系八大行星中体积最大、自转最快的行星,排行第五。它的质量为太阳的千分之一,但为太阳系中其它七大行星质量总和的2.5倍",
            "土星为太阳系八大行星之一,排行第六,体积仅次于木星"
    };

    public static ArrayList<Planet> getDefaultList() {
        ArrayList<Planet> planetList = new ArrayList<Planet>();
        for (int i = 0; i < nameArray.length; i++) {
            planetList.add(new Planet(iconArray[i], nameArray[i], descArray[i]));
        }
        return planetList;
    }
}

6. 效果如下:

  • 第一张图是:不显示分隔线
  • 第二张图是:只显示内部分隔线(NO_STRETCH)
  • 第三张图是:只显示内部分隔线(COLUMN_WIDTH)
  • 第一张图是:只显示内部分隔线(STRETCH_SPACING)
  • 第二张图是:只显示内部分隔线(SPACING_UNIFORM)
  • 第三张图是:显示全部分隔线(看我用padding大法)