Android 中图可以用到的图片处理类 BitmapUtils
Android在实际开发中很多时候都要对图片进行一定的处理,这里总结的BitmapUtils 类包括一下几个功能:
1.Android图片倒影,
2.Android图片模糊处理,
3.Android图片圆角处理,
4.图片沿着y轴旋转一定角度,
5.Android给图片添加边框。
接下来就直接上代码了,代码中有一定的解释。直接哪来用就可以了。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
|
/* * @Title: BitmapUtils.java * @Copyright: Corporation. Ltd. Copyright 1998-2018, All rights reserved * @Description: TODO<请描述此文件是做什么的> * @author: xjp * @data: 2014年9月18日 上午10:10:30 * @version: V1.0 */ package com.mktech.bitmaputils; import android.annotation.SuppressLint; import android.annotation.TargetApi; import android.content.Context; import android.graphics.Bitmap; import android.graphics.BitmapShader; import android.graphics.Camera; import android.graphics.Canvas; import android.graphics.LinearGradient; import android.graphics.Matrix; import android.graphics.Paint; import android.graphics.PorterDuffXfermode; import android.graphics.Bitmap.Config; import android.graphics.Rect; import android.graphics.RectF; import android.graphics.Shader; import android.graphics.Shader.TileMode; import android.os.Build; import android.renderscript.Allocation; import android.renderscript.Element; import android.renderscript.RenderScript; import android.renderscript.ScriptIntrinsicBlur; import android.util.Log; /** * TODO<请描述这个类是干什么的> * * @author xjp * @data: 2014年9月18日 上午10:10:30 * @version: V1.0 */ public class BitmapUtils { private static final String TAG = "BitmapUtils" ; /** * * TODO<创建倒影图片> * @throw * @return Bitmap * @param srcBitmap 源图片的bitmap * @param reflectionHeight 图片倒影的高度 */ public static Bitmap createReflectedBitmap(Bitmap srcBitmap, int reflectionHeight) { if ( null == srcBitmap) { Log.e(TAG, "the srcBitmap is null" ); return null ; } // The gap between the reflection bitmap and original bitmap. final int REFLECTION_GAP = 0 ; int srcWidth = srcBitmap.getWidth(); int srcHeight = srcBitmap.getHeight(); if ( 0 == srcWidth || srcHeight == 0 ) { Log.e(TAG, "the srcBitmap is null" ); return null ; } // The matrix Matrix matrix = new Matrix(); matrix.preScale( 1 , - 1 ); try { // The reflection bitmap, width is same with original's, height is // half of original's. Bitmap reflectionBitmap = Bitmap.createBitmap(srcBitmap, 0 , srcHeight - reflectionHeight, srcWidth, reflectionHeight, matrix, false ); if ( null == reflectionBitmap) { Log.e(TAG, "Create the reflectionBitmap is failed" ); return null ; } // Create the bitmap which contains original and reflection bitmap. Bitmap bitmapWithReflection = Bitmap.createBitmap(srcWidth, srcHeight + reflectionHeight, Bitmap.Config.ARGB_8888); if ( null == bitmapWithReflection) { return null ; } // Prepare the canvas to draw stuff. Canvas canvas = new Canvas(bitmapWithReflection); // Draw the original bitmap. canvas.drawBitmap(srcBitmap, 0 , 0 , null ); // Draw the reflection bitmap. canvas.drawBitmap(reflectionBitmap, 0 , srcHeight + REFLECTION_GAP, null ); Paint paint = new Paint(); paint.setAntiAlias( true ); LinearGradient shader = new LinearGradient( 0 , srcHeight, 0 , bitmapWithReflection.getHeight() + REFLECTION_GAP, 0x70FFFFFF , 0x00FFFFFF , TileMode.MIRROR); paint.setShader(shader); paint.setXfermode( new PorterDuffXfermode( android.graphics.PorterDuff.Mode.DST_IN)); canvas.save(); // Draw the linear shader. canvas.drawRect( 0 , srcHeight, srcWidth, bitmapWithReflection.getHeight() + REFLECTION_GAP, paint); if (reflectionBitmap != null && !reflectionBitmap.isRecycled()){ reflectionBitmap.recycle(); reflectionBitmap = null ; } canvas.restore(); return bitmapWithReflection; } catch (Exception e) { e.printStackTrace(); } Log.e(TAG, "Create the reflectionBitmap is failed" ); return null ; } /** * * TODO<图片圆角处理> * @throw * @return Bitmap * @param srcBitmap 源图片的bitmap * @param ret 圆角的度数 */ public static Bitmap getRoundImage(Bitmap srcBitmap, float ret) { if ( null == srcBitmap){ Log.e(TAG, "the srcBitmap is null" ); return null ; } int bitWidth = srcBitmap.getWidth(); int bitHight = srcBitmap.getHeight(); BitmapShader bitmapShader = new BitmapShader(srcBitmap, Shader.TileMode.CLAMP, Shader.TileMode.CLAMP); Paint paint = new Paint(); paint.setAntiAlias( true ); paint.setShader(bitmapShader); RectF rectf = new RectF( 0 , 0 , bitWidth, bitHight); Bitmap outBitmap = Bitmap.createBitmap(bitWidth, bitHight, Config.ARGB_8888); Canvas canvas = new Canvas(outBitmap); canvas.drawRoundRect(rectf, ret, ret, paint); canvas.save(); canvas.restore(); return outBitmap; } /** * * TODO<图片沿着Y轴旋转一定角度> * @throw * @return Bitmap * @param srcBitmap 源图片的bitmap * @param reflectionHeight 图片倒影的高度 * @param rotate 图片旋转的角度 */ public static Bitmap skewImage(Bitmap srcBitmap, float rotate, int reflectionHeight) { if ( null == srcBitmap){ Log.e(TAG, "the srcBitmap is null" ); return null ; } Bitmap reflecteBitmap = createReflectedBitmap(srcBitmap, reflectionHeight); if ( null == reflecteBitmap){ Log.e(TAG, "failed to createReflectedBitmap" ); return null ; } int wBitmap = reflecteBitmap.getWidth(); int hBitmap = reflecteBitmap.getHeight(); float scaleWidth = (( float ) 180 ) / wBitmap; float scaleHeight = (( float ) 270 ) / hBitmap; Matrix matrix = new Matrix(); matrix.postScale(scaleWidth, scaleHeight); reflecteBitmap = Bitmap.createBitmap(reflecteBitmap, 0 , 0 , wBitmap, hBitmap, matrix, true ); Camera localCamera = new Camera(); localCamera.save(); Matrix localMatrix = new Matrix(); localCamera.rotateY(rotate); localCamera.getMatrix(localMatrix); localCamera.restore(); localMatrix.preTranslate(-reflecteBitmap.getWidth() >> 1 , -reflecteBitmap.getHeight() >> 1 ); Bitmap localBitmap2 = Bitmap.createBitmap(reflecteBitmap, 0 , 0 , reflecteBitmap.getWidth(), reflecteBitmap.getHeight(), localMatrix, true ); Bitmap localBitmap3 = Bitmap.createBitmap(localBitmap2.getWidth(), localBitmap2.getHeight(), Bitmap.Config.ARGB_8888); Canvas localCanvas = new Canvas(localBitmap3); Paint localPaint = new Paint(); localPaint.setAntiAlias( true ); localPaint.setFilterBitmap( true ); localCanvas.drawBitmap(localBitmap2, 0 .0F, 0 .0F, localPaint); if ( null != reflecteBitmap && !reflecteBitmap.isRecycled()) { reflecteBitmap.recycle(); reflecteBitmap = null ; } if ( null != localBitmap2 && !localBitmap2.isRecycled()) { localBitmap2.recycle(); localBitmap2 = null ; } localCanvas.save(); localCanvas.restore(); return localBitmap3; } /** * * TODO<图片模糊化处理> * @throw * @return Bitmap * @param bitmap 源图片 * @param radius The radius of the blur Supported range 0 < radius <= 25 * @param context 上下文 */ @TargetApi (Build.VERSION_CODES.JELLY_BEAN_MR1) @SuppressLint ( "NewApi" ) public static Bitmap blurBitmap(Bitmap bitmap, float radius,Context context){ //Let's create an empty bitmap with the same size of the bitmap we want to blur Bitmap outBitmap = Bitmap.createBitmap(bitmap.getWidth(), bitmap.getHeight(), Config.ARGB_8888); //Instantiate a new Renderscript RenderScript rs = RenderScript.create(context); //Create an Intrinsic Blur Script using the Renderscript ScriptIntrinsicBlur blurScript = ScriptIntrinsicBlur.create(rs, Element.U8_4(rs)); //Create the Allocations (in/out) with the Renderscript and the in/out bitmaps Allocation allIn = Allocation.createFromBitmap(rs, bitmap); Allocation allOut = Allocation.createFromBitmap(rs, outBitmap); //Set the radius of the blur if (radius > 25 ){ radius = 25 .0f; } else if (radius <= 0 ){ radius = 1 .0f; } blurScript.setRadius(radius); //Perform the Renderscript blurScript.setInput(allIn); blurScript.forEach(allOut); //Copy the final bitmap created by the out Allocation to the outBitmap allOut.copyTo(outBitmap); //recycle the original bitmap bitmap.recycle(); bitmap = null ; //After finishing everything, we destroy the Renderscript. rs.destroy(); return outBitmap; } /** * TODO<给图片添加指定颜色的边框> * @param srcBitmap 原图片 * @param borderWidth 边框宽度 * @param color 边框的颜色值 * @return */ public static Bitmap addFrameBitmap(Bitmap srcBitmap, int borderWidth, int color) { if (srcBitmap == null ){ Log.e(TAG, "the srcBitmap or borderBitmap is null" ); return null ; } int newWidth = srcBitmap.getWidth() + borderWidth ; int newHeight = srcBitmap.getHeight() + borderWidth ; Bitmap outBitmap = Bitmap.createBitmap(newWidth, newHeight, Config.ARGB_8888); Canvas canvas = new Canvas(outBitmap); Rect rec = canvas.getClipBounds(); rec.bottom--; rec.right--; Paint paint = new Paint(); //设置边框颜色 paint.setColor(color); paint.setStyle(Paint.Style.STROKE); //设置边框宽度 paint.setStrokeWidth(borderWidth); canvas.drawRect(rec, paint); canvas.drawBitmap(srcBitmap, borderWidth/ 2 , borderWidth/ 2 , null ); canvas.save(Canvas.ALL_SAVE_FLAG); canvas.restore(); if (srcBitmap != null && !srcBitmap.isRecycled()){ srcBitmap.recycle(); srcBitmap = null ; } return outBitmap; } } |
以上代码经验证可以直接使用。
分享。
完结。
来自:http://www.2cto.com/kf/201409/335681.html
Android 中图可以用到的图片处理类 BitmapUtils的更多相关文章
- Android 中图能够用到的图片处理类 BitmapUtils
Android在实际开发中非常多时候都要对图片进行一定的处理,这里总结的BitmapUtils 类包含一下几个功能: 1.Android图片倒影, 2.Android图片模糊处理, 3.Android ...
- Android中使用开源框架android-image-indicator实现图片轮播部署
之前的博文中有介绍关于图片轮播的实现方式,分别为(含超链接): 1.<Android中使用ViewFlipper实现屏幕切换> 2.<Android中使用ViewPager实现屏幕页 ...
- android 中ImageButton按下改变背景图片的效果
最近在做一个app的登陆界面,才发现原来认为很简单的UI效果,其实背后却蕴含的知识很多,积累一个算一个吧. 实现方法有两种:一种是添加代码,一种是配置xml文件. 方法一:代码添加 ImageButt ...
- 浅谈Android中拍照、从相册选择图片并截图相关知识点
前言 我们在Android开发中经常会需要使用相机或者从相册中选取图片的情况,今天就把这里面相关的知识点总结下,方便以后开发的时候使用. 1.相机拍照并可自定义截图功能 我们先来看如何使用Intent ...
- android中图型的阴影效果(shadow-effect-with-custom-shapes)
思路: 在自己定义shape中添加一层或多层,并错开.就可以显示阴影效果.为添加立体感,button按下的时候,仅仅设置一层.我们能够通过top, bottom, right 和 left 四个參数来 ...
- 关于android中调用系统拍照,返回图片是旋转90度
转载博客:http://blog.csdn.net/walker02/article/details/8211628 项目开发中遇到的一个问题,对于三星手机在做手机照片选择时出现图片显示不正常,研究后 ...
- Android中的几种解析XML文件的类
Ø DOM解析 优点: 1.XML树在内存中完整存储,因此可以直接修改其数据和结构. 2.可以通过该解析器随时访问XML树中的任何一个节点. 3.DOM解析器的API在使用上也相对比较简单. 缺点:如 ...
- Android开发之使用Handler封装下载图片工具类(源码分享)
假设每下载一张图片,就得重写一次Http协议,多线程的启动和handler的信息传递就显得太麻烦了,我们直接来封装一个工具类,便于我们以后在开发时随时能够调用. (1)在清单文件加入权限 <us ...
- Android中SQLite数据库操作(2)——SQLiteOpenHelper类
如果开发者对SQL语法不熟悉,我要告诉你一个好消息,Android提供了一个SQLiteOpenHelper类. 在实际项目中很少使用SQLiteDatabase的方法(请看:http://blog. ...
随机推荐
- python爬虫基础16-cookie在爬虫中的应用
Cookie的Python爬虫应用 Cookie是什么 Cookie,有时也用其复数形式 Cookies,英文是饼干的意思.指某些网站为了辨别用户身份.进行 session 跟踪而储存在用户本地终端上 ...
- LeetCode(166) Fraction to Recurring Decimal
题目 Given two integers representing the numerator and denominator of a fraction, return the fraction ...
- Ice cream samples Gym - 101670G 滑动扫描
题目:题目链接 思路:比赛中读错了题,题目要求选一个连续区间,却读成了随便选取几个柜台,英语要好好学啊,读懂题就很简单了,扫一遍就出结果了 AC代码: #include <iostream> ...
- Android开发——AsyncTask的使用以及源码解析
.AsyncTask使用介绍 转载请标明出处:http://blog.csdn.net/seu_calvin/article/details/52172248 AsyncTask封装了Thread和 ...
- Win7通知区域的图标怎么去除?
由于本人有洁癖,最近在用win7的时候,很收不了已经卸载了的一些软件,在win7右下角的通知区域图标中还留有痕迹,于是上网查找了下解决方案. 用以下方法完美解决问题. 这里依然是以注册表的修改方法为主 ...
- python中json操作了解
什么是接口? 交换数据 http://openweathermap.org/current json简介 JSON 是存储和交换文本信息的语法.类似 XML JSON 语法是 JavaScript 语 ...
- cinema 4d 包括宝典 --- 改线 循环边 建模布线原则
cinema 4d 一.视图控制与物体控制 1.摇移 alt+鼠标左键 转圈看物体 改变角度 2.平移 alt +鼠标中键 不改变角度 移动 3.推拉 alt+鼠标右键 ...
- 薛XX后代的IQ CSU1597【循环节】或【快速幂】
薛先生想改变后代的IQ,为此他发明了一种药,这种药有三种属性:A, B,P.他父亲的智商为X,薛先生的智商为Y,用了这种药之后,薛先生的孩子的智商就可以变为(AX+BY) mod P.后代的智商以此类 ...
- C++程序在Windows平台上各种定位内存泄漏的方法,并对比了它们的优缺点
一.前言 在Linux平台上有valgrind可以非常方便的帮助我们定位内存泄漏,因为Linux在开发领域的使用场景大多是跑服务器,再加上它的开源属性,相对而言,处理问题容易形成“统一”的标准.而在W ...
- spring AOP详解〇
AOP正在成为软件开发的下一个圣杯.使用AOP,你可以将处理aspect的代码注入主程序,通常主程序的主要目的并不在于处理这些aspect.AOP可以防止代码混乱. 为了理解AOP如何做到这点,考虑一 ...