关于bitmap你不知道的一些事
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你不知道的一些事的更多相关文章
- 开源 VS 商业,消息中间件你不知道的那些事
11月23日,新炬网络中间件技术专家刘拓老师在DBA+社群中间件用户组进行了一次主题为“开源 VS 商业,消息中间件你不知道的那些事”的线上分享.小编特别整理出其中精华内容,供大家学习交流. 嘉宾简介 ...
- EntityFramework之你不知道的那些事(七)
前言 前面一系列几乎都是循序渐进式的进行叙述,似乎脚步走得太快了,于是我开始歇一歇去追寻一些我所不太了解的细枝末节,在此过程中也屡次碰壁,但是唯有如此才能更好的成长,不是吗!希望此文对你亦有帮助. 属 ...
- transform你不知道的那些事
transform是诸多css3新特性中最打动我的,因为它让方方正正的box module变得真实了. transform通过一组函数实现了对盒子大小.位置.角度的2D或者3D变换.不过很长时间内,我 ...
- 关于cout<<ends你不知道的那些事
关于ends是C++中比较基础的一个东西,但是可能不是每个人都能够清楚的理解这是个什么东西,我就经历了这么一个过程,写出来让大家看看,有什么理解的不对的地方欢迎拍砖. 今天以前我对ends的理解是:输 ...
- Javascript你不知道的那些事!(数字计算篇-变态篇)无意中聊天发现的一些奇怪的事情
javascript:alert(0.1 + 0.2) 如果看到这样一道题你会怎么思考了!大家肯定第一反应0.3,但是考虑到我已经这样问了!那么幼稚的答案我会专门写篇文章吗 然后人就开始折磨自己了会不 ...
- iOS应用安全开发,你不知道的那些事
来源:http://www.csdn.net/article/2014-04-30/2819573-The-Secret-Of-App-Dev-Security 摘要:iOS应用由于其直接运行在手机上 ...
- vue中动态引入图片为什么要是require, 你不知道的那些事
相信用过vue的小伙伴,肯定被面试官问过这样一个问题:在vue中动态的引入图片为什么要使用require 有些小伙伴,可能会轻蔑一笑:呵,就这,因为动态添加src被当做静态资源处理了,没有进行编译,所 ...
- android 自定义view之选座功能
效果图: 界面比较粗糙,主要看原理. 这个界面主要包括以下几部分 1.座位 2.左边的排数 3.左上方的缩略图 4.缩略图中的红色区域 5.手指移动时跟随移动 6.两个手指缩放时跟随缩放 主要技术点 ...
- Es6的那些事
现在看招聘网站上的要求,作为前端er~都要熟悉甚至精通(滑稽脸)es6,项目中也经常用,啥let,const,尤其是用react的同学,肯定对解构赋值不会陌生,今天逛淘宝前端的博客,看到一篇名为Es6 ...
随机推荐
- [LeetCode] Number of Distinct Islands II 不同岛屿的个数之二
Given a non-empty 2D array grid of 0's and 1's, an island is a group of 1's (representing land) conn ...
- [LeetCode] Predict the Winner 预测赢家
Given an array of scores that are non-negative integers. Player 1 picks one of the numbers from eith ...
- for-each的坑(Hollis)
直接用代码来说明: public class ForEach { public static void main(String[] args) { List<String> list = ...
- [CEOI2008]order
Description 有N个工作,M种机器,每种机器你可以租或者买过来. 每个工作包括若干道工序,每道工序需要某种机器来完成,你可以通过购买或租用机器来完成. 现在给出这些参数,求最大利润 Solu ...
- Codeforces Round #460 D. Karen and Cards
Description Karen just got home from the supermarket, and is getting ready to go to sleep. After tak ...
- ●BZOJ 2434: [Noi2011]阿狸的打字机
●赘述题目 (题意就不赘述了) ●解法: ●我先想的一个比较暴力的方法(要TLE): (ac自动机)先求出last数组(参见刘汝佳的解释:last[j]:表示j节点沿着失配指针往回走时,遇到的下一个单 ...
- Codeforces Round #402 (Div. 1)
A题卡壳了,往离线倒着加那方面想了会儿,后来才发现方向错了,二十多分钟才过掉,过了B后做D,想法好像有点问题,最后只过两题,掉分了,差一点回紫. AC:AB Rank:173 Rating:2227- ...
- ScalaPB(0): 找寻合适的内部系统微服务集成工具
前一段时间我们探讨了SDP的一个基于集群的综合数据平台解决方案,由多种数据库组成,包括:JDBC, Cassandra 及MongoDB.其中Cassandra和MongoDB属于分布式数据库,可以在 ...
- Linux下实现普通用户免密码登录【超详细】
现有需求,需要把所有服务器的root和密码登录都禁用,只开放普通用户登录,这时需要给普通用户配置秘钥文件,实现无密码登录 如果普通用户需要root权限,在root用户下执行命令:visudo [roo ...
- C语言程序设计第二次作业—————顺序结构
(一)改错题 1.输出带框文字:在屏幕上输出以下3行信息. ************* Welcome ************* 源程序 include int mian() { printf(&q ...