文章连接: https://mp.weixin.qq.com/s/FQmYfT-KYiDbp-0HzK_Hpw
项目中常常会用到分享的功能,有分享连接也有分享图片,其中分享图片有的须要移动端对屏幕内容进行截取分享,说白了就是将view 转成bitmap 再到图片分享,还有一种状况是将不可见的view 转成bitmap ,这种view是没有直接显示在界面上的,须要咱们使用inflate 进行建立的view。git
先看经过 DrawingCache 方法来截取普通的view,获取它的视图(Bitmap)。github
private Bitmap createBitmap(View view) { view.buildDrawingCache(); Bitmap bitmap = view.getDrawingCache(); return bitmap; }
这个方法适用于view 已经显示在界面上了,能够得到view 的宽高实际大小,进而经过DrawingCache 保存为bitmap。微信
可是 若是要截取的view 没有在屏幕上显示彻底的,例如要截取的是超过一屏的 scrollview ,经过上面这个方法是获取不到bitmap的,须要使用下面方法,传的view 是scrollview 的子view(LinearLayout)等, 固然彻底显示的view(第一种状况的view) 也能够使用这个方法截取。布局
public Bitmap createBitmap2(View v) { Bitmap bmp = Bitmap.createBitmap(v.getWidth(), v.getHeight(), Bitmap.Config.ARGB_8888); Canvas c = new Canvas(bmp); c.drawColor(Color.WHITE); v.draw(c); return bmp; }
还有一种 是view彻底没有显示在界面上,经过inflate 转化的view,这时候经过 DrawingCache 是获取不到bitmap 的,也拿不到view 的宽高,以上两种方法都是不可行的。第三种方法经过measure、layout 去得到view 的实际尺寸。学习
public Bitmap createBitmap3(View v, int width, int height) { //测量使得view指定大小 int measuredWidth = View.MeasureSpec.makeMeasureSpec(width, View.MeasureSpec.EXACTLY); int measuredHeight = View.MeasureSpec.makeMeasureSpec(height, View.MeasureSpec.EXACTLY); v.measure(measuredWidth, measuredHeight); //调用layout方法布局后,能够获得view的尺寸大小 v.layout(0, 0, v.getMeasuredWidth(), v.getMeasuredHeight()); Bitmap bmp = Bitmap.createBitmap(v.getWidth(), v.getHeight(), Bitmap.Config.ARGB_8888); Canvas c = new Canvas(bmp); c.drawColor(Color.WHITE); v.draw(c); return bmp; } View view = LayoutInflater.from(this).inflate(R.layout.view_inflate, null, false); //这里传值屏幕宽高,获得的视图即全屏大小 createBitmap3(view, getScreenWidth(), getScreenHeight());
另外写了个简易的保存图片的方法,方便查看效果的。ui
private void saveBitmap(Bitmap bitmap) { FileOutputStream fos; try { File root = Environment.getExternalStorageDirectory(); File file = new File(root, "test.png"); fos = new FileOutputStream(file); bitmap.compress(Bitmap.CompressFormat.PNG, 90, fos); fos.flush(); fos.close(); } catch (Exception e) { e.printStackTrace(); } }
github地址:https://github.com/taixiang/view2bitmapthis
欢迎关注个人博客:https://www.manjiexiang.cn/ spa
更多精彩欢迎关注微信号:春风十里不如认识你
一块儿学习 一块儿进步code