图片二次加载后直接从内存中提取

原创 2018年04月17日 20:41:44


MainActivity


public class MainActivity extends AppCompatActivity {


    private ImageView imageView;
    private LruCacheUtils lruCacheUtils;
    private String picUrl="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1513777051557&di=a6de503f11b6aa53a60e844e13c01f0c&imgtype=jpg&src=http%3A%2F%2Fimg3.imgtn.bdimg.com%2Fit%2Fu%3D3164275898%2C1502108289%26fm%3D214%26gp%3D0.jpg";
    private Button btnDown;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);


        imageView = findViewById(R.id.img);
        btnDown = findViewById(R.id.btn_down);


        //初使化内存缓存
        lruCacheUtils = new LruCacheUtils(this);


        //按钮的点击事件
        btnDown.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                //首先判断内存缓存中有没有
                Bitmap bitmap=lruCacheUtils.getPicFromMemory(picUrl);


                if(bitmap!=null){
                    Log.d("zzz","从内存缓存中获取");
                    imageView.setImageBitmap(bitmap);
                }else {
                    Log.d("zzz","从网络中获取");
                    //进行网络下载图片
                    MyPicTask task=new MyPicTask();
                    task.execute(picUrl);
                }
            }
        });
    }


    class MyPicTask extends AsyncTask<String,Void,Bitmap>{


        @Override
        protected Bitmap doInBackground(String... strings) {


            try {
                //使用HttpUrlConnection
                URL url=new URL(strings[0]);
                HttpURLConnection connection=(HttpURLConnection) url.openConnection();
                connection.setRequestMethod("GET");
                connection.setReadTimeout(5000);
                connection.setConnectTimeout(5000);


                if(connection.getResponseCode()==200){
                    InputStream inputStream=connection.getInputStream();
                    return BitmapFactory.decodeStream(inputStream);
                }


            } catch (MalformedURLException e) {
                e.printStackTrace();
            }catch (IOException e){
                e.printStackTrace();
            }
            return null;
        }


        @Override
        protected void onPostExecute(Bitmap bitmap) {
            super.onPostExecute(bitmap);
            imageView.setImageBitmap(bitmap);
            //保存在内存缓存中
            lruCacheUtils.savePicToMemory(picUrl,bitmap);
        }
    }


}









方法类



public class LruCacheUtils {
    //申明内存缓存
    private LruCache<String,Bitmap> mLruCache;


    //在构造方法中进行初使化
    public LruCacheUtils(Context context) {
        //得到当前应用程序的内存
        int maxMemory=(int)Runtime.getRuntime().maxMemory();
        //内存缓存为当前应用程序的8分之1
        int cacheMemory=maxMemory/8;


        //进行初使化
        mLruCache=new LruCache<String, Bitmap>(cacheMemory){
            @Override
            protected int sizeOf(String key, Bitmap value) {
                return value.getByteCount();//自定义bitmap数据大小的计算方式
            }
        };
    }


    /**
     * 保存图片到内存缓存
     * @param key 图片的url
     * @param bitmap 图片
     */
    public void savePicToMemory(String key,Bitmap bitmap){
        try {
            mLruCache.put(key,bitmap);


        } catch (Exception e) {
            e.printStackTrace();
        }
    }
    /**
     * 通过key值得到缓存的图片
     * @param key 图片的url地址
     * @return Bitmap 或 null
     */
    public  Bitmap getPicFromMemory(String key){


        Bitmap bitmap=null;
        try {
            //通过key获取图片
            bitmap= mLruCache.get(key);
        } catch (Exception e) {
            e.printStackTrace();
        }


        return bitmap;
    }
/**
     * 清除缓存
     * evict:驱逐 逐出
     */
    public void clearCache() {
        if (mLruCache != null) {
            if (mLruCache.size() > 0) {
                Log.d("CacheUtils",
                        "mMemoryCache.size() " + mLruCache.size());
                mLruCache.evictAll();


                Log.d("CacheUtils", "mMemoryCache.size()" + mLruCache.size());
            }
            mLruCache = null;
        }
    }


}



从内存中提取图片等数据

  • 2018年01月14日 10:18
  • 338KB
  • 下载

从资源或内存中加载dll

  • 2016年08月15日 22:33
  • 225KB
  • 下载

opencv 内存中读取一段jpg 图片

FILE* f=fopen("d:\\background_left.jpg","r");     unsigned char *m=(unsigned char*)malloc(1280*...
  • laoji48
  • laoji48
  • 2015-12-25 14:29:53
  • 1812

OpenCV读取内存数据

环境说明: OpenCV 3.2 VS2015 Win7 #include"opencv2/core/core.hpp" #include"opencv2/highgui/hig...
  • Solo_Q
  • Solo_Q
  • 2017-07-20 14:44:43
  • 752

从内存中加载并启动一个EXE

windows似乎只提供了一种启动进程的方法:即必须从一个可执行文件中加载并启动。 而下面这段代码就是提供一种可以直接从内存中启动一个exe的变通办法。 用途嘛, 也许可以用来保护你的exe,你可以对...
  • suiyunonghen
  • suiyunonghen
  • 2008-03-18 01:54:00
  • 2689

[绘制相关] 用CImage 读取 内存中的图片数据

void LoadMemImage(void* pMemData, long len){  HGLOBAL hGlobal = GlobalAlloc(GMEM_MOVEABLE, len);  vo...
  • zhangzongnan
  • zhangzongnan
  • 2010-08-18 16:47:00
  • 1635

opencv从内存读取图片

使用场景: cv_2.4.1/ cpp/linux,我有一内存的文件内存快,是一图片。需要读取到Mat中。 原方案是io保存一次,然后执行imread。后面细想,这个方案要消耗两次IO,很浪费。能否绕...
  • songtzu
  • songtzu
  • 2015-06-01 10:49:53
  • 7978

CImage从内存和资源中加载图片文件

用CImage加载内存里的Image 问题:已知一块内存,知道里面是一张图片的数据,如何显示出来? 一种解决方法: CImage(MFC or ATL)提供了一个加载内存中Image的成员函数H...
  • Templar1000
  • Templar1000
  • 2014-05-29 01:24:21
  • 1834

opencv 从内存加载图像

opencv 从内存加载图像参考资料: http://stackoverflow.com/questions/13705578/convert-a-string-of-bytes-to-cvmat ...
  • yuzx2008
  • yuzx2008
  • 2015-12-08 14:46:20
  • 1542

OpenCv读取与解码内存中的图片及过程中的内存问题

开发中遇到的问题,为了让别人方便也让自己方便,特此记录。 有时候我们会需要读取内存里面的图片,为了提高效率,避免了从硬盘重复读取文件所消耗的时间。 以下是代码: //data为图像再内存...
  • swjtu_ray
  • swjtu_ray
  • 2016-09-13 21:09:16
  • 3003
收藏助手
不良信息举报
您举报文章:图片二次加载后直接从内存中提取
举报原因:
原因补充:

(最多只允许输入30个字)