GridView和SimpleAdapter的结合使用显示图片

今天学习了GridView的使用,和ListView类似都是一种布局容器。下面实现的的是“带预览的图片浏览器”的Demo

带预览的图片浏览器
思路:
1、采用GridView来组织所有图片的预览效果。用ImageSwitch来显示
2、ImageSwitcher要设置一个ImageSwitcher.ViewFactory,并实现makeView()方法,
返回一个人ImageView,ImageSwitcher负责显示ImageView

步骤:
1、在xml文件中设置GridView布局,ImageSwicher组件
2、在MainActivity中定义图片数组id,实例化GridView和ImageSwitcher。
3、为ImageSwitcher设置动画效果。
4、通过SimpleAdapter将图片数组加载到GridView中。
5、为GridView中的图片设置点击预览事件,通过ImageSwitcher显示选中的图片。

xml布局文件:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
    android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity">
<LinearLayout
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical">
    <GridView
        android:id="@+id/image_gridview"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:numColumns="4"
        android:gravity="center"></GridView>
    <ImageView
        android:id="@+id/image1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
    <ImageSwitcher
        android:id="@+id/imageswitcher"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        ></ImageSwitcher>
</LinearLayout>
</RelativeLayout>
MainActivity.java

package lzl.edu.com.gridviewtest;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup;
import android.view.animation.AnimationUtils;
import android.widget.AdapterView;
import android.widget.GridView;
import android.widget.ImageSwitcher;
import android.widget.ImageView;
import android.widget.SimpleAdapter;
import android.widget.ViewSwitcher;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class MainActivity extends Activity {

    public static final String TAG = "MainActivityInfos";
    GridView imagegridview;
    ImageSwitcher imageswitcher;
    ImageView image1;
    int[] imagesId = new int[]{R.mipmap.image1, R.mipmap.image2, R.mipmap.image3,R.mipmap.image4,
            R.mipmap.image5,R.mipmap.image6,R.mipmap.image7,R.mipmap.image8};

    @Override
      protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        init();
    }
    void init(){
        imagegridview = (GridView)findViewById(R.id.image_gridview);
        imageswitcher=(ImageSwitcher)findViewById(R.id.imageswitcher);
        image1 = (ImageView)findViewById(R.id.image1);
        //设置图片切换动画
        imageswitcher.setInAnimation(AnimationUtils.loadAnimation(this, android.R.anim.fade_in));
        imageswitcher.setOutAnimation(AnimationUtils.loadAnimation(this, android.R.anim.fade_out));

        imageswitcher.setFactory(new ViewSwitcher.ViewFactory() {
            @Override
            public View makeView() {
                ImageView imageView = new ImageView(MainActivity.this);
                //设置imageView的属性
                imageView.setBackgroundColor(0xff0000);
                imageView.setScaleType(ImageView.ScaleType.FIT_CENTER);
                imageView.setLayoutParams(new ImageSwitcher.LayoutParams(
                        ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT));
                return imageView;
            }
        });
        setGridViewImages();
    }

    //设置图片到GridView布局中
    void setGridViewImages(){
        /**
         * SimpleAdapter(Context context, List<? extends Map<String, ?>> data, int resource, String[] from, int[] to)
         参数context:上下文,比如this。关联SimpleAdapter运行的视图上下文
         参数data:Map列表,列表要显示的数据,这部分需要自己实现,如例子中的getData(),类型要与上面的一致,每条项目要与from中指定条目一致
         参数resource:ListView单项布局文件的Id,这个布局就是你自定义的布局了,你想显示什么样子的布局都在这个布局中。这个布局中必须包括了to中定义的控件id
         参数 from:一个被添加到Map上关联每一个项目列名称的列表,数组里面是列名称
         参数 to:是一个int数组,数组里面的id是自定义布局中各个控件的id,需要与上面的from对应
         */
        SimpleAdapter simpleAdapter = new SimpleAdapter(this,getData(), R.layout.activity_main,
                new String[]{"image"},new int[]{R.id.image1});
        imagegridview.setAdapter(simpleAdapter);
        //添加列表项被单击的监听器
        imagegridview.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                Log.i(TAG+"--1",""+position);
                Log.i(TAG+"--2",""+position % imagesId.length);
                imageswitcher.setImageResource(imagesId[position]);
            }
        });

        //添加列表项被选中的监听器
        imagegridview.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
            @Override
            public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
                Log.i(TAG+"---3",""+position);
                Log.i(TAG+"---4",""+position%imagesId.length);
                imageswitcher.setImageResource(imagesId[position]);
            }

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

     //将imagesId存储到List集合中
    public List<Map<String,Object>> getData(){
        List<Map<String,Object>> listItems =new ArrayList<Map<String,Object>>();
        for (int i=0;i<imagesId.length;i++) {
            Map<String,Object> maps = new HashMap<String,Object>();
            maps.put("image",imagesId[i]);
            listItems.add(maps);
        }
        return listItems;
    }
}



  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值