温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Android中怎么实现图片浏览

发布时间:2021-06-26 15:03:15 来源:亿速云 阅读:157 作者:Leah 栏目:移动开发

本篇文章为大家展示了Android中怎么实现图片浏览,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

首先是Android图片浏览中layout xml:

< ?xml version="1.0" encoding="utf-8"?> < RelativeLayout xmlns:android="http://schemas.Android.com/apk/res/Android"   Android:layout_width="fill_parent"   Android:layout_height="fill_parent">   < ImageSwitcher Android:id="@+id/switcher" Android:layout_width="fill_parent" Android:layout_height="fill_parent" Android:layout_alignParentTop="true" Android:layout_alignParentLeft="true" /> < Gallery Android:id="@+id/gallery" Android:background="#55000000" Android:layout_width="fill_parent" Android:layout_height="60dp" Android:layout_alignParentBottom="true" Android:layout_alignParentLeft="true" Android:gravity="center_vertical" Android:spacing="16dp" /> < /RelativeLayout>

layout里面用到了前面所说的两个控件,ImageSwitcher用啦显示全图,Gallery用来显示缩略图。着重看看ImageSwitcher,在ImageSwitcher1中需要实现ViewSwitcher.ViewFactory这个接口,这个接口里有个方法makeView,这样就产生了用来显示图片的view. ImageSwitcher调用过程是这样的,首先要有一个Factory为它提供一个View,然后ImageSwitcher就可以初始化各种资源了。注意在使用一个ImageSwitcher之前,一定要调用setFactory方法,要不setImageResource这个方法会报空指针异常。

下面是Android图片浏览代码:

  1. package com.zx.imageswitcher;  

  2. import Android.app.Activity;  

  3. import Android.content.Context;  

  4. import Android.os.Bundle;  

  5. import Android.view.View;  

  6. import Android.view.ViewGroup;  

  7. import Android.view.animation.AnimationUtils;  

  8. import Android.widget.AdapterView;  

  9. import Android.widget.BaseAdapter;  

  10. import Android.widget.Gallery;  

  11. import Android.widget.ImageSwitcher;  

  12. import Android.widget.ImageView;  

  13. import Android.widget.ViewSwitcher;  

  14. import Android.widget.Gallery.LayoutParams;  

  15. public class ImageSwitcherTest extends Activity implements  

  16. AdapterView.OnItemSelectedListener, ViewSwitcher.ViewFactory{  

  17. private ImageSwitcher mSwitcher;  

  18. private Integer[] mThumbIds = {  

  19. R.drawable.sample_thumb_0, R.drawable.sample_thumb_1,  

  20. R.drawable.sample_thumb_2, R.drawable.sample_thumb_3,  

  21. R.drawable.sample_thumb_4, R.drawable.sample_thumb_5,  

  22. R.drawable.sample_thumb_6, R.drawable.sample_thumb_7};  

  23. private Integer[] mImageIds = {  

  24. R.drawable.sample_0, R.drawable.sample_1, R.drawable.sample_2,  

  25. R.drawable.sample_3, R.drawable.sample_4, R.drawable.sample_5,  

  26. R.drawable.sample_6, R.drawable.sample_7};  

  27. /** Called when the activity is first created. */  

  28. @Override  

  29. public void onCreate(Bundle savedInstanceState) {  

  30. super.onCreate(savedInstanceState);  

  31. setContentView(R.layout.main);  

  32. mSwitcher = (ImageSwitcher) findViewById(R.id.switcher);  

  33. mSwitcher.setFactory(this);  

  34. mSwitcher.setInAnimation(AnimationUtils.loadAnimation(this,  

  35. Android.R.anim.fade_in));  

  36. mSwitcher.setOutAnimation(AnimationUtils.loadAnimation(this,  

  37. Android.R.anim.fade_out));  

  38. Gallery g = (Gallery) findViewById(R.id.gallery);  

  39. g.setAdapter(new ImageAdapter(this));  

  40. g.setOnItemSelectedListener(this);  

  41. }  

  42. /*  

  43. * override for ViewSwitcher.ViewFactory#makeView()  

  44. */  

  45. public View makeView() {  

  46. ImageView i = new ImageView(this);  

  47. i.setBackgroundColor(0xFF000000);  

  48. i.setScaleType(ImageView.ScaleType.FIT_CENTER);  

  49. i.setLayoutParams(new ImageSwitcher.LayoutParams
    (LayoutParams.FILL_PARENT,  

  50. LayoutParams.FILL_PARENT));  

  51. return i;  

  52. }  

  53. /*  

  54. * override for   

  55. * AdapterView.OnItemSelectedListener#onItemSelected()  

  56. */  

  57. public void onItemSelected(AdapterView parent, 
    View v, int position, long id) {  

  58. mSwitcher.setImageResource(mImageIds[position]);  

  59. }  

  60. /*  

  61. * override for AdapterView.OnItemSelectedListener
    #onNothingSelected()  

  62. */  

  63. public void onNothingSelected(AdapterView< ?> arg0) {  

  64. // TODO Auto-generated method stub  

  65. }  

  66. public class ImageAdapter extends BaseAdapter {  

  67. public ImageAdapter(Context c) {  

  68. mContext = c;  

  69. }  

  70. public int getCount() {  

  71. return mThumbIds.length;  

  72. }  

  73. public Object getItem(int position) {  

  74. return position;  

  75. }  

  76. public long getItemId(int position) {  

  77. return position;  

  78. }  

  79. public View getView(int position, View convertView, 
    ViewGroup parent) {  

  80. ImageView i = new ImageView(mContext);  

  81. i.setImageResource(mThumbIds[position]);  

  82. i.setAdjustViewBounds(true);  

  83. i.setLayoutParams(new Gallery.LayoutParams(  

  84. LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));  

  85. i.setBackgroundResource(R.drawable.picture_frame);  

  86. return i;  

  87. }  

  88. private Context mContext;  

  89. }  

从Android图片浏览的代码中看到还实现了AdapterView.OnItemSelectedListener,这样就需要重写onItemSelected()方法,然后在该方法中:mSwitcher.setImageResource(mImageIds[position]);这样就实现了图片在ImageSwitcher中的切换。

上述内容就是Android中怎么实现图片浏览,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI