`
zhouxin464585932
  • 浏览: 81546 次
  • 性别: Icon_minigender_1
  • 来自: 南京
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

Android gallery实现图片的左右循环旋转源码分享

阅读更多

Android gallery实现图片的左右循环旋转源码分享

三步走:第一步初始化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) */
  1. package irdc.ex03_15;
  2. import android.app.Activity;
  3. import android.content.Context;
  4. import android.content.res.TypedArray;
  5. import android.os.Bundle;
  6. import android.view.View;
  7. import android.view.ViewGroup;
  8. import android.widget.AdapterView;
  9. import android.widget.BaseAdapter;
  10. import android.widget.Gallery;
  11. import android.widget.ImageView;
  12. import android.widget.TextView;
  13. import android.widget.Toast;
  14. import android.widget.AdapterView.OnItemSelectedListener;
  15. public class EX03_15 extends Activity
  16. {
  17. private TextView mTextView01;
  18. @Override
  19. public void onCreate(Bundle savedInstanceState)
  20. {
  21. super.onCreate(savedInstanceState);
  22. setContentView(R.layout.main);
  23. Gallery gallery = ((Gallery) findViewById(R.id.myGallery1));
  24. gallery.setAdapter(new ImageAdapter(this));
  25. gallery.setSelection(200);
  26. gallery.setOnItemSelectedListener(new OnItemSelectedListener()
  27. {
  28. public void onItemSelected(AdapterView<?> arg0, View arg1, int arg2,
  29. long arg3)
  30. {
  31. Toast.makeText(EX03_15.this, "当前位置:" + arg2, Toast.LENGTH_SHORT).show();
  32. }
  33. public void onNothingSelected(AdapterView<?> arg0)
  34. {
  35. }
  36. });
  37. }
  38. public class ImageAdapter extends BaseAdapter
  39. {
  40. /* 类成员 myContext为Context父类 */
  41. private Context myContext;
  42. /*声明GalleryItemBackground*/
  43. int mGalleryItemBackground;
  44. /* 使用android.R.drawable里的图片作为图库来源,类型为整数数组 */
  45. private int[] myImageIds =
  46. { R.drawable.a1, R.drawable.a2, R.drawable.a3, R.drawable.a4,
  47. R.drawable.a5, R.drawable.a27 };
  48. /* 构造器只有一个参数,即要存储的Context */
  49. public ImageAdapter(Context c)
  50. {
  51. myContext = c;
  52. /*
  53. * 使用在res/values/attrs.xml中的<declare-styleable>定义 的Gallery属性.
  54. */
  55. TypedArray a = obtainStyledAttributes(R.styleable.Gallery);
  56. /* 取得Gallery属性的Index id */
  57. mGalleryItemBackground = a.getResourceId(
  58. R.styleable.Gallery_android_galleryItemBackground, 0);
  59. /* 让对象的styleable属性能够反复使用 */
  60. a.recycle();
  61. }
  62. /* 返回所有已定义的图片总数量 */
  63. // public int getCount() { return this.myImageIds.length; }
  64. // 为了使资源循环使用
  65. public int getCount()
  66. {
  67. return Integer.MAX_VALUE;
  68. }
  69. /* 利用getItem方法,取得目前容器中图像的数组ID */
  70. public Object getItem(int position)
  71. {
  72. return position;
  73. }
  74. public long getItemId(int position)
  75. {
  76. return position;
  77. }
  78. /* 取得目前欲显示的图像View,传入数组ID值使之读取与成像 */
  79. public View getView(int position, View convertView, ViewGroup parent)
  80. {
  81. /* 创建一个ImageView对象 */
  82. ImageView i = new ImageView(this.myContext);
  83. i.setPadding(10, 10, 10, 10);
  84. i.setAlpha(80);
  85. // i.setImageResource(this.myImageIds[position]);
  86. if(position<0){
  87. position =position+myImageIds.length;
  88. }
  89. i.setImageResource(this.myImageIds[position% myImageIds.length]);
  90. i.setScaleType(ImageView.ScaleType.FIT_XY);
  91. i.setBackgroundResource(mGalleryItemBackground);
  92. /* 设置这个ImageView对象的宽高,单位为dip */
  93. i.setLayoutParams(new Gallery.LayoutParams(85, 72));
  94. return i;
  95. }
  96. /* 依据距离中央的位移量 利用getScale返回views的大小(0.0f to 1.0f) */
  97. public float getScale(boolean focused, int offset)
  98. {
  99. return Math.max(0, 1.0f / (float) Math.pow(2, Math.abs(offset)));
  100. }
  101. }
  102. }
复制代码
分享到:
评论

相关推荐

    Android Gellary3D 源码

    **Android Gellary3D 源码解析*...通过深入研究Android Gellary3D的源代码,开发者可以学习到如何在Android平台上实现高效的3D图形渲染、数据加载优化、UI设计以及多线程编程,这对于提升Android应用开发技能大有裨益。

    Android应用源码模拟立体翻转效果,非Gallery实现.zip

    标题中的"Android应用源码模拟立体翻转效果,非Gallery实现.zip" 提供了一个源码示例,它展示了如何在不使用内置的Gallery组件的情况下,实现一个立体翻转效果。Gallery组件在较旧版本的Android API中被用于展示图像...

    Android自定义带倒影和偏转的超炫Gallery

    本文将详细探讨如何实现一个"Android自定义带倒影和偏转的超炫Gallery",该Gallery组件能展示出极具视觉冲击力的效果。 首先,让我们了解一下Android中的Gallery组件。Gallery是Android提供的一个特殊的视图,它...

    仿安卓市场广告条(中心条目放大且无限循环的gallery)

    项目中的"ZKtest48_CirculateGallery"很可能包含了实现这个功能的所有源代码和资源文件。开发者可以深入研究这些代码,理解如何创建自定义的Gallery,以及如何实现无限循环和中心放大效果。这有助于提升Android UI...

    Android改进版CoverFlow效果控件无限循环

    在原生Android SDK中,并没有内置的CoverFlow控件,因此需要通过自定义ViewGroup,如Gallery或HorizontalScrollView来实现。这个改进版的控件可能是在此基础上进行了优化,解决了原始实现中可能存在的性能问题,并...

    Android2.3 3D系统图库源码

    7. **界面设计**:Gallery3D的UI设计简洁明了,源码中包含了XML布局文件和自定义控件,展示了如何在Android中实现3D视图和动画效果。 总的来说,通过分析Android 2.3的3D系统图库源码,我们可以学习到如何利用...

    3DGallery无限自动循环+倒影效果

    【3D Gallery无限自动循环+倒影效果】是一款专为Android平台设计的图像展示应用,它结合了3D视觉效果和动态循环播放功能,同时增加了图片的倒影特效,为用户带来独特的视觉体验。这款应用在Android开发领域具有较高...

    android 3D效果

    文件"mainbeijing.png"可能是3D场景中的一个纹理资源,而"android_effects-master"可能是一个包含3D效果实现的Android项目源码。通过分析这些文件,开发者可以学习到具体的实现细节,如纹理加载、3D模型构建以及动画...

Global site tag (gtag.js) - Google Analytics