如IPhone拖动相片特效(Gallery画廊)

本文介绍如何在Android应用中实现类似iOS的相册拖动效果。通过创建自定义的GalleryAdapter并使用反射来加载资源图片,实现了流畅的图片轮播体验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


如IPhone拖动相片特效(Gallery画廊)

    新建一个继承Activity类的GalleryActivity,并设置布局文件为:gallery.xml。

首先在gallery布局文件中添加一个Gallery组件:

    <Gallery

        android:id="@+id/gallery_g01"

        android:layout_width="fill_parent"

        android:layout_height="wrap_content" />

而后在Activity中获取到这个组件。

而使用Gallery最主要的是为其设置一个适配器,这里我们自己定义一个继承BaseAdapter类的GalleryAdapter类。里面覆写几个父类方法。

package lyx.feng.simpletextdemo;

 

import java.util.List;

 

import android.content.Context;

import android.view.View;

import android.view.ViewGroup;

import android.widget.BaseAdapter;

import android.widget.ImageView;

import android.widget.ImageView.ScaleType;

 

public class GalleryAdapter extends BaseAdapter {

    private List<Integer> images = null;

    private Context mContext = null;

 

    public GalleryAdapter(Context mContext, List<Integer> images) {

       // 在构造方法中初始化属性

       this.images = images;

       this.mContext = mContext;

    }

 

    @Override

    public int getCount() {

       return images.size();

    }

 

    @Override

    public Object getItem(int position) {

       return images.get(position);

    }

 

    @Override

    public long getItemId(int position) {

       return position;

    }

 

    @Override

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

       ImageView imageView = new ImageView(mContext);

       imageView.setImageResource(images.get(position));

       imageView.setScaleType(ScaleType.FIT_XY);

       return imageView;

    }

 

}

 

接下来在主方法中通过反射得到图片:

 

    public List<Integer> getImageResource(String startWith) {

       List<Integer> temp = new ArrayList<Integer>();

       Field fields[] = R.drawable.class.getDeclaredFields();

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

           if (fields[i].getName().startsWith(startWith)) {

              try {

                  temp.add(fields[i].getInt(R.drawable.class));

              } catch (Exception e) {

                  e.printStackTrace();

              }

           }

       }

       return temp;

    }

最后为Gallery设置定义好的适配器

this.gallery = (Gallery) super.findViewById(R.id.gallery_g01);

       this.images = getImageResource("icon_");

       this.gallery.setAdapter(new GalleryAdapter(this, images));

运行结果:


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值