三步走:第一步初始化gallery时设置较大的初始化位置 Gallery gallery = ((Gallery) findViewById(R.id.myGallery1)); gallery.setAdapter(new ImageAdapter(this)); gallery.setSelection(200); 第二步:重写 BaseAdapter方法中的getCount时返回一个较大的值: // 为了使资源循环使用 public int getCount() { return Integer.MAX_VALUE; } 第三步:重写BaseAdapter时使用用position对集合大小取余的值,如下: /* 取得目前欲显示的图像View,传入数组ID值使之读取与成像 */ public View getView(int position, View convertView, ViewGroup parent) { /* 创建一个ImageView对象 */ ImageView i = new ImageView(this.myContext); i.setPadding(10, 10, 10, 10); i.setAlpha(80); // i.setImageResource(this.myImageIds[position]); if(position<0){ position =position+myImageIds.length; } i.setImageResource(this.myImageIds[position% myImageIds.length]); i.setScaleType(ImageView.ScaleType.FIT_XY); i.setBackgroundResource(mGalleryItemBackground); /* 设置这个ImageView对象的宽高,单位为dip */ i.setLayoutParams(new Gallery.LayoutParams(85, 72)); return i; }
以下是该类的完整代码: /* 依据距离中央的位移量 利用getScale返回views的大小(0.0f to 1.0f) */
- package irdc.ex03_15;
-
- import android.app.Activity;
- import android.content.Context;
- import android.content.res.TypedArray;
- import android.os.Bundle;
- import android.view.View;
- import android.view.ViewGroup;
- import android.widget.AdapterView;
- import android.widget.BaseAdapter;
- import android.widget.Gallery;
- import android.widget.ImageView;
- import android.widget.TextView;
- import android.widget.Toast;
- import android.widget.AdapterView.OnItemSelectedListener;
-
- public class EX03_15 extends Activity
- {
- private TextView mTextView01;
- @Override
- public void onCreate(Bundle savedInstanceState)
- {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
-
- Gallery gallery = ((Gallery) findViewById(R.id.myGallery1));
- gallery.setAdapter(new ImageAdapter(this));
- gallery.setSelection(200);
-
-
- gallery.setOnItemSelectedListener(new OnItemSelectedListener()
- {
-
- public void onItemSelected(AdapterView<?> arg0, View arg1, int arg2,
- long arg3)
- {
- Toast.makeText(EX03_15.this, "当前位置:" + arg2, Toast.LENGTH_SHORT).show();
- }
-
- public void onNothingSelected(AdapterView<?> arg0)
- {
-
- }
- });
- }
-
- public class ImageAdapter extends BaseAdapter
- {
- /* 类成员 myContext为Context父类 */
- private Context myContext;
- /*声明GalleryItemBackground*/
- int mGalleryItemBackground;
-
- /* 使用android.R.drawable里的图片作为图库来源,类型为整数数组 */
- private int[] myImageIds =
- { R.drawable.a1, R.drawable.a2, R.drawable.a3, R.drawable.a4,
- R.drawable.a5, R.drawable.a27 };
-
- /* 构造器只有一个参数,即要存储的Context */
- public ImageAdapter(Context c)
- {
- myContext = c;
-
- /*
- * 使用在res/values/attrs.xml中的<declare-styleable>定义 的Gallery属性.
- */
- TypedArray a = obtainStyledAttributes(R.styleable.Gallery);
-
- /* 取得Gallery属性的Index id */
- mGalleryItemBackground = a.getResourceId(
- R.styleable.Gallery_android_galleryItemBackground, 0);
-
- /* 让对象的styleable属性能够反复使用 */
- a.recycle();
- }
-
- /* 返回所有已定义的图片总数量 */
- // public int getCount() { return this.myImageIds.length; }
- // 为了使资源循环使用
- public int getCount()
- {
- return Integer.MAX_VALUE;
- }
-
- /* 利用getItem方法,取得目前容器中图像的数组ID */
- public Object getItem(int position)
- {
- return position;
- }
-
- public long getItemId(int position)
- {
- return position;
- }
-
- /* 取得目前欲显示的图像View,传入数组ID值使之读取与成像 */
- public View getView(int position, View convertView, ViewGroup parent)
- {
- /* 创建一个ImageView对象 */
- ImageView i = new ImageView(this.myContext);
- i.setPadding(10, 10, 10, 10);
- i.setAlpha(80);
- // i.setImageResource(this.myImageIds[position]);
- if(position<0){
- position =position+myImageIds.length;
- }
- i.setImageResource(this.myImageIds[position% myImageIds.length]);
- i.setScaleType(ImageView.ScaleType.FIT_XY);
- i.setBackgroundResource(mGalleryItemBackground);
- /* 设置这个ImageView对象的宽高,单位为dip */
- i.setLayoutParams(new Gallery.LayoutParams(85, 72));
- return i;
- }
-
- /* 依据距离中央的位移量 利用getScale返回views的大小(0.0f to 1.0f) */
- public float getScale(boolean focused, int offset)
- {
- return Math.max(0, 1.0f / (float) Math.pow(2, Math.abs(offset)));
- }
- }
- }
复制代码
|
相关推荐
UI开发第七篇之Android gallery实现图片的循环旋转UI开发第七篇之Android gallery实现图片的循环旋转
UI开发之Android gallery实现图片的循环旋转 UI开发之Android gallery实现图片的循环旋转 UI开发之Android gallery实现图片的循环旋转 UI开发之Android gallery实现图片的循环旋转
网上大神的文档,我整理了一下并加入一些自己的东西整理成工程共享给大家,内附大神文档,出处忘了,百度一搜全是此大神的文档。...不敢多要分,标准价,不是大神的代码不值分,而是并非原创不敢叫分。
Android Gallery 3张图无限循环 左右滑动都有效
android Gallery实现异步加载网络图片 并只加载当前停止页面图.zip
android Gallery 3d实现无限循环播放 用做广告板最后了 有多种效果 有倒影 能无限循环播放 当滑动到最后的时候 能反过来播放
Android Gallery 自定义ImageView和Gallery实现图片浏览功能,类似Android图库软件,主要实现的功能有:图片左右滑动、放大缩小、放大弹回、缩小弹回。 一开始使用Viewpager实现图片浏览,发现两张图片滑动时没有...
实现网络图片和本地图片循环播放
android Gallery实现异步加载网络图片 并只加载当前停止页面图
android 循环gallery 选中时图片放大 可按钮控制左右 带图片选中时弹出动画效果`
Android3D画廊Gallery实现无限循环、自动跳转、倒影效果,可根据不同情况自己设置图片间间距,从而改变整体间距样式。
Android Gallery 一次一张图片,可以循环显示,可显示当前为第几张图片
android利用gallery 和 imageswitcher 实现画廊图片拖动,并且点击显示相应图片的功能
Android应用源码Gallery实现异步加载网络图片,并只加载当前停止页面
android 4.0 Gallery源码
android gallery的使用 可以 循环 带左右按钮控制 选中时图片放大
可以实现左右循环滑动,并且能够定时切换图片。
1.gallery循环 2.java反射机制获取图片 3.可以从gallery中删除图片 初学必看。。
AndroidTouchGallery 支持双击或双指缩放的Gallery(用ViewPager实现) 相比PhotoView,在被放大后依然能滑到下一个item,并且支持直接从url和文件中获取图片,
基于ImageSwitcher实现图片左右切换,类似ViewFlipper,ViewPager的效果