GridView实现一个图片加多个文本框

GridView的使用是很简单的,API Demo中有例子,但是要实现复杂的GridView,就需要自定义了。

今天我们要实现如下的效果:

先说它的布局,它是由gridview和grid_item两部分组成。

main.xml

 

<?xml version="1.0" encoding="utf-8"?>

<GridView xmlns:android="http://schemas.android.com/apk/res/android"

android:id="@+id/gridview"

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:columnWidth="90dp"

android:numColumns="auto_fit"

android:verticalSpacing="10dp"

android:horizontalSpacing="10dp"

android:stretchMode="columnWidth"

android:gravity="center"

/>

grid_item.xml

 

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

android:layout_width="fill_parent" android:layout_height="fill_parent"

android:orientation="vertical"

android:layout_marginTop="5dp"

>

<ImageView android:id="@+id/image" android:layout_width="80dip"

android:layout_height="80dip" android:layout_gravity="center_horizontal">

</ImageView>

<TextView android:id="@+id/title" android:layout_width="wrap_content"

android:layout_height="wrap_content" android:layout_gravity="left"

android:textSize="16dip"

android:gravity="left">

</TextView>

<TextView android:id="@+id/description" android:layout_width="wrap_content"

android:layout_height="wrap_content" android:layout_gravity="left"

android:textColor="#938192"

android:textSize="13dip"

android:gravity="left"

>

</TextView>

</LinearLayout>

接下来我们要新写一个继承自BaseAdapter类的Adapter类,在这里做grid item的适配。

由于我们每个grid item是一个图片加两个文本框,就需要有一个容器类:

class GridItem

{

private String title;

private int imageId;

private String description;

public GridItem()

{

super();

}

public GridItem(String title, int imageId,String time)

{

super();

this.title = title;

this.imageId = imageId;

this.description = time;

}

public String getTime( )

{

return description;

}

public String getTitle()

{

return title;

}

public int getImageId()

{

return imageId;

}

}

再来个Viewholder

static class ViewHolder

{

public ImageView image;

public TextView title;

public TextView time;

}

接下来的Adapter的实现就顺理成章了。GridItemAdapter

import java.util.ArrayList;

import java.util.List;

import android.content.Context;

import android.view.LayoutInflater;

import android.view.View;

import android.view.ViewGroup;

import android.widget.BaseAdapter;

import android.widget.ImageView;

import android.widget.TextView;

public class GridItemAdapter extends BaseAdapter

{

private LayoutInflater inflater;

private List<GridItem> gridItemList;

public GridItemAdapter(String[] titles, int[] images,String[] description, Context context)

{

super();

gridItemList = new ArrayList<GridItem>();

inflater = LayoutInflater.from(context);

for (int i = 0; i < images.length; i++)

{

GridItem picture = new GridItem(titles[i], images[i],description[i]);

gridItemList.add(picture);

}

}

@Override

public int getCount( )

{

if (null != gridItemList)

{

return gridItemList.size();

}

else

{

return 0;

}

}

@Override

public Object getItem( int position )

{

return gridItemList.get(position);

}

@Override

public long getItemId( int position )

{

return position;

}

@Override

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

{

ViewHolder viewHolder;

if (convertView == null)

{

convertView = inflater.inflate(R.layout.grid_item, null);

viewHolder = new ViewHolder();

viewHolder.title = (TextView) convertView.findViewById(R.id.title);

viewHolder.image = (ImageView) convertView.findViewById(R.id.image);

viewHolder.time = (TextView) convertView.findViewById(R.id.description);

convertView.setTag(viewHolder);

} else

{

viewHolder = (ViewHolder) convertView.getTag();

}

viewHolder.title.setText(gridItemList.get(position).getTitle());

viewHolder.time.setText(gridItemList.get(position).getTime());

viewHolder.image.setImageResource(gridItemList.get(position).getImageId());

return convertView;

}

在activity中调用如下:

 

package com.linc.gridview;

import android.app.Activity;

import android.os.Bundle;

import android.view.View;

import android.widget.AdapterView;

import android.widget.GridView;

import android.widget.Toast;

import android.widget.AdapterView.OnItemClickListener;

public class CustomGridViewActivity extends Activity {

private GridView gridView;

//图片的第一行文字

private String[] titles = new String[]

{ "美女卷珠帘", "美女回眸", "美女很有趣", "美女醉酒", "美女微笑", "美女如脱兔", "美女柳叶弯眉"};

//图片的第二行文字

private String[] description = new String[]

{ "啦啦啦", "嘎嘎嘎", "哇哇哇", "喵喵喵", "刚刚刚", "当当当", "咔咔咔"};

//图片ID数组

private int[] images = {

R.drawable.five, R.drawable.sample_7,

R.drawable.one, R.drawable.three,

R.drawable.sample_3, R.drawable.sample_7,

R.drawable.sample_0 };

/** Called when the activity is first created. */

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

gridView = (GridView) findViewById(R.id.gridview);

GridItemAdapter adapter = new GridItemAdapter(titles, images,description,this);

gridView.setAdapter(adapter);

gridView.setOnItemClickListener(new OnItemClickListener()

{

@Override

public void onItemClick(AdapterView<?> parent, View v, int position, long id)

{

Toast.makeText(CustomGridViewActivity.this, "item" + (position+1), Toast.LENGTH_SHORT).show();

}

});

}

}

这样就可以了,

此实现与ListView类似,熟练使用会带来很好的用户体验。

时间: 2025-01-01 08:01:27

GridView实现一个图片加多个文本框的相关文章

Canvas---Canvas图像加载、利用javascript回调机制实现一个图片加载器

canvas的drawImage方法有个缺点,就是当图片还未加载完成时调用它将无效. 当然,在高速运转的游戏主循环中,可以直接忽略这个问题,或者用 img.complete == true来做下判断. 在游戏循环之外的地方,可以用 img.onload = function (){};这样的回调解决. 但是,如果需要实现预先大量图片的加载,并且将加载进度告知用户,这时就需要一个图片加载器. 一.图片加载器原理 1.对于每张图片,开启对应的一个线程去负责加载,加载完成后修改一个变量的值-loade

ASP.NET中页面加载时文本框(texbox控件)内有文字获得焦点时文字消失

代码如下: <asp:TextBox ID="TextBox1" runat="server" Height="26px" MaxLength="10" Width="166px" Text="请输入用户名" OnFocus="javascript:if(this.value=='请输入用户名') {this.value='';this.style.color='#000

json解析+GridView自适应布局+图片加载

如何规范化的完成一个需要网络加载数据的页面? 先来看一下效果图 1.Json数据获取解析 查看Json数据,这里推荐使用chrome自带扩展程序JSONView:Validate and view JSON documents,但是可能需要翻墙,如下所示: 准备好工具了,我们接下来看我们如何实现对数据的json解析,假设我们需要的数据来源为: public class UrlContainer { public static final String HOST_URL = "http://sea

一起写一个Android图片加载框架

本文会从内部原理到具体实现来详细介绍如何开发一个简洁而实用的Android图片加载缓存框架,并在内存占用与加载图片所需时间这两个方面与主流图片加载框架之一Universal Image Loader做出比较,来帮助我们量化这个框架的性能.通过开发这个框架,我们可以进一步深入了解Android中的Bitmap操作.LruCache.LruDiskCache,让我们以后与Bitmap打交道能够更加得心应手.若对Bitmap的大小计算及inSampleSize计算还不太熟悉,请参考这里:高效加载Bit

实现一个图片懒加载插件

实现一个图片懒加载插件-转 Web 图片的懒加载就是通过读取img元素,然后获得img元素的data-src(也可以约定为其他属性名)属性的值,并赋予img的src,从而实现动态加载图片的机制. 这里需要注意的是: img在初始化的时候不要设置src属性,因为即使设置 src='' 浏览器也会尝试加载图片. 一个简单的图片懒加载共涉及两个方面, 1. HTML 约定 我们首先需要给准备实施懒加载的img元素添加指定的class 这里为m-lazyload ,同时将img src赋值给 data-

关于图片加载非常爽的一个三方控件 fresco

Hi  EveryBody 今天来玩一个非常爽的控件 fresco 到底有多爽呢 接着看就知道了 首先 来看看fresco 是个神马东西 https://github.com/facebook/fresco 这个是fresco的一个官方gifhub 官网为http://frescolib.org/ 这个网站是个英文站点 对英文不太精通的童鞋也没关系啦 因为这就是一个图片加载库 我们说传统的加载库 从自己写一个BitMap类的工具 到软引用 到ImageLoader这些无非是解决一个oom问题 但

图片加载框架之ImageLoader

Android开发中,多少会接触到异步加载图片,或者加载大量图片的问题,而加载图片我们常常会遇到许多的问题,比如说图片的错乱,OOM等问题,对于这些问题解决起来会比较吃力,比较著名的就是Universal-Image-Loader,该项目可以在于Github搜索到. 特征: 多线程下载图片,图片可以来源于网络,文件系统,项目文件夹assets中以及drawable中等 支持随意的配置ImageLoader,例如线程池,图片下载器,内存缓存策略,硬盘缓存策略,图片显示选项以及其他的一些配置 支持图

LrcCache和DiskLruCache相结合打造图片加载框架

LrcCache和DiskLruCache相结合打造图片加载框架 1概述 这几在研究图片加载的方面的知识,在网上看了一下前辈们写的文章,受到了一些启发,于是综合多方面的知识,将这些整合起来,自己边写了一个图片加载框架.说到图片加载最容易出问题的就是OOM就是内存溢出,所以一定要限制加载图片时使用的内存,这就使用到Android提供的缓存类LruCache,关于LruCache的知识这里不再赘述,大家自行学习.但是如果图片非常的多而且频繁操作的话,加上LruCache的缓存空间有限,缓存就不得不经

给图片加ALT属性是个什么意思?有什么好处呢

使用百度统计的seo建议其中一条图片ALT信息"存在没有alt信息的img标签"扣分较多.网站图片中添加ALT对seo有什么好处呢?这是很多初学seo的朋友们都需要询问的问题.alt标签是什么?厦门SEO给大家介绍一下 一种利用图片进行SEO的方法就是在这些图片的img标签中使用alt标签.HTML标签中的alt标签用于显示图片的替换文本信息.alt标签应该是对图片的简短介绍,同时应该尽可能的包含当前网页的关键字. alt标签曾经被部分站长滥用,在alt标签中写上大量的关键词,而并非对