android 合并单元格,Android GridView 实现合并单元格效果

package com.example.test;

import android.app.Activity;

import android.content.Context;

import android.graphics.Color;

import android.os.Bundle;

import android.view.Gravity;

import android.view.View;

import android.view.ViewGroup;

import android.widget.AbsListView;

import android.widget.BaseAdapter;

import android.widget.GridView;

import android.widget.LinearLayout;

import android.widget.TextView;

public class MainActivity extends Activity {

private static GridView mGridView;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

mGridView = new GridView(getApplicationContext());

MAdapter adapter = new MAdapter(mGridView.getContext(), new String[]{

"你好1","你好2","你好3","你好4","你好5","你好6","你好7","你好8","你好9","你好10",

"你好11","你好12","你好13","你好14","你好15","你好16","你好17","你好18","你好19","你好20",

"你好21","你好22","你好23","你好24","你好25","你好26","你好27","你好28","你好29","你好30"

});

LinearLayout headLayout = new LinearLayout(getApplicationContext());

LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(

LinearLayout.LayoutParams.FILL_PARENT, 300);

headLayout.setLayoutParams(params);

headLayout.setBackgroundColor(Color.RED);

mGridView.setAdapter(adapter);

mGridView.setNumColumns(2);

setContentView(mGridView);

}

static class MAdapter extends BaseAdapter{

private String[] items;

private Context context;

public MAdapter(Context context, String[] items) {

this.items = items;

this.context = context;

}

@Override

public int getCount() {

return items.length;

}

@Override

public Object getItem(int position) {

return position;

}

@Override

public long getItemId(int position) {

return position;

}

@Override

public int getItemViewType(int position) {

return super.getItemViewType(position);

}

@Override

public View getView(int position, View convertView, ViewGroup parent) {

TextView textView = null;

if (position %4 == 0) {

textView = new MyText(context);

AbsListView.LayoutParams params = new AbsListView.LayoutParams(

AbsListView.LayoutParams.FILL_PARENT, 100);

textView.setLayoutParams(params);

textView.setTextColor(Color.BLACK);

textView.setTextSize(20);

textView.setText(items[position]);

textView.setBackgroundColor(0x88FF0000);

textView.setGravity(Gravity.LEFT | Gravity.CENTER_VERTICAL);

} else {

textView = new TextView(context);

AbsListView.LayoutParams params = new AbsListView.LayoutParams(

AbsListView.LayoutParams.FILL_PARENT, 200);

textView.setLayoutParams(params);

textView.setTextColor(Color.BLACK);

textView.setTextSize(20);

textView.setText(items[position]);

textView.setVisibility(View.VISIBLE);

if (position %4 == 1) {// GridView的行高由该行最后一个元素的高度决定

AbsListView.LayoutParams params2 = new AbsListView.LayoutParams(

AbsListView.LayoutParams.FILL_PARENT, 100);

textView.setLayoutParams(params2);

textView.setVisibility(View.INVISIBLE);

}

textView.setGravity(Gravity.CENTER);

}

return textView;

}

class MyText extends TextView {

public MyText(Context context) {

super(context);

}

@Override

protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {

super.onMeasure(widthMeasureSpec, heightMeasureSpec);

int targetWidth = mGridView.getMeasuredWidth()

- mGridView.getPaddingLeft()

- mGridView.getPaddingRight();

widthMeasureSpec = MeasureSpec.makeMeasureSpec(targetWidth,

MeasureSpec.getMode(widthMeasureSpec));

super.onMeasure(widthMeasureSpec, heightMeasureSpec);

}

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的 Android GridView 实现的示例代码: 首先,在你的布局文件中添加 GridView 组件: ``` <GridView android:id="@+id/gridView" android:layout_width="match_parent" android:layout_height="match_parent" android:numColumns="3" android:verticalSpacing="10dp" android:horizontalSpacing="10dp" android:padding="10dp" android:stretchMode="columnWidth" /> ``` 这个示例中,我们设置了 GridView 的 id、宽高、列数、垂直和水平间距、内边距和列宽拉伸方式。 接着,在你的 Activity 或 Fragment 中获取 GridView 并设置适配器: ``` GridView gridView = findViewById(R.id.gridView); gridView.setAdapter(new MyAdapter(this)); ``` 这个示例中,我们创建了一个 MyAdapter 类,并将这个适配器设置给 GridView。 最后,实现 MyAdapter 类来为 GridView 提供数据和布局: ``` public class MyAdapter extends BaseAdapter { private Context mContext; private Integer[] mThumbIds = { R.drawable.image1, R.drawable.image2, R.drawable.image3, R.drawable.image4, R.drawable.image5, R.drawable.image6, R.drawable.image7, R.drawable.image8, R.drawable.image9 }; public MyAdapter(Context context) { mContext = context; } public int getCount() { return mThumbIds.length; } public Object getItem(int position) { return mThumbIds[position]; } public long getItemId(int position) { return 0; } public View getView(int position, View convertView, ViewGroup parent) { ImageView imageView; if (convertView == null) { imageView = new ImageView(mContext); imageView.setLayoutParams(new GridView.LayoutParams(350, 350)); imageView.setScaleType(ImageView.ScaleType.CENTER_CROP); } else { imageView = (ImageView) convertView; } imageView.setImageResource(mThumbIds[position]); return imageView; } } ``` 这个示例中,我们向适配器提供了一个图片资源数组,并将其作为数据源。然后,我们在 getView() 方法中绑定了每个图片的资源 ID 到 ImageView 中,并设置了它们的布局参数和缩放类型。 以上就是一个简单的 Android GridView 实现的示例代码,你可以根据自己的需求进行修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值