博客
关于我
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/

    你可能感兴趣的文章
    nodejs + socket.io 同时使用http 和 https
    查看>>
    NodeJS @kubernetes/client-node连接到kubernetes集群的方法
    查看>>
    Nodejs express 获取url参数,post参数的三种方式
    查看>>
    nodejs http小爬虫
    查看>>
    nodejs libararies
    查看>>
    nodejs npm常用命令
    查看>>
    NodeJS 导入导出模块的方法( 代码演示 )
    查看>>
    nodejs 的 Buffer 详解
    查看>>
    nodejs 读取xlsx文件内容
    查看>>
    nodejs 运行CMD命令
    查看>>
    nodejs-mime类型
    查看>>
    NodeJs——(11)控制权转移next
    查看>>
    NodeJS、NPM安装配置步骤(windows版本)
    查看>>
    NodeJS、NPM安装配置步骤(windows版本)
    查看>>
    nodejs与javascript中的aes加密
    查看>>
    nodejs中Express 路由统一设置缓存的小技巧
    查看>>
    Nodejs中的fs模块的使用
    查看>>
    nodejs包管理工具对比:npm、Yarn、cnpm、npx
    查看>>
    NodeJs单元测试之 API性能测试
    查看>>
    nodejs图片转换字节保存
    查看>>