Android 中WebView 截图的实现方式
HybridApp中网页部分的分享方式越来越趋向于多元化,比较常见的用户操作方式有:复制网页链接式,直接选择目标应用自动分享式等。其中,截图行为,越来越成为丰富用户操作、备受用户喜爱的互动方式之一,我们在很多内容社区类应用中都能看到这种功能。这篇文章总结一下Android应用中WebView截图的实现方式。
WebView作为一种特殊的控件,自然不能像其他系统View或者截屏的方式来获取截图(多为截取长图)。如:
publicstaticBitmapgetScreenShot(Viewview){ ViewscreenView=view.getRootView(); screenView.setDrawingCacheEnabled(true); Bitmapbitmap=Bitmap.createBitmap(screenView.getDrawingCache()); screenView.setDrawingCacheEnabled(false); returnbitmap; }
如果将上述代码套在WebView上使用,将会得到内容不完整的截图。而事实上,WebView系统本身提供有对应的API来获取Bitmap对象。
privateBitmapcaptureWebView(WebViewwebView){ Picturepicture=webView.capturePicture(); intwidth=picture.getWidth(); intheight=picture.getHeight(); if(width>0&&height>0){ Bitmapbitmap=Bitmap.createBitmap(width,height,Bitmap.Config.RGB_565); Canvascanvas=newCanvas(bitmap); picture.draw(canvas); returnbitmap; } returnnull; }
获取到Bitmap对象后,利用这段代码可以将其保存到设备的存储卡中:
privatevoidsaveBitmap(Bitmapbitmap){ Filefile=newFile(Environment.getExternalStorageDirectory(),System.currentTimeMillis()+".jpg"); try{ FileOutputStreamfos=newFileOutputStream(file); bitmap.compress(CompressFormat.JPEG,80,fos); fos.flush(); fos.close(); }catch(java.io.IOExceptione){ e.printStackTrace(); } }
简单两步,大功告成。然而当你在Android5.0及更高版本系统的设备中操作时,你会发现,截图显示并不完全。虽然图片宽高符合实际要求,但是内容只包含当前屏幕显示区域内WebView的内容。
原因在于,为了减少内存占用和提升性能,从Android5.0开始,系统能够智能化地选择部分Html文档进行渲染。所以,默认情况下,我们只能截取到部分屏幕显示区域内WebView的内容,也就出现了上述问题。
不过,系统也提供了对应的API来修改这一默认优化行为。代码很简单:
if(Build.VERSION.SDK_INT>=Build.VERSION_CODES.LOLLIPOP){ WebView.enableSlowWholeDocumentDraw(); }
需要注意的是,这段代码必须添加在WebView实例被创建之前。如果使用Activity的话,也就是在setContentView()方法前面。
虽然capturePicture()方法已经能够获取WebView截图,但是到API19时该方法被系统废弃掉了。取而代之的是使用onDraw()方法获取获取Bitmap对象。
privateBitmapcaptureWebView(WebViewwebView){ floatscale=webView.getScale(); intwidth=webView.getWidth(); intheight=(int)(webView.getHeight()*scale); Bitmapbitmap=Bitmap.createBitmap(width,height,Bitmap.Config.RGB_565); Canvascanvas=newCanvas(bitmap); webView.draw(canvas); returnbitmap; }
这里又要提到的是,getScale()方法从API17开始也被系统废弃掉了。所以获取scale值的另一种更优雅的方式是:
webView.setWebViewClient(newWebViewClient(){ @Override publicvoidonScaleChanged(WebViewview,floatoldScale,floatnewScale){ super.onScaleChanged(view,oldScale,newScale); scale=newScale; } });
最后一点,在实际使用过程中,我们还需要考虑到Bitmap的内存占用问题,做好异常捕获,防止OOM的出现。
总结
以上所述是小编给大家介绍的Android中WebView截图的实现方式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票的支持!