博客
关于我
Android 高清加载巨图方案 拒绝压缩图片
阅读量:217 次
发布时间:2019-02-28

本文共 2726 字,大约阅读时间需要 9 分钟。

如何高效加载并展示大图?

随着移动设备的普及,用户对展示高清图片的需求不断增加。然而,传统的图片加载方式往往面临内存溢出(OOM)或性能优化问题。对于需要显示高清大图的场景,如地图、历史画卷等,如何高效地加载和展示图片,是一个值得深入探讨的问题。本文将详细介绍解决方案,并提供实际代码示例。

加载图片的挑战

一般情况下,为了避免内存溢出,图片加载时会采取以下措施:

  • 图片压缩:根据显示区域对图片进行比例缩放。
  • 缓存机制:使用LruCache等技术限制内存占用。
  • 然而,对于某些特殊场景,例如需要展示非常大的图片(如地图、历史画卷等),直接加载原图会导致屏幕显示不全,且内存占用过高。此时,如何在不影响性能的前提下,实现高效的大图加载与展示,成为了一个关键问题。

    BitmapRegionDecoder的应用

    为了应对上述挑战,Android提供了BitmapRegionDecoder类,专门用于加载图片的特定矩形区域。这种方式可以在不占用过多内存的前提下,灵活地显示大图的不同区域。以下是BitmapRegionDecoder的基本使用方法:

    BitmapRegionDecoder bitmapRegionDecoder = BitmapRegionDecoder.newInstance(inputStream, false);BitmapFactory.Options options = new BitmapFactory.Options();options.inPreferredConfig = Bitmap.Config.RGB_565; // 设定内存优化配置Rect rect = new Rect(0, 0, width, height);Bitmap bitmap = bitmapRegionDecoder.decodeRegion(rect, options);imageView.setImageBitmap(bitmap);

    自定义大图显示控件

    为了实现大图的拖动查看功能,我们需要自定义一个控件。该控件的核心逻辑包括:

  • 图片加载:使用BitmapRegionDecoder加载指定区域的图片。
  • 手势检测:通过MoveGestureDetector检测用户拖动手势,动态调整显示区域。
  • 边界检查:确保显示区域不会超出图片边界。
  • 以下是自定义控件的代码实现:

    public class LargeImageView extends View {    private BitmapRegionDecoder mDecoder;    private int mImageWidth, mImageHeight;    private Rect mRect;    private MoveGestureDetector mDetector;    public LargeImageView(Context context) {        super(context);        init();    }    private void init() {        mDetector = new MoveGestureDetector(context, new SimpleMoveGestureDetector());    }    @Override    public boolean onTouchEvent(MotionEvent event) {        mDetector.onTouchEvent(event);        return true;    }    @Override    protected void onDraw(Canvas canvas) {        Bitmap bitmap = mDecoder.decodeRegion(mRect, options);        canvas.drawBitmap(bitmap, 0, 0, null);    }}

    完整实现步骤

  • 设置图片流:通过setInputStream方法加载图片流,初始化BitmapRegionDecoder并获取图片尺寸。
  • public void setInputStream(InputStream is) {    try {        mDecoder = BitmapRegionDecoder.newInstance(is, false);        BitmapFactory.Options tmpOptions = new BitmapFactory.Options();        tmpOptions.inJustDecodeBounds = true;        BitmapFactory.decodeStream(is, null, tmpOptions);        mImageWidth = tmpOptions.outWidth;        mImageHeight = tmpOptions.outHeight;        requestLayout();        invalidate();    } catch (IOException e) {        e.printStackTrace();    }}
    1. 初始化手势检测:在布局初始化时创建MoveGestureDetector实例。
    2. public class MoveGestureDetector extends BaseGestureDetector {    // ...手势检测逻辑...}
      1. 手势回调:定义一个简单的回调类,处理拖动事件。
      2. public class SimpleMoveGestureDetector implements OnMoveGestureListener {    @Override    public boolean onMove(MoveGestureDetector detector) {        return false;    }}
        1. 布局中的使用
        2. 测试与验证

          在实际应用中,需要通过测试确保控件正常工作,包括:

        3. 图片加载成功:检查图片是否正确显示在指定区域。
        4. 拖动功能:验证用户是否可以通过拖动手势查看不同区域。
        5. 边界适应:确保显示区域不会超出图片边界。
        6. 通过以上步骤,可以轻松实现大图的高效加载与展示,同时提供良好的用户体验。

    转载地址:http://nles.baihongyu.com/

    你可能感兴趣的文章
    nginx 常用配置记录
    查看>>
    Nginx 我们必须知道的那些事
    查看>>
    Nginx 的 proxy_pass 使用简介
    查看>>
    Nginx 的配置文件中的 keepalive 介绍
    查看>>
    Nginx 负载均衡与权重配置解析
    查看>>
    Nginx 负载均衡详解
    查看>>
    nginx 配置 单页面应用的解决方案
    查看>>
    nginx 配置https(一)—— 自签名证书
    查看>>
    nginx 配置~~~本身就是一个静态资源的服务器
    查看>>
    Nginx 配置解析:从基础到高级应用指南
    查看>>
    Nginx下配置codeigniter框架方法
    查看>>
    nginx添加模块与https支持
    查看>>
    Nginx用户认证
    查看>>
    Nginx的Rewrite正则表达式,匹配非某单词
    查看>>
    Nginx的使用总结(一)
    查看>>
    Nginx的可视化神器nginx-gui的下载配置和使用
    查看>>
    Nginx的是什么?干什么用的?
    查看>>
    Nginx访问控制_登陆权限的控制(http_auth_basic_module)
    查看>>
    nginx负载均衡器处理session共享的几种方法(转)
    查看>>
    nginx负载均衡的5种策略(转载)
    查看>>