Android 马赛克(Mosaics)效果
前几天看见开源项目效果好赞,看了下代码,实现大致就是在原界面之上覆盖一成自定义的View,获取到点击的那个View的内容(Bitmap),然后在覆盖的那个自定义View的特定位置画出来,之后就是对这个Bitmap做一些列拆分,变化重绘的过程。在这里根据他对bitmap的拆分,感觉用来实现Bitmap的效果也是不错的,就试着做一做。
在这里介绍使用两种方式实现马赛克效果.开始之前先看看效果
感觉还不错吧!
1、直接绘制
public static Bitmap getMosaicsBitmap(Bitmap bmp, double precent) { long start = System.currentTimeMillis(); int bmpW = bmp.getWidth(); int bmpH = bmp.getHeight(); Bitmap resultBmp = Bitmap.createBitmap(bmpW, bmpH, Bitmap.Config.ARGB_8888); Canvas canvas = new Canvas(resultBmp); Paint paint = new Paint(); double unit; if (precent == 0) { unit = bmpW; } else { unit = 1 / precent; } double resultBmpW = bmpW / unit; double resultBmpH = bmpH / unit; for (int i = 0; i < resultBmpH; i++) { for (int j = 0; j < resultBmpW; j++) { int pickPointX = (int) (unit * (j + 0.5)); int pickPointY = (int) (unit * (i + 0.5)); int color; if (pickPointX >= bmpW || pickPointY >= bmpH) { color = bmp.getPixel(bmpW / 2, bmpH / 2); } else { color = bmp.getPixel(pickPointX, pickPointY); } paint.setColor(color); canvas.drawRect((int) (unit * j), (int) (unit * i), (int) (unit * (j + 1)), (int) (unit * (i + 1)), paint); } } canvas.setBitmap(null); long end = System.currentTimeMillis(); Log.v(TAG, "DrawTime:" + (end - start)); return resultBmp; }
2、修改像素点
public static Bitmap getMosaicsBitmaps(Bitmap bmp, double precent) { long start = System.currentTimeMillis(); int bmpW = bmp.getWidth(); int bmpH = bmp.getHeight(); int[] pixels = new int[bmpH * bmpW]; bmp.getPixels(pixels, 0, bmpW, 0, 0, bmpW, bmpH); int raw = (int) (bmpW * precent); int unit; if (raw == 0) { unit = bmpW; } else { unit = bmpW / raw; //原来的unit*unit像素点合成一个,使用原左上角的值 } if (unit >= bmpW || unit >= bmpH) { return getMosaicsBitmap(bmp, precent); } for (int i = 0; i < bmpH; ) { for (int j = 0; j < bmpW; ) { int leftTopPoint = i * bmpW + j; for (int k = 0; k < unit; k++) { for (int m = 0; m < unit; m++) { int point = (i + k) * bmpW + (j + m); if (point < pixels.length) { pixels[point] = pixels[leftTopPoint]; } } } j += unit; } i += unit; } long end = System.currentTimeMillis(); Log.v(TAG, "DrawTime:" + (end - start)); return Bitmap.createBitmap(pixels, bmpW, bmpH, Bitmap.Config.ARGB_8888); }
从效率上来看,第二中方式效率会高10倍,只要是因为第一种方式绘制的次数太多了,而绘制是比较费时间的。这里特别提示,不要在大量的循环语句内部使用Log.v(...),这是一个很耗时间的操作。
是不是很有趣,大家可以亲自动手试验一下。
相关文章
Android CameraX结合LibYUV和GPUImage自定义相机滤镜
之前使用Camera实现了一个自定义相机滤镜(Android自定义相机滤镜 ),但是运行起来有点卡顿,这次用Camerax来实现一样的效果发现很流畅,在此记录一下,也希望能帮到有需要的同学2021-12-12Android 判断SIM卡是中国移动\中国联通\中国电信(移动运营商)
本文给带来两种方法来判断sim卡是属于哪个运营商的,要实现此功能我们需要先获取手机的imsi码然后在判断,对此功能感兴趣的朋友一起通过本文学习吧2016-09-09Android四大组件之广播BroadcastReceiver详解
Android开发的四大组件分别是:活动(activity),用于表现功能;服务(service),后台运行服务,不提供界面呈现;广播接受者(Broadcast Receive),勇于接收广播;内容提供者(Content Provider),支持多个应用中存储和读取数据,相当于数据库,本篇着重介绍广播组件2021-11-11Android webview拦截H5的接口请求并返回处理好的数据代码示例
这篇文章主要给大家介绍了关于Android webview拦截H5的接口请求并返回处理好的数据的相关资料,通过WebView的shouldInterceptRequest方法,Android可以拦截并处理WebView中的H5网络请求,需要的朋友可以参考下2024-10-10
最新评论