public class AndroidImageSwitcher  extends Activity implements ViewFactory {
private ImageSwitcher is;  
    private Gallery gallery;  
    private int downX,upX;  
    private ArrayList<Integer> imgList=new ArrayList<Integer>();//图像ID

protected void onCreate(Bundle savedInstanceState) {  
        // TODO Auto-generated method stub  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.imageswitchview);  
        //用反射机制来获取资源中的图片ID  
        Field[] fields = R.drawable.class.getDeclaredFields();  
        for (Field field : fields)  
        {  
            if (!"icon".equals(field.getName()))//除了icon之外的图片  
            {     
                int index = 0;  
                try {  
                    index = field.getInt(R.drawable.class);  
                } catch (IllegalArgumentException e) {  
                    // TODO Auto-generated catch block  
                    e.printStackTrace();  
                } catch (IllegalAccessException e) {  
                    // TODO Auto-generated catch block  
                    e.printStackTrace();  
                }  
                //保存图片ID  
                imgList.add(index);  
            }  
        }  
          
        //设置ImageSwitcher控件  
        is = (ImageSwitcher) findViewById(R.id.switcher);  
        is.setFactory(this);  
        is.setInAnimation(AnimationUtils.loadAnimation(this,  
                android.R.anim.fade_in));  
        is.setOutAnimation(AnimationUtils.loadAnimation(this,  
                android.R.anim.fade_out));  
        is.setOnTouchListener(new OnTouchListener(){  
            /* 
             * 在ImageSwitcher控件上滑动可以切换图片 
             */ 
     
            public boolean onTouch(View v, MotionEvent event) {  
                if(event.getAction()==MotionEvent.ACTION_DOWN)  
                {  
                    downX=(int) event.getX();//取得按下时的坐标  
                    return true;  
                }  
                else if(event.getAction()==MotionEvent.ACTION_UP)  
                {  
                    upX=(int) event.getX();//取得松开时的坐标  
                    int index=0;  
                    if(upX-downX>100)//从左拖到右,即看前一张  
                    {  
                        //如果是第一,则去到尾部  
                        if(gallery.getSelectedItemPosition()==0)  
                           index=gallery.getCount()-1;  
                        else 
                            index=gallery.getSelectedItemPosition()-1;  
                    }  
                    else if(downX-upX>100)//从右拖到左,即看后一张  
                    {  
                        //如果是最后,则去到第一  
                        if(gallery.getSelectedItemPosition()==(gallery.getCount()-1))  
                            index=0;  
                        else 
                            index=gallery.getSelectedItemPosition()+1;  
                    }  
                    //改变gallery图片所选,自动触发ImageSwitcher的setOnItemSelectedListener  
                    gallery.setSelection(index, true);  
                    return true;  
                }  
                return false;  
            }  
              
        });  
          
        //设置gallery控件  
        gallery = (Gallery) findViewById(R.id.gallery);  
        gallery.setAdapter(new ImageAdapter(this));  
        gallery.setOnItemSelectedListener(new OnItemSelectedListener(){

public void onItemSelected(AdapterView<?> arg0, View arg1,  
                    int position, long arg3) {  
                is.setImageResource(imgList.get(position));  
            }  
           
            public void onNothingSelected(AdapterView<?> arg0) {  
                // TODO Auto-generated method stub  
            }  
              
        });  
    }  
    //设置ImgaeSwitcher  
 
    public View makeView() {  
        ImageView i = new ImageView(this);  
        i.setBackgroundColor(0xFF000000);  
        i.setScaleType(ImageView.ScaleType.CENTER);//居中  
        i.setLayoutParams(new ImageSwitcher.LayoutParams(//自适应图片大小  
                LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));  
        return i;  
    }  
    public class ImageAdapter extends BaseAdapter {  
        public ImageAdapter(Context c) {  
            mContext = c;  
        }  
        public int getCount() {  
            return imgList.size();  
        }  
        public Object getItem(int position) {  
            return position;  
        }  
        public long getItemId(int position) {  
            return position;  
        }  
        public View getView(int position, View convertView, ViewGroup parent) {  
            ImageView i = new ImageView(mContext);  
            i.setImageResource(imgList.get(position));  
            i.setAdjustViewBounds(true);  
            i.setLayoutParams(new Gallery.LayoutParams(  
                    LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));  
            return i;  
        }  
        private Context mContext;  
    }

(转)gallary和imageswitcher相关推荐

  1. android学习笔记23:幻灯片

    使用gallary和imageswitcher可以在android中实现如windows中的幻灯片图片浏览效果. 用gallary作为下面的图片选择部分,imageSwitcher作为图片显示部分 & ...

  2. 【Android实战】Gallary+ImageSwicther图片查看器

    仿照如今各大新闻站点图片新闻的浏览模式,上面展示详细图片(ImageSwitch),以下是能够滑动的小图片(Gallery). 当中须要注意的是ImageSwitch须要定义一个工厂返回的组件,而且能 ...

  3. Android 控件之ImageSwitcher图片切换器

    ImageSwitcher是Android中控制图片展示效果的一个控件,如:幻灯片效果...,颇有感觉啊.做相册一绝 源码下载 一.重要方法 setImageURI(Uri uri):设置图片地址 s ...

  4. android高级组件,Android高级组件ImageSwitcher图像切换器使用方法详解

    图像切换器(ImageSwitcher),用于实现类似于Windows操作系统的"Windows照片查看器"中的上一张.下一张切换图片的功能.在使用ImageSwitcher时,必 ...

  5. Android_TextSwitcher和ImageSwitcher

    Android_TextSwitcher和ImageSwitcher

  6. Android用户界面开发(16):ImageSwitcher

    图片切换(ImageSwitcher) 通过ImageSwitcher类来实现切换图片的效果,ImageSwitcher类必须设置一个ViewFactory,主要用来将显示的图片和父窗口区分开来,因此 ...

  7. Android中Gallery和ImageSwitcher的使用

    效果如下:  布局文件activity_main.xml如下: <code class="hljs xml has-numbering" style="displa ...

  8. Android学习笔记26:图片切换控件ImageSwitcher的使用

    在Windows操作系统中,要查看多张图片,可以通过使用"Windows照片查看器"在"上一张"和"下一张"之间切换,进行多张图片的浏览. ...

  9. Android中通过ImageSwitcher实现相册滑动查看照片功能(附代码下载)

    场景 效果 注: 博客: https://blog.csdn.net/badao_liumang_qizhi 关注公众号 霸道的程序猿 获取编程相关电子书.教程推送与免费下载. 实现 将需要滚动查看的 ...

最新文章

  1. 回归Dos操作的快感,进入PowerShell世界
  2. 独立按键控制数码管c语言,各位大佬,独立按键控制数码管为什么按下的时候要加一呢?...
  3. c++exe程序在别人电脑上双击无法打开_Windows10电脑磁盘占用率过高,用这二招轻松解决...
  4. html5 indexeddb 排序,html5 – 在IndexedDB中,有没有办法进行排序复合查询?
  5. xpage 传参_jQuery iScroll.js 移动端滚动条美化插件第1/5页
  6. mongodb数据库的启动和停止
  7. python代码示例-Python3 实例
  8. STVD ERROR:misplaced local declaration
  9. 程序员的 10 款代码表白特效,一个比一个浪漫
  10. Android中的权限请求
  11. linux下chm文件制作,自己动手将在线文档制作成CHM文件
  12. PLC网络流量异常检测的统计模型和神经网络模型的比较研究
  13. ifup,ifdown命令详解
  14. java-简易计算器设计
  15. 使用MMDetection训练自己的数据集
  16. 水晶报表(Crystal Report)- 水晶报表常见问题总结
  17. MTK平台ota升级后不删除u盘的update.zip
  18. 美容行业竞争分析:2022年大型美容院成为市场主流
  19. 【深度学习】入门之keras
  20. (操作系统开发)从实模式---->保护模式---->IA-32e模式( 64位模式)

热门文章

  1. 深度学习常规概念(持续更新)
  2. 画原型图的几大坑,你被埋了吗?!
  3. 9月28日科技资讯|华为发布全容器化 5G 核心网;余承东评小米 MIX Aphla 手机无实用价值;PHP 新版本更新
  4. 深渊水妖 (模拟 看清题意
  5. 转载自杭电大牛的博客 线段树 绝对经典
  6. 机器人II_ny_371
  7. 再谈BPM(业务流程管理)为企业带来哪些提升
  8. 电销人必须 ,好用稳定的外呼系统,具备这8个共同点
  9. MacOS安装brew教程从入门到入土
  10. 《给程序员的职场情商课》读书笔记