1、计算机表示图形的几种方式

1)BMP :几乎不进行压缩 占用空间比较大

2)JPG : 在BMP的基础上对相邻的像素进行压缩,占用空间比BMP小

3) PNG : 在JPG的基础上进一步压缩 占用空间比较小

这是对三种格式进行一个简单的介绍,知道是怎么回事就行,在android中一般都用png格式的图片,因为他占用空间小

2、图形的大小

图形的大小 = 图片的总像素*每个像素的大小

图片总像素 = 图片的长*图片的高

可以看到 保存一张图片时有一些选项看一下其中几个

单色位图: 每个像素最多可以表示2种颜色,只需要使用长度为1的二进制位来表示,因此每个像素占1/8byte

16色位图: 每个像素最多可以表示16种颜色,所以只需要长度为4的二进制表示,因此每个像素占1/2byte

256色位图: 每个像素最多可以表示256中颜色,所以只需要长度是8的二级制位表示就可以了,因此每个像素占1byte

24位位图:即RGB三原色位图 每个像素占3个byte。

3、android 加载大图失败的原因

知道了上面的知识后,来研究一下android 当中的位图信息,

在android 中采用ARGB来表示颜色,所以每个像素会占4byte。

当用BitmapFactory加载原图时当图片的宽和高远大于手机的宽和高时会出现

E/AndroidRuntime(2128): Caused by: java.lang.OutOfMemoryError
E/dalvikvm-heap(2128): Out of memory on a 30720012-byte allocation.

也就是内存越界异常,但是看图片的大小并没有超过系统所分给每个应用的内存大小。

所以可以确定 加载原图时图片的计算方式是按上面的公式计算的。

4、加载大图的方法

知道了加载大图失败的原因后,解决OutOfMemoryError的方法也就很明显了,对的 就是缩放。

下面就看看下缩放的步骤

1) 获取手机的宽和高

2)获取图片的宽和高

3)计算缩放比

4)按照缩放比显示图片


        //1) 获取手机的宽和高
        WindowManager wm = (WindowManager) getSystemService(WINDOW_SERVICE);
        int screenWidth = wm.getDefaultDisplay().getWidth();
        int screenHeight = wm.getDefaultDisplay().getHeight();
        //2)获取图片的宽和高
        BitmapFactory.Options options = new Options();
        //返回一个null 没有bitmap,不去真正解析位图,但是能返回图片的一些信息。
        options.inJustDecodeBounds = true;
        BitmapFactory.decodeResource(getResources(), R.drawable.dog,options);
        int imagWidth = options.outWidth;
        int imagHeight = options.outHeight;
        //3)计算缩放比
        int scale =1;
        int scalex = imagWidth / screenWidth;
        int scaley = imagHeight / screenHeight;
        scale = Math.max(scalex, scaley);
        //4)按照缩放比显示图片
        options.inSampleSize = scale;
        //开始真正的解析位图
        options.inJustDecodeBounds = false;
        Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.dog,options);

5、Bitmap修改图片

在看一种情况,当用BitmapFactory.decodeXXX decode一张图片后,需要修改图片

如:

 Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.ic_launcher);
        bitmap.setPixel(100, 20, Color.RED);

发现push到手机后报错了,这是因为原图是不能被修改的。

那么当需要修改图片是怎么办呢?

对了 可以操作原图的副本,副本是可以修改的

创建原图的副本步骤如下:

1)创建模板

2)创建一个画布以原图作为模板

3)创建一个画笔

4)开始拷贝原图

Bitmap bitmap = BitmapFactory.decodeResource(getResources(),
                R.drawable.ic_launcher);
        // bitmap.setPixel(100, 20, Color.RED);
        // 1)创建模板
        Bitmap copybitmap = Bitmap.createBitmap(bitmap.getWidth(),
                bitmap.getHeight(), bitmap.getConfig());
        // 2)创建一个画布以原图作为模板
        Canvas canvas = new Canvas(copybitmap);
        // 3)创建一个画笔
        Paint paint = new Paint();
        // 4)开始拷贝原图
        canvas.drawBitmap(bitmap, new Matrix(), paint);

        // 修改图片
        copybitmap.setPixel(20, 30, Color.RED);

至此是我工作中发现的一些小的细节,别的一些操作位图的方法应该都是大家所熟知的了,就不再班门弄斧了

关于bitmap你不知道的一些事的更多相关文章

  1. 开源 VS 商业,消息中间件你不知道的那些事

    11月23日,新炬网络中间件技术专家刘拓老师在DBA+社群中间件用户组进行了一次主题为“开源 VS 商业,消息中间件你不知道的那些事”的线上分享.小编特别整理出其中精华内容,供大家学习交流. 嘉宾简介 ...

  2. EntityFramework之你不知道的那些事(七)

    前言 前面一系列几乎都是循序渐进式的进行叙述,似乎脚步走得太快了,于是我开始歇一歇去追寻一些我所不太了解的细枝末节,在此过程中也屡次碰壁,但是唯有如此才能更好的成长,不是吗!希望此文对你亦有帮助. 属 ...

  3. transform你不知道的那些事

    transform是诸多css3新特性中最打动我的,因为它让方方正正的box module变得真实了. transform通过一组函数实现了对盒子大小.位置.角度的2D或者3D变换.不过很长时间内,我 ...

  4. 关于cout<<ends你不知道的那些事

    关于ends是C++中比较基础的一个东西,但是可能不是每个人都能够清楚的理解这是个什么东西,我就经历了这么一个过程,写出来让大家看看,有什么理解的不对的地方欢迎拍砖. 今天以前我对ends的理解是:输 ...

  5. Javascript你不知道的那些事!(数字计算篇-变态篇)无意中聊天发现的一些奇怪的事情

    javascript:alert(0.1 + 0.2) 如果看到这样一道题你会怎么思考了!大家肯定第一反应0.3,但是考虑到我已经这样问了!那么幼稚的答案我会专门写篇文章吗 然后人就开始折磨自己了会不 ...

  6. iOS应用安全开发,你不知道的那些事

    来源:http://www.csdn.net/article/2014-04-30/2819573-The-Secret-Of-App-Dev-Security 摘要:iOS应用由于其直接运行在手机上 ...

  7. vue中动态引入图片为什么要是require, 你不知道的那些事

    相信用过vue的小伙伴,肯定被面试官问过这样一个问题:在vue中动态的引入图片为什么要使用require 有些小伙伴,可能会轻蔑一笑:呵,就这,因为动态添加src被当做静态资源处理了,没有进行编译,所 ...

  8. android 自定义view之选座功能

    效果图: 界面比较粗糙,主要看原理. 这个界面主要包括以下几部分 1.座位 2.左边的排数 3.左上方的缩略图 4.缩略图中的红色区域 5.手指移动时跟随移动 6.两个手指缩放时跟随缩放 主要技术点 ...

  9. Es6的那些事

    现在看招聘网站上的要求,作为前端er~都要熟悉甚至精通(滑稽脸)es6,项目中也经常用,啥let,const,尤其是用react的同学,肯定对解构赋值不会陌生,今天逛淘宝前端的博客,看到一篇名为Es6 ...

随机推荐

  1. DOM 节点

    <html> <head> <title>DOM 教程</title> </head> <body> <h1>DOM ...

  2. windows下 在cmd中输入ls命令出现“ls不是内部或外部命令“解决方法

    1.新建一个文件命名为 ls.bat 2.打开编辑这个文件 输入: @echo off dir 3.将这个文件放在C:\windows目录下

  3. ML笔记:Classification: Logistic Regression

  4. [SDOI2010]古代猪文

    题目背景 “在那山的那边海的那边有一群小肥猪.他们活泼又聪明,他们调皮又灵敏.他们自由自在生活在那绿色的大草坪,他们善良勇敢相互都关心……” ——选自猪王国民歌 很久很久以前,在山的那边海的那边的某片 ...

  5. LOJ #6119. 「2017 山东二轮集训 Day7」国王

    Description 在某个神奇的大陆上,有一个国家,这片大陆的所有城市间的道路网可以看做是一棵树,每个城市要么是工业城市,要么是农业城市,这个国家的人认为一条路径是 exciting 的,当且仅当 ...

  6. ●POJ 3237 Tree

    题链: http://poj.org/problem?id=3237 题解: LCT 说一说如何完成询问操作就好了(把一条链的边权变成相反数的操作可以类比着来): 首先明确一下,我们把边权下放到点上. ...

  7. [ HOJ 2713]Matrix1[网络流] 最大点权独立集问题

    题目大意: 一个 N*M 的网格,每个单元都有一块价值 Cij 的宝石.问最多能取多少价值的宝石且任意两块宝石不相邻.(1 <= N, M <= 50, 0 <= Cij <= ...

  8. 51 nod 1188 最大公约数之和 V2

    1188 最大公约数之和 V2 题目来源: UVA 基准时间限制:2 秒 空间限制:262144 KB 分值: 160 难度:6级算法题   给出一个数N,输出小于等于N的所有数,两两之间的最大公约数 ...

  9. poj 1269 线段与线段相交

    Intersecting Lines Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 13605   Accepted: 60 ...

  10. 【Codeforces 851D Arpa and a list of numbers】

    Arpa的数列要根据GCD变成好数列. ·英文题,述大意:      给出一个长度为n(n<=5000000)的序列,其中的元素a[i]<=106,然后输入两个数x,y(x,y<=1 ...