gallery 循环播放

来源:互联网 发布:python高性能编程 编辑:程序博客网 时间:2024/05/22 17:18

/*让Galllery循环播放的方法
* 1. 使getCount方法返回一个很大的值。建议返回Integer.MAX_VALUE,这个值可以到达20亿多。
* 2. 在getView方法中通过取余来循环取得resIds数组中的图像资源ID。
* 3.循环Gallery参考http://blog.csdn.net/herryz/article/details/6141957
*/

并修正其中的一个bug。

直接贴代码:

Java代码 复制代码 收藏代码
  1. import android.app.Activity;   
  2. import android.content.Context;   
  3. import android.os.Bundle;   
  4. import android.util.Log;   
  5. import android.view.View;   
  6. import android.view.ViewGroup;   
  7. import android.widget.AdapterView;   
  8. import android.widget.BaseAdapter;   
  9. import android.widget.Gallery;   
  10. import android.widget.ImageView;   
  11.   
  12. public class App extends Activity {   
  13.     private Integer[] imgs = {   
  14.                     R.drawable.photo1,   
  15.                     R.drawable.photo2,   
  16.                     R.drawable.photo3,   
  17.                     R.drawable.photo4,   
  18.                     R.drawable.photo5,   
  19.                     R.drawable.photo6,   
  20.                     R.drawable.photo7,   
  21.                     R.drawable.photo8   
  22.                     };   
  23.     /** Called when the activity is first created. */  
  24.     @Override  
  25.     public void onCreate(Bundle savedInstanceState) {   
  26.         super.onCreate(savedInstanceState);   
  27.         setContentView(R.layout.main);   
  28.         Gallery g = (Gallery) findViewById(R.id.gallery);   
  29.         g.setAdapter(new ImageAdapter(this));   
  30.         g.setOnItemClickListener(new Gallery.OnItemClickListener() {   
  31.   
  32.             @Override  
  33.             public void onItemClick(AdapterView<?> parent, View view,   
  34.                     int position, long id) {   
  35.                 // TODO Auto-generated method stub  
  36.                 Log.i("tag""position==="+position);   
  37.             }   
  38.         });   
  39.     }   
  40.     class ImageAdapter extends BaseAdapter{   
  41.         private Context context;   
  42.         ImageAdapter(Context context){   
  43.             this.context=context;   
  44.         }   
  45.         @Override  
  46.         public int getCount() {   
  47.             // TODO Auto-generated method stub  
  48.             return Integer.MAX_VALUE;//返回无限多个  
  49.         }   
  50.         @Override  
  51.         public Object getItem(int position) {   
  52.             // TODO Auto-generated method stub  
  53.             return imgs[position%imgs.length];//修正!  
  54.         }   
  55.         @Override  
  56.         public long getItemId(int position) {   
  57.             // TODO Auto-generated method stub  
  58.             return position%imgs.length;//修正!  
  59.         }   
  60.         @Override  
  61.         public View getView(int position, View convertView, ViewGroup parent) {   
  62.             // TODO Auto-generated method stub  
  63. //          Log.i("tag", "position=="+getItemId(position));  
  64.             ImageView iv = new ImageView(context);   
  65.             iv.setImageResource(imgs[position%imgs.length]);//取余  
  66.             iv.setScaleType(ImageView.ScaleType.CENTER);   
  67.             iv.setLayoutParams(new Gallery.LayoutParams(150100));   
  68.             return iv;   
  69.         }   
  70.     }   
  71. }  


 

目标:gallery播放时,图片向左或者向右,到头后都会留点空白,这样的效果很不好,虽然可以使用setselection()函数设置默认显示图片,留有空白是仍然存在的,于是为了解决此问题,好像大家都是使用gallery的循环播放。

为了实现循环播放,一般有三个地方,需要修改:

(1)修改ImageAdapter中的getCount()(返回图像的总数量)函数:

?
1
2
3
4
5
6
// 返回图像总数   
public int getCount()
{
    //return images.length;
    returnInteger.MAX_VALUE;
}

 

(2)修改ImageAdapter中的getView()函数:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
public View getView(int position, View convertView, ViewGroup parent)
{  
  ImageView i =new ImageView(mContext);
 
  //i. setImageResource(myImageIds[position]); 
  //循环取图像数据     
  i.setImageResource(myImageIds[position%images.length]);/* 设定图片给imageView对象 */  
 
  i.setScaleType(ImageView.ScaleType.FIT_XY);            /* 重新设定图片的宽高 */  
  i.setLayoutParams(new Gallery.LayoutParams(136, 88));  /* 重新设定Layout的宽高 */  
  i.setBackgroundResource(mGalleryItemBackground);       /* 设定Gallery背景图 */  
  return i;                                              /* 传回imageView物件 */  
}

(3)一般而言,上述1、2步就可以了,但是如果你细心点的话,就会发现,其实1、2步向右的确实现了循环播放,但是向左,仍然不可以循环。这时候,为了实现向左的“循环”,我们可以设置gallery的setselection()函数:

?
1
gallery.setselection(300);

取第301张图片昨晚默认居中图片,这样,用户向左滑动的时候,一般而言,不会滑300下吧~这样给用户造成的视觉效果就是实现了向左循环了。

原创粉丝点击