http://www.eoeandroid.com/viewthread.php?tid=12007&highlight=gall
三步走:第一步初始化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中删除图片 初学必看。。
Android利用Gallery和ImageSwitcher实现在线相册图片预览功能(异步加载图片)
AndroidTouchGallery 支持双击或双指缩放的Gallery(用ViewPager实现) 相比PhotoView,在被放大后依然能滑到下一个item,并且支持直接从url和文件中获取图片,