使用Gallery实现缩略图浏览器

我们有时候在iPhone手机上或者Windows上面看到动态的图片,可以通过鼠标或者手指触摸来移动它,产生动态的图片滚动效果,还可以根据你的点击或者触摸触发其他事件响应。同样的,在Android中也提供这这种实现,这就是通过Gallery在UI上实现缩略图浏览器。

 

我们来看看Gallery是如何来实现的,先把控件绑架出来,从哪里绑架?控件当然藏在布局文件中,这个首先需要在UI布局中声明,这里就不再赘述,只需知道ID为gallery。

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

一般情况下,我们在Android中要用到类似这种图片容器的控件,都需要为它指定一个适配器,让它可以把内容按照我们定义的方式来显示,因此我们来给它加一个适配器,至于这个适配器如何实现,后面接着来操作,这里只需知道这个适配器的类叫ImageAdapter。

gallery.setAdapter(new ImageAdapter(this));

接下来就是重头戏了,适配器可以说是最重要的,我们来看看如何做?到这里似乎还缺少一些很重要的东西?什么东西呢?我们需要显示的是图片,那么图片我们当然首先要准备好,这里我们准备了5张图片(存放drawable文件夹中),我们用其IDs做索引,以便在适配器中使用。

private Integer[] mps = {
   R.drawable.icon1,
   R.drawable.icon2,
   R.drawable.icon3,
   R.drawable.icon4,
   R.drawable.icon5
};

OK,这里将开始定义适配器了,通过继承BaseAdapter用以实现的适配器。

public class ImageAdapter extends BaseAdapter {
   private ContextmContext;
   public ImageAdapter(Contextcontext) {
   mContext = context;
   }
   public int getCount(){ 
     return mps.length;
   }
   public Object getItem(intposition) {
     return position;
   }
   public long getItemId(intposition) {
     return position;
   }
   public View getView(intposition, View convertView, ViewGroup parent) {
     ImageView image = new ImageView(mContext);
     image.setImageResource(mps[position]);
     image.setAdjustViewBounds(true);
     image.setLayoutParams(new Gallery.LayoutParams(
         LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
     return image;
     }
}

至此,整个Gallery基本都是先完成了,我们还需要为它添加一个监听器,否则这个缩略图浏览器就仅仅只可以看不能用了。

gallery.setOnItemSelectedListener(newAdapterView.OnItemSelectedListener() {
   @Override
    public voidonItemSelected(AdapterView<?> parent,View v,int position, long id) {
       //显示提示框“随时随地,即兴时代,ATAAW.COM!”
    }
   @Override
    public voidonNothingSelected(AdapterView<?>arg0) {
   //这里不做响应
    }
});


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的jQuery实现带有缩略图的相册导航特效的示例代码: HTML结构: ``` <div class="gallery"> <div class="main-image"> <img src="image1.jpg" alt="Image 1"> </div> <div class="thumbnails"> <a href="image1.jpg"><img src="thumbnail1.jpg" alt="Thumbnail 1"></a> <a href="image2.jpg"><img src="thumbnail2.jpg" alt="Thumbnail 2"></a> <a href="image3.jpg"><img src="thumbnail3.jpg" alt="Thumbnail 3"></a> <a href="image4.jpg"><img src="thumbnail4.jpg" alt="Thumbnail 4"></a> </div> </div> ``` CSS样式: ``` .gallery { position: relative; width: 100%; height: 500px; } .main-image { position: absolute; top: 0; left: 0; width: 100%; height: 100%; overflow: hidden; } .main-image img { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); max-width: 100%; max-height: 100%; } .thumbnails { position: absolute; bottom: 0; left: 0; width: 100%; height: 100px; background-color: #f2f2f2; overflow-x: auto; white-space: nowrap; -webkit-overflow-scrolling: touch; } .thumbnails a { display: inline-block; width: 100px; height: 100%; text-align: center; vertical-align: middle; } .thumbnails img { max-width: 100%; max-height: 100%; vertical-align: middle; cursor: pointer; opacity: 0.5; } .thumbnails img:hover { opacity: 1; } ``` jQuery代码: ``` $(document).ready(function() { // 初始化 $('.thumbnails a:first-child img').css('opacity', 1); // 点击缩略图 $('.thumbnails a').click(function(e) { e.preventDefault(); // 切换图片 var mainImage = $('.main-image img'); var newImageSrc = $(this).attr('href'); mainImage.attr('src', newImageSrc); // 修改缩略图透明度 $('.thumbnails img').css('opacity', 0.5); $(this).find('img').css('opacity', 1); }); // 滚动缩略图 $('.thumbnails').on('scroll', function() { var scrollLeft = $(this).scrollLeft(); var thumbnailsWidth = $(this).outerWidth(); var thumbnailsContainerWidth = $(this).prop('scrollWidth'); var maxScrollLeft = thumbnailsContainerWidth - thumbnailsWidth; if (scrollLeft == 0) { $('.thumbnails-arrow-left').removeClass('active'); } else { $('.thumbnails-arrow-left').addClass('active'); } if (scrollLeft == maxScrollLeft) { $('.thumbnails-arrow-right').removeClass('active'); } else { $('.thumbnails-arrow-right').addClass('active'); } }); // 点击缩略图左箭头 $('.thumbnails-arrow-left').click(function() { var scrollLeft = $('.thumbnails').scrollLeft(); var newScrollLeft = scrollLeft - 100; $('.thumbnails').animate({scrollLeft: newScrollLeft}, 500); }); // 点击缩略图右箭头 $('.thumbnails-arrow-right').click(function() { var scrollLeft = $('.thumbnails').scrollLeft(); var newScrollLeft = scrollLeft + 100; $('.thumbnails').animate({scrollLeft: newScrollLeft}, 500); }); }); ``` 注:上述示例代码仅为示范,具体实现方式可能因具体需求而异。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值