Android实现大图滚动显示效果

Android实现大图滚动显示效果,第1张

概述问题:      我有一张比较大的图片,比如长宽都是屏幕的两倍大小,我想实现的功能是首先将图片居中显示,由于图片太大显然只能显示一部分,然后可以通过拖动,实现图片的平滑滚动

问题:

       我有一张比较大的图片,比如长宽都是屏幕的两倍大小,我想实现的功能是首先将图片居中显示,由于图片太大显然只能显示一部分,然后可以通过拖动,实现图片的平滑滚动(既看不出来滚动刷新痕迹)。

       就像Google地图一样,如果用mapVIEw这个控件,那么可以在屏幕上拖动整个地图,但是由于地图信息量太大,如果一次拖动过快,那么屏幕会暂时显示出一些刷新痕迹(灰白的格子)。

       想使用mapVIEw来加载已有图片,但是没有成功,后来也使用了SrollvIEw控件,和最常用的imageVIEw,还是没有成功。 

解决:

       经过大量查资料,使用imageVIEw配合ontouch事件,可以解决。

关键代码:

布局文件中imageVIEw控件如下

<ImageVIEw   androID:layout_wIDth="wrap_content"   androID:layout_height="wrap_content"   androID:ID="@+ID/img"   androID:scaleType="center"   androID:background="#fff"   androID:src="@drawable/picname" /> 

Activity文件中主要代码如下

@OverrIDe public voID onCreate(Bundle savedInstanceState) {   super.onCreate(savedInstanceState);    setContentVIEw(R.layout.xml_name_layout);    final ImageVIEw switcherVIEw = (ImageVIEw) this.findVIEwByID(R.ID.img);    switcherVIEw.setontouchListener(new VIEw.OntouchListener() {      public boolean ontouch(VIEw arg0,MotionEvent event) {        float curX,curY;        switch (event.getAction()) {          case MotionEvent.ACTION_DOWN:           mx = event.getX();           my = event.getY();           break;         case MotionEvent.ACTION_MOVE:           curX = event.getX();           curY = event.getY();           switcherVIEw.scrollBy((int) (mx - curX),(int) (my - curY));           mx = curX;           my = curY;           break;         case MotionEvent.ACTION_UP:           curX = event.getX();           curY = event.getY();           switcherVIEw.scrollBy((int) (mx - curX),(int) (my - curY));           break;       }        return true;     }   });  } 

原图

模拟器里效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。

总结

以上是内存溢出为你收集整理的Android实现大图滚动显示效果全部内容,希望文章能够帮你解决Android实现大图滚动显示效果所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/1143376.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存