阅读967 返回首页    go 微软 go windows


可循环显示图像的Android Gallery组件

 

https://www.cnblogs.com/nokiaguy/archive/2010/08/23/1806870.html

Gallery组件主要用于横向显示图像列表,不过按常规做法。Gallery组件只能有限地显示指定的图像。也就是说,如果为Gallery组件指定了10张图像,那么当Gallery组件显示到第10张时,就不会再继续显示了。这虽然在大多数时候没有什么关系,但在某些情况下,我们希望图像显示到最后一张时再重第1张开始显示,也就是循环显示。要实现这种风格的Gallery组件,就需要对GalleryAdapter对象进行一番改进。

Gallery组件的传统用法

<!--[endif]-->

     在实现可循环显示图像的Gallery组件之前先来回顾一下Gallery组件的传统用法。Gallery组件可以横向显示一个图像列表,当单击当前图像的后一个图像时,这个图像列表会向左移动一格,当单击当前图像的前一个图像时,这个图像列表会向右移动一样。也可以通过拖动的方式来向左和向右移动图像列表。当前显示的是第1个图像的效果如图1所示。Gallery组件显示到最后一个图像的效果如图2所示。




从图2可以看出,当显示到最后一个图像时,列表后面就没有图像的,这也是Gallery组件的基本显示效果。在本文后面的部分将详细介绍如何使Gallery组件显示到最后一个图像时会从第1个图像开始显示。

好了,现在我们来看一下图1和图2的效果是如何做出来的吧。Gallery既然用于显示图像,那第1步就必须要有一些图像文件用来显示。现在可以随意准备一些图像。在本文的例子中准备了15jpg文件(item1.jpgitem15.jpg)。将这些文件都放在res\drawable目录中。

下面将这些图像的资源ID都保存在int数组中,代码如下:


 private int[] resIds = new int[]
    { R.drawable.item1, R.drawable.item2, R.drawable.item3,        
      R.drawable.item4, R.drawable.item5, R.drawable.item6,      
      R.drawable.item7, R.drawable.item8, R.drawable.item9, 
      R.drawable.item10, R.drawable.item11, R.drawable.item12,
      R.drawable.item13, R.drawable.item14, R.drawable.item15 };
 
在本例的main.xml文件中配置了一个Gallery组件,代码如下:
代码
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="https://schemas.android.com/apk/res/android"
    android:orientation
="vertical" android:layout_width="fill_parent"
    android:layout_height
="fill_parent">
    
<Gallery android:id="@+id/gallery" android:layout_width="fill_parent"
        android:layout_height
="wrap_content" android:layout_marginTop="30dp" />
</LinearLayout>
在本例的main.xml文件中配置了一个Gallery组件,代码如下:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="https://schemas.android.com/apk/res/android"
    android:orientation
="vertical" android:layout_width="fill_parent"
    android:layout_height
="fill_parent">
    
<Gallery android:id="@+id/gallery" android:layout_width="fill_parent"
        android:layout_height
="wrap_content" android:layout_marginTop="30dp" />
</LinearLayout>
 
现在在onCreate方法中装载这个组件,代码如下:
 
public void onCreate(Bundle savedInstanceState)
    {
        
super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        
// 装载Gallery组件
        Gallery gallery = (Gallery) findViewById(R.id.gallery);
        
// 创建用于描述图像数据的ImageAdapter对象
        ImageAdapter imageAdapter = new ImageAdapter(this);
         
// 设置Gallery组件的Adapter对象
        gallery.setAdapter(imageAdapter);
    }

    在上面的代码中涉及到一个非常重要的类:ImageAdapter。该类是android.widget.BaseAdapter的子类,用于描述图像信息。下面先看一下这个类的完整代码。

public class ImageAdapter extends BaseAdapter
    {
        
int mGalleryItemBackground;
        
private Context mContext;

        
public ImageAdapter(Context context)
        {
            mContext 
= context;
              
// 获得Gallery组件的属性
            TypedArray typedArray = obtainStyledAttributes(R.styleable.Gallery);
            mGalleryItemBackground 
= typedArray.getResourceId(
                    R.styleable.Gallery_android_galleryItemBackground, 
0);                        
        }
         
// 返回图像总数
        public int getCount()
        {
            
return resIds.length;
        }
        
public Object getItem(int position)
        {
            
return position;
        }

        
public long getItemId(int position)
        {
            
return position;
        }
         
// 返回具体位置的ImageView对象
        public View getView(int position, View convertView, ViewGroup parent)
        {
            ImageView imageView 
= new ImageView(mContext);
             
// 设置当前图像的图像(position为当前图像列表的位置)
            imageView.setImageResource(resIds[position]);
            imageView.setScaleType(ImageView.ScaleType.FIT_XY);
            imageView.setLayoutParams(
new Gallery.LayoutParams(163106));
            
// 设置Gallery组件的背景风格
            imageView.setBackgroundResource(mGalleryItemBackground);
            
return imageView;
        }
    }

 

在编写ImageAdapter类时应注意的两点:

1. ImageAdapter类的构造方法中获得了Gallery组件的属性信息。这些信息被定义在res\values\attrs.xml文件中,代码如下:

 

最后更新:2017-04-02 06:51:59

  上一篇:go Java基础小技巧回顾--浅析String
  下一篇:go java.lang.UnsatisfiedLinkError: Can&#39;t load library from JNI code