android自定义放大缩小按钮,Android------实现图片双击放大,缩小,左右滑动的多种方式...

该博客展示了如何在Android应用中实现类似微信朋友圈和QQ空间的图片浏览功能,包括双击放大、缩小以及左右滑动的效果。作者通过自定义图片控件和使用ViewPager,详细介绍了四种不同的实现方式,并提供了代码示例。第五部分讨论了PhotoView在不同场景下的应用,如单张图片展示、旋转和在ViewPager、GridView中的使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

项目中常常有图片浏览功能。像微信朋友圈图片浏览,QQ空间照片浏览 的功能。

实现图片双击放大,缩小,左右滑动等效果。

来看看我的效果图,希望能满足你的要求

dd998d264ce51b46084b30f1bd23cc4c.gif

0d3e5670e912ba95e846697a6bb71f05.png 

433cd30a6cf399db2250bf3bab865866.png

前三个button按钮是参考网上的多种实现方式,三种自定义图片控件,

第4个是ViewPager实现图片左右滑动

public class ViewPagerImageViewZQUI extends AppCompatActivity {

ViewPager viewPager;

private int[] mImgs = new int[] {

R.mipmap.img1,

R.mipmap.img2,

R.mipmap.tour

};

ImageView[] mImageViews;

@Override

protected void onCreate(@Nullable Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.viewpager_layout);

initView();

}

private void initView(){

mImageViews= new ImageView[mImgs.length];

viewPager= (ViewPager) findViewById(R.id.img_viewpager);

viewPager.setAdapter(new PagerAdapter() {

@Override

public Object instantiateItem(ViewGroup container, int position) {

//可以使用其他的ImageView 控件,其他自定义控件,你也可以使用自己的哦

TounChImageView tounChImageView=new TounChImageView(ViewPagerImageViewZQUI.this);

try {

Picasso.with(ViewPagerImageViewZQUI.this).load(mImgs[position])

.placeholder(R.mipmap.img1)//默认显示的图片

// .resize(500,300)//控制图片高度,不添加则自适应

.error(R.mipmap.ic_launcher)//加载时出现错误显示的图片

.into(tounChImageView);

} catch (Exception e) {

}

//单击返回

tounChImageView.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

finish();

}

});

container.addView(tounChImageView,LinearLayout.LayoutParams.WRAP_CONTENT,

LinearLayout.LayoutParams.WRAP_CONTENT);

mImageViews[position] = tounChImageView;

return tounChImageView;

}

@Override

public int getCount() {

return mImgs.length;

}

@Override

public void destroyItem(ViewGroup container, int position, Object object) {

container.removeView(mImageViews[position]);

}

@Override

public boolean isViewFromObject(View arg0, Object arg1) {

return arg0 == arg1;

}

});

}

}

第5个按钮主要说的是 PhotoView  的多种使用方式,单张,旋转,ViewPager,GridView等

由于界面太多,就没上传太多图片,下载运行看效果即可。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值