Gallery用法之百家姓显示

package com.example.testgallary;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import android.os.Bundle;
import android.app.Activity;
import android.content.Context;
import android.graphics.Color;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.BaseAdapter;
import android.widget.Gallery;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;
public class MainActivity extends Activity implements OnItemClickListener{
private Gallery mGallery;
private MyAdapter adapter;
private List> data = null;
private List> list;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mGallery = (Gallery) findViewById(R.id.gallery1);
data = getData();// 获取数据
adapter = new MyAdapter(this);
mGallery.setAdapter(adapter);
mGallery.setOnItemClickListener(this);
}
private List> getData(){
list = new ArrayList>();
Map map;
for(int i=0; i();
map.put("title", str[i]);
list.add(map);
}
return list;
}
// ViewHolder静态类
static class ViewHolder {
public TextView title;
}
public class MyAdapter extends BaseAdapter {
private LayoutInflater mInflater = null;
private MyAdapter(Context context) {
// 根据context上下文加载布局
this.mInflater = LayoutInflater.from(context);
}
@Override
public int getCount() {
// 在此适配器中所代表的数据集中的条目数
return data.size();
}
@Override
public Object getItem(int position) {
// 获取数据集中与指定索引对应的数据项
return position;
}
@Override
public long getItemId(int position) {
// 获取在列表中与指定索引对应的行id
return position;
}
// 获取一个在数据集中指定索引的视图来显示数据
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = null;
// 如果缓存convertView为空,则需要创建View
if (convertView == null) {
holder = new ViewHolder();
// 根据自定义的Item布局加载布局
convertView = mInflater.inflate(R.layout.list_item, null);
holder.title = (TextView) convertView.findViewById(R.id.title);
holder.title.setTextSize(32);
// 将设置好的布局保存到缓存中,并将其设置在Tag里,以便后面方便取出Tag
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
holder.title.setText((String) data.get(position).get("title"));
holder.title.setTextColor(Color.BLACK);//
return convertView;
}
}
@Override
public void onItemClick(AdapterView arg0, View arg1, int arg2, long arg3) {
Toast.makeText(MainActivity.this, data.get(arg2).get("title").toString(), Toast.LENGTH_SHORT).show();
}
String[] str = {"李","王","孙","杜","赵","吴","陆","杨","侯","屈","宋","周","张","陈","冯",
"朱","蒋","沈","韩","秦","许","何","吕","孔","诸葛","夏侯"};
}

//activity_main layout布局文件

创新互联主要从事成都做网站、网站设计、网页设计、企业做网站、公司建网站等业务。立足成都服务兰坪,十载网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:18982081108


    

//list_item.xml



    
http://670176656.blog.51cto.com/addblog.php

标题名称:Gallery用法之百家姓显示
链接URL:http://csdahua.cn/article/pgiphd.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流