Android实现幻灯片式图片浏览器

所属分类: 软件编程 / Android 阅读数: 32
收藏 0 赞 0 分享

我们来实现一个幻灯片式图片浏览器:

最下面一个画廊视图,选中画廊中的图片,会在上面的ImageSwitcher控件中显示大图。

效果图如图


实现方法:

在布局文件中添加图片切换控件ImageSwitcher和画廊视图控件Gallery
res/layout/main.xml:

<?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"  
  android:id="@+id/layout1" 
  android:gravity="center_horizontal" 
  >  
  <ImageSwitcher 
    android:id="@+id/imageSwitcher" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:paddingTop="30px" 
    android:layout_weight="2"/> 
  <Gallery 
    android:id="@+id/gallery1" 
    android:spacing="5px" 
    android:layout_weight="1" 
    android:unselectedAlpha="0.6" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content"/> 
</LinearLayout>  

在res/values目录中,创建一个名为attr.xml的文件,在该文件中定义一个styleable对象,用于组合多个属性。这里只指定了一个系统自带的android:galleryItemBackground属性,用于设置各选项的背景。具体代码如下:
res/values/attr.xml:

<?xml version="1.0" encoding="utf-8"?> 
<resources> 
  <declare-styleable name="Gallery"> 
    <attr name="android:galleryItemBackground"/> 
  </declare-styleable> 
</resources> 

MainActivity:

package com.example.test;  
  
import android.app.Activity; 
import android.content.res.TypedArray; 
import android.os.Bundle; 
import android.view.View; 
import android.view.ViewGroup; 
import android.view.ViewGroup.LayoutParams; 
import android.view.animation.AnimationUtils; 
import android.widget.AdapterView; 
import android.widget.AdapterView.OnItemSelectedListener; 
import android.widget.BaseAdapter; 
import android.widget.Gallery; 
import android.widget.ImageSwitcher; 
import android.widget.ImageView; 
import android.widget.ViewSwitcher.ViewFactory; 
  
public class MainActivity extends Activity {  
  //定义并初始化保存图片id的数组 
   private int[] imageId=new int[]{R.drawable.img1,R.drawable.img2,R.drawable.img3,R.drawable.img4, 
       R.drawable.img5,R.drawable.img6,R.drawable.img7,R.drawable.img8,R.drawable.img9}; 
   //声明一个图像切换器对象 
   private ImageSwitcher imageSwitcher; 
  @Override  
  public void onCreate(Bundle savedInstanceState) {  
    super.onCreate(savedInstanceState);  
    setContentView(R.layout.main);  
      
    Gallery gallery=(Gallery)findViewById(R.id.gallery1);//获取gallery组件 
     
    imageSwitcher=(ImageSwitcher)findViewById(R.id.imageSwitcher);//获取图像切换器 
    //设置动画效果 
    imageSwitcher.setInAnimation(AnimationUtils.loadAnimation(this, 
        android.R.anim.fade_in));//设置淡入动画 
    imageSwitcher.setOutAnimation(AnimationUtils.loadAnimation(this,  
        android.R.anim.fade_out));//设置淡出动画 
    imageSwitcher.setFactory(new ViewFactory(){ 
 
 
      @Override 
      public View makeView() { 
        ImageView imageView=new ImageView(MainActivity.this);//实例化一个imageView类的对象 
        imageView.setScaleType(ImageView.ScaleType.FIT_CENTER);//设置保持纵横比居中缩放图像 
        imageView.setLayoutParams(new ImageSwitcher.LayoutParams( 
            LayoutParams.WRAP_CONTENT,LayoutParams.WRAP_CONTENT)); 
        return imageView;//返回imageView对象 
      } 
    }); 
     
    BaseAdapter adapter=new BaseAdapter(){ 
 
 
      @Override 
      public View getView(int position, View convertView, ViewGroup parent) { 
        ImageView imageView;//声明ImageView的对象 
        if(convertView==null){ 
          imageView=new ImageView(MainActivity.this);//实例化ImageView的对象 
          imageView.setScaleType(ImageView.ScaleType.FIT_XY);//设置缩放方式 
          imageView.setLayoutParams(new Gallery.LayoutParams(180,135)); 
          //设置gallery每一项图片的背景资源(使用的是attr.xml的自定义样式) 
          TypedArray typedArray=obtainStyledAttributes(R.styleable.Gallery); 
          imageView.setBackgroundResource(typedArray.getResourceId( 
              R.styleable.Gallery_android_galleryItemBackground, 0)); 
           
          imageView.setPadding(5, 0, 5, 0);//设置imageView的内边距 
        }else{ 
          imageView=(ImageView)convertView; 
        } 
        imageView.setImageResource(imageId[position]);//为imageView设置要显示的图片 
        return imageView;//返回ImageView 
      } 
       
      //功能:获得当前选项的id 
      @Override 
      public long getItemId(int position) { 
        return position; 
      } 
       
      //功能:获得当前选项 
      @Override 
      public Object getItem(int position) { 
        return position; 
      } 
       
      //获得数量 
      @Override 
      public int getCount() { 
        return imageId.length; 
      } 
    }; 
     
    gallery.setAdapter(adapter);//将适配器与Gallery关联 
    gallery.setSelection(imageId.length/2);//选中中间的图片 
    gallery.setOnItemSelectedListener(new OnItemSelectedListener() { 
 
 
      @Override 
      public void onItemSelected(AdapterView<?> parent, View v, 
          int position, long id) { 
        imageSwitcher.setImageResource(imageId[position]);//显示选中的图片 
      } 
 
 
      @Override 
      public void onNothingSelected(AdapterView<?> arg0) { 
        // TODO Auto-generated method stub 
      } 
    }); 
  }  
}  

这样单击某张图片,可以选中该图片,并且让其居中显示,也可以用手指拖动图片来移动图片,并且让选中的图片在上方显示,如图是切换瞬间的效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

Android中加入名片扫描功能实例代码

这篇文章主要介绍了Android中加入名片扫描功能实例代码的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

Android仿微信发表说说实现拍照、多图上传功能

这篇文章主要为大家详细介绍了Android仿微信发表说说实现拍照、多图上传功能,使用Retrofit2.0技术,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

设置Android系统永不锁屏永不休眠的方法

在进行Android系统开发的时候,有些特定的情况需要设置系统永不锁屏,永不休眠。本篇文章给大家介绍Android 永不锁屏,开机不锁屏,删除设置中休眠时间选项,需要的朋友一起学习吧
收藏 0 赞 0 分享

Android Retrofit 2.0框架上传图片解决方案

这篇文章主要介绍了Android Retrofit 2.0框架上传一张与多张图片解决方案,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android自定义等待对话框

这篇文章主要为大家详细介绍了Android自定义等待对话框的实现方法,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android中Window添加View的底层原理

这篇文章主要介绍了Android中Window添加View的底层原理,需要的朋友可以参考下
收藏 0 赞 0 分享

Android调用系统默认浏览器访问的方法

这篇文章主要介绍了Android调用系统默认浏览器访问的方法的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

Android开发退出程序的方法汇总

Android程序有很多Activity,比如说主窗口A,调用了子窗口B,子窗口B又调用子窗口C,back返回子窗口B后,在B中如何关闭整个Android应用程序呢? 下面脚本之家小编就给大家介绍android开发退出程序的几种方法,感兴趣的朋友参考下吧
收藏 0 赞 0 分享

Android程序开发中单选按钮(RadioGroup)的使用详解

在android程序开发中,无论是单选按钮还是多选按钮都非常的常见,接下来通过本文给大家介绍Android程序开发中单选按钮(RadioGroup)的使用,需要的朋友参考下吧
收藏 0 赞 0 分享

Android实现仿网易今日头条等自定义频道listview 或者grideview等item上移到另一个view中

这篇文章主要介绍了Android实现仿网易今日头条等自定义频道listview 或者grideview等item上移到另一个view中 的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多