关于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 ...
随机推荐
- DOM 节点
<html> <head> <title>DOM 教程</title> </head> <body> <h1>DOM ...
- windows下 在cmd中输入ls命令出现“ls不是内部或外部命令“解决方法
1.新建一个文件命名为 ls.bat 2.打开编辑这个文件 输入: @echo off dir 3.将这个文件放在C:\windows目录下
- ML笔记:Classification: Logistic Regression
- [SDOI2010]古代猪文
题目背景 “在那山的那边海的那边有一群小肥猪.他们活泼又聪明,他们调皮又灵敏.他们自由自在生活在那绿色的大草坪,他们善良勇敢相互都关心……” ——选自猪王国民歌 很久很久以前,在山的那边海的那边的某片 ...
- LOJ #6119. 「2017 山东二轮集训 Day7」国王
Description 在某个神奇的大陆上,有一个国家,这片大陆的所有城市间的道路网可以看做是一棵树,每个城市要么是工业城市,要么是农业城市,这个国家的人认为一条路径是 exciting 的,当且仅当 ...
- ●POJ 3237 Tree
题链: http://poj.org/problem?id=3237 题解: LCT 说一说如何完成询问操作就好了(把一条链的边权变成相反数的操作可以类比着来): 首先明确一下,我们把边权下放到点上. ...
- [ HOJ 2713]Matrix1[网络流] 最大点权独立集问题
题目大意: 一个 N*M 的网格,每个单元都有一块价值 Cij 的宝石.问最多能取多少价值的宝石且任意两块宝石不相邻.(1 <= N, M <= 50, 0 <= Cij <= ...
- 51 nod 1188 最大公约数之和 V2
1188 最大公约数之和 V2 题目来源: UVA 基准时间限制:2 秒 空间限制:262144 KB 分值: 160 难度:6级算法题 给出一个数N,输出小于等于N的所有数,两两之间的最大公约数 ...
- poj 1269 线段与线段相交
Intersecting Lines Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 13605 Accepted: 60 ...
- 【Codeforces 851D Arpa and a list of numbers】
Arpa的数列要根据GCD变成好数列. ·英文题,述大意: 给出一个长度为n(n<=5000000)的序列,其中的元素a[i]<=106,然后输入两个数x,y(x,y<=1 ...