Android实现仿Windows7图片预览窗格效果

 更新时间:2017年12月26日 10:25:23   作者:光仔December  
这篇文章主要为大家详细介绍了Android实现仿Windows7图片预览窗格效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本实例将显示类似于windows7提供的图片预览窗格效果,单击任意一张图片,可以在右侧显示该图片的预览效果。

效果如图所示:

具体实现方法:
res/layout/main.xml:

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 android:orientation="horizontal" 
 android:layout_width="fill_parent" 
 android:layout_height="fill_parent" 
 android:id="@+id/layout1" 
 > 
 <GridView android:id="@+id/gridView1" 
  android:layout_height="match_parent" 
  android:layout_width="440px" 
  android:layout_marginTop="10px" 
  android:horizontalSpacing="3px" 
  android:verticalSpacing="3px" 
  android:numColumns="3"/> 
 <!-- 添加一个图像切换器 --> 
 <ImageSwitcher 
  android:id="@+id/imageSwitcher1" 
  android:padding="10px" 
  android:layout_width="match_parent" 
  android:layout_height="match_parent"/> 
</LinearLayout> 

MainActivity:

package com.example.test; 
 
import android.app.Activity; 
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.OnItemClickListener; 
import android.widget.BaseAdapter; 
import android.widget.GridView; 
import android.widget.ImageSwitcher; 
import android.widget.ImageView; 
import android.widget.ViewSwitcher.ViewFactory; 
 
public class MainActivity extends Activity { 
 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); 
   
  imageSwitcher=(ImageSwitcher)findViewById(R.id.imageSwitcher1);//获取图像切换器 
  //设置动画效果 
  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 imageView=new ImageView(MainActivity.this); 
    //设置保持纵横比居中缩放图像 
    imageView.setScaleType(ImageView.ScaleType.FIT_CENTER); 
    imageView.setLayoutParams(new ImageSwitcher.LayoutParams( 
      LayoutParams.WRAP_CONTENT,LayoutParams.WRAP_CONTENT)); 
    return imageView;//返回imageView对象 
   } 
  }); 
  imageSwitcher.setImageResource(R.drawable.img3);//设置默认显示的图像 
   
   
  GridView gridview=(GridView)findViewById(R.id.gridView1); 
  BaseAdapter adapter=new BaseAdapter(){ 
 
 
   @Override 
   public View getView(int position, View convertView, ViewGroup parent) { 
    ImageView imageView = null;//声明一个ImageView对象 
    if(convertView==null){ 
     imageView=new ImageView(MainActivity.this);//实例化ImageView对象 
     /****************设置图像的宽度和高度*******************/ 
     imageView.setAdjustViewBounds(true); 
     imageView.setMaxWidth(150); 
     imageView.setMaxHeight(113); 
     /*********************************************************/ 
     imageView.setPadding(5, 5, 5, 5); 
    }else{ 
     imageView=(ImageView)convertView; 
    } 
    imageView.setImageResource(imageId[position]); 
    return 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; 
   } 
  }; 
  gridview.setAdapter(adapter); 
  gridview.setOnItemClickListener(new OnItemClickListener() { 
 
 
   @Override 
   public void onItemClick(AdapterView<?> parent, View view, int position, 
     long id) { 
     //显示选中的照片 
     imageSwitcher.setImageResource(imageId[position]); 
   } 
  }); 
 } 
} 

运行效果与开头描述相同,成功实现。

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

相关文章

  • Android开发中Google为什么不让用Handler的runWithScissors()

    Android开发中Google为什么不让用Handler的runWithScissors()

    这篇文章主要介绍了Android开发中Google为什么不让用Handler的runWithScissors(),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-09-09
  • ListView的Adapter使用 之 初学ArrayAdapter String

    ListView的Adapter使用 之 初学ArrayAdapter String

    ListView是Android中经常会使用的东西,绑定数据对于初学者来说,尤其是刚接触编程的人来说,往往会觉得很难理解,我上大二的时候学的java,但是基本上相当于没有学,什么都没写过,真正接触编程就是开始上手学android,把这些记录下来,自己可以回头看下,也可以让新手更好的理解
    2013-06-06
  • 浅析Android的启动原理

    浅析Android的启动原理

    当谈到Android启动原理时,我们进入了Android操作系统的核心,理解Android系统启动的原理对于开发者来说非常重要,因为这有助于优化应用程序性能并提供更好的用户体验,本文给大家讲讲Android启动原理,需要的朋友可以参考下
    2023-10-10
  • Android使用GridLayout绘制自定义日历控件

    Android使用GridLayout绘制自定义日历控件

    这篇文章主要为大家详细介绍了Android使用GridLayout绘制自定义日历控件的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • Android BottomNavigationBar底部导航的使用方法

    Android BottomNavigationBar底部导航的使用方法

    这篇文章主要为大家详细介绍了Android BottomNavigationBar底部导航的使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-11-11
  • Android实现微信首页左右滑动切换效果

    Android实现微信首页左右滑动切换效果

    这篇文章主要介绍了Android实现微信首页左右滑动切换效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • Android仿微信联系人字母排序效果

    Android仿微信联系人字母排序效果

    大家使用到的联系人界面,几乎都是按照字母排序,如何实现联系人按字母排序?下面就为大家详解介绍了Android仿微信联系人按字母排序的实现方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-11-11
  • Android实现掷骰子效果

    Android实现掷骰子效果

    这篇文章主要为大家详细介绍了Android实现掷骰子效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-05-05
  • android和服务器的URLEncodedUtils乱码编码问题的解决方案

    android和服务器的URLEncodedUtils乱码编码问题的解决方案

    今天小编就为大家分享一篇关于android和服务器的URLEncodedUtils乱码编码问题的解决方案,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • Android 蓝牙BLE开发完全指南

    Android 蓝牙BLE开发完全指南

    BLE蓝牙的兴起主要因为近年来可穿戴设备的流行,由于传统蓝牙功耗高不能满足可穿戴设备对于续航的要求,所以大部分可穿戴设备采用蓝牙4.0,即BLE蓝牙技术,这篇文章主要给大家介绍了关于Android 蓝牙BLE开发的相关资料,需要的朋友可以参考下
    2021-11-11

最新评论