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

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

效果图如图

实现方法:

在布局文件中添加图片切换控件ImageSwitcher和画廊视图控件Gallery

res/layout/main.xml:

android:orientation="vertical"

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:id="@+id/layout1"

android:gravity="center_horizontal"

>

android:id="@+id/imageSwitcher"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:paddingTop="30px"

android:layout_weight="2"/>

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"/>

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

res/values/attr.xml:

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实现幻灯片式图片浏览器相关推荐

  1. android相册幻灯片功能,Android实现幻灯片式图片浏览器

    我们来实现一个幻灯片式图片浏览器: 最下面一个画廊视图,选中画廊中的图片,会在上面的ImageSwitcher控件中显示大图. 效果图如图 实现方法: 在布局文件中添加图片切换控件ImageSwitc ...

  2. Android点击按钮显示密码,Android 开发仿简书登录框可删除内容或显示密码框的内容...

    简书App 是我很喜欢的一款软件.今天就模仿了一下他的登录框.先上图: 好了下面上代码,自定义ImgEditText 继承与EditText.重写一些方法. package lyf.myimgedit ...

  3. android+点击屏幕隐藏键盘,Android点击EditText文本框之外任何地方隐藏键盘的解决办法...

    1,实现方法一: 通过给当前界面布局文件的父layout设置点击事件(相当于给整个Activity设置点击事件),在事件里进行键盘隐藏 android:id="@+id/traceroute ...

  4. Android点击通知进入详情,Android 点击通知进入正在运行的程序

    好久没写文章,今天遇到一个新需求,app正在通话过程切换到后台,点击通知栏的时候 回到通话界面. 直接上代码吧首先是实现通知的代码 NotificationCompat.Builder notific ...

  5. Android幻灯片式图片浏览器

    今天我们通过使用Android提供给我们的现有空间Gallery和ImageSwitcher来实现一个幻灯片式的图片浏览器. (1)首先我们新建一个工程,修改主布局文件activity_main.xm ...

  6. android点击跳转卸载,[android]通过JNI实现卸载自身App后台发送Http请求~

    freddon 发表于2016-10-21 阅读 1252 | 评论 1 使用JNI fork进程实现 监控自身App被卸载 首先这个功能仅供cankao 也可以使用linux exec命令跳转到浏览 ...

  7. android 点击通知栏打开activity,Android实现点击通知栏后,先启动应用再打开目标Activity...

    情况简述 在开发Android app的过程中,遇到这样一个需求:app中启动一个Service,该Service在独立进程中运行,与服务器保持长连接,将服务器推送过来的消息在通知栏中显示,并设置点击 ...

  8. android点击隐藏控件,Android编程实现点击EditText之外的控件隐藏软键盘功能

    本文实例讲述了Android编程实现点击EditText之外的控件隐藏软键盘功能.分享给大家供大家参考,具体如下: 工具类 ... public static void hideKeyboard(Co ...

  9. android点击textview后选择,android - 单击后,ClickableSpan TextView保持选中状态 - SO中文参考 - www.soinside.com...

    我正在使用以下代码使我的TextView看起来像一个链接,当用户点击它时,我显示一个AlertDialog.但是在用户离开对话框后文本保持选中状态并且看起来很难看. TextView terms = ...

  10. android点击地址调用地图,Android 实现点击按钮 调用手机外部地图导航

    //弹出Dialog 选择外部地图 private void setMap(){ final Dialog dia=new AlertDialog.Builder(mContext).create() ...

最新文章

  1. 清华中德大数据研究学生交换项目成果报告会成功举办
  2. linux find 忽略大小写查找文件
  3. 黑马vue---13、事件修饰符的介绍
  4. Coursera ML笔记 - 神经网络(Learning)
  5. 小腹下面是什么部位_为什么肚子上的肉最难减?说好的马甲线呢?
  6. java国际化——Locale+数字格式
  7. 合并不同gdb下的相同要素_GDB调试学习
  8. Android多媒体学习八:调用Android自带的音频录制程序,实现录制
  9. 英语总结系列(二十七):重复就是力量
  10. 功夫小子实践开发-具有简单AI的怪物类的分析和实现
  11. python循环语句for 循环十次_Python 循环 while,for语句
  12. 2010 模板下载 罗斯文_选择并使用 Access 模板
  13. charles(青花瓷)抓包乱码【青花瓷抓包https内容】
  14. 【记忆法】记忆法推荐书
  15. OSChina 周二乱弹 ——深入浅出微信小程序
  16. 微信三个平台区分(开放,公众,商户平台)(转)
  17. 天之痕java 郡王府_轩辕剑3外传天之痕图文攻略【含支线任务】
  18. word2019使一级标题为第一章,二级标题为1.1的格式
  19. 【小程序源码】强大的万年历微信小程序源码下载
  20. python写excel文件头_Python帮你做Excel——写入Excel文档

热门文章

  1. 汽车距离报警系统c语言编程,基于单片机的汽车防盗报警系统的设计本科生毕业论文.doc...
  2. Time——信仰:梦在远方,路在脚下
  3. 大咖带你免费学前端,附不容错过的前端100篇文章合集
  4. k8s pv与pvc
  5. win快速打开计算机,这十个“Windows+”使用技巧,打开你的电脑技巧新世界
  6. python元祖封包_python的封包与解包
  7. LU分解、矩阵求逆与解线性方程组(matlab代码)
  8. 三步激活win10(转)
  9. 用友U8V10.1软件安装教程
  10. 京东AI:用于视觉识别的上下文Transformer网络-Contextual Transformer Networks for Visual Recognition