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

简介:

 

http://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 ="http://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="http://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 文件中,代码如下:

 

相关文章
|
4月前
|
存储 设计模式 数据库
构建高效的安卓应用:探究Android Jetpack架构组件
【4月更文挑战第20天】 在移动开发的世界中,构建一个既高效又可维护的安卓应用是每个开发者追求的目标。随着Android Jetpack的推出,Google为开发者提供了一套高质量的库、工具和指南,以简化应用程序开发流程。本文将深入探讨Jetpack的核心组件之一——架构组件,并展示如何将其应用于实际项目中,以提升应用的响应性和稳定性。我们将通过分析这些组件的设计原则,以及它们如何协同工作,来揭示它们对于构建现代化安卓应用的重要性。
|
4月前
|
Android开发 算法 架构师
android的基础ui组件,这些知识点你会吗
android的基础ui组件,这些知识点你会吗
android的基础ui组件,这些知识点你会吗
|
4月前
|
Android开发 缓存 双11
android的基础ui组件,Android开发社招面试经验
android的基础ui组件,Android开发社招面试经验
android的基础ui组件,Android开发社招面试经验
|
4月前
|
Java 开发工具 Android开发
如何在Eclipse中查看Android源码或者第三方组件包源码(转)
如何在Eclipse中查看Android源码或者第三方组件包源码(转)
39 4
|
13天前
|
存储 搜索推荐 Java
探索安卓开发中的自定义视图:打造个性化UI组件Java中的异常处理:从基础到高级
【8月更文挑战第29天】在安卓应用的海洋中,一个独特的用户界面(UI)能让应用脱颖而出。自定义视图是实现这一目标的强大工具。本文将通过一个简单的自定义计数器视图示例,展示如何从零开始创建一个具有独特风格和功能的安卓UI组件,并讨论在此过程中涉及的设计原则、性能优化和兼容性问题。准备好让你的应用与众不同了吗?让我们开始吧!
|
12天前
|
XML 搜索推荐 Android开发
安卓开发中的自定义View组件实践
【8月更文挑战第30天】探索Android世界,自定义View是提升应用界面的关键。本文以简洁的语言带你了解如何创建自定义View,从基础到高级技巧,一步步打造个性化的UI组件。
|
21天前
|
开发工具 Android开发
Android项目架构设计问题之组件A通知组件B某个事件的发生如何解决
Android项目架构设计问题之组件A通知组件B某个事件的发生如何解决
27 0
|
2月前
|
机器学习/深度学习 人工智能 算法
探索AI在医疗影像分析中的应用探索安卓开发中的自定义View组件
【7月更文挑战第31天】随着人工智能技术的飞速发展,其在医疗健康领域的应用日益广泛。本文将聚焦于AI技术在医疗影像分析中的运用,探讨其如何通过深度学习模型提高诊断的准确性和效率。我们将介绍一些关键的深度学习算法,并通过实际代码示例展示这些算法是如何应用于医学影像的处理和分析中。文章旨在为读者提供对AI在医疗领域应用的深刻理解和实用知识。
29 0
|
3月前
|
开发工具 Android开发 开发者
Android `.9.png` 图像是用于UI的可拉伸格式,保持元素清晰度和比例
【6月更文挑战第26天】Android `.9.png` 图像是用于UI的可拉伸格式,保持元素清晰度和比例。通过边上的黑线定义拉伸区域,右下角黑点标识内容区域,适应文本或组件大小变化。常用于按钮、背景等,确保跨屏幕尺寸显示质量。Android SDK 提供`draw9patch.bat`工具来创建和编辑。**
218 6
|
3月前
|
API Android开发 开发者
`RecyclerView`是Android API 21引入的UI组件,用于替代ListView和GridView
【6月更文挑战第26天】`RecyclerView`是Android API 21引入的UI组件,用于替代ListView和GridView。它提供高效的数据视图复用,优化的布局管理,支持多种布局(如线性、网格),并解耦数据、适配器和视图。RecyclerView的灵活性、性能(如局部刷新和动画支持)和扩展性使其成为现代Android开发的首选,特别是在处理大规模数据集时。
44 2