WKWebView 整个网页截屏

WKWebView 整个网页截屏,第1张

在iOS8之前,使用的UIWebView是renderInContext 截图

但是,直接UIWebView替换成WKWebView,会发现截屏的出来的Image 是 WKWebView的背景色,里面没有任何内容

替换成上面的方法,将 renderInContext: 替换成 drawViewHierarchyInRect:afterScreenUpdates: 截屏正常

具体方法如下,实现逻辑是:

回答:Android SDK的截屏

方法步骤:如下

方法一:

       (1)主要就是利用SDK提供的ViewgetDrawingCache()方法。网上已经有很多的实例了。首先创建一个android project,然后进行Layout,画一个按键

HelloAndroidjava实现代码为:packagecomexamplehelloandroid;

这个代码会在按下app中按键的时候自动在手机的/sdcard/目录下生成一个时间戳命名的png截屏文件。

这种截屏有一个问题,就是只能截到一部分,比如电池指示部分就截不出来了。

(2)在APK中调用“adb shell screencap -pfilepath” 命令

该命令读取系统的framebuffer,需要获得系统权限:

(1) 在AndroidManifestxml文件中添加

(2) 修改APK为系统权限,将APK放到源码中编译,

(3)利用系统的API,实现Screenshot,这部分代码是系统隐藏的,需要在源码下编译,

1)修改Androidmk, 添加系统权限

LOCAL_CERTIFICATE := platform

2)修改AndroidManifestxml 文件,添加

权限

方法二:

Android ddmlib进行截屏

 Android本地编程(Native Programming)读取framebuffer

(1)命令行,框架的截屏功能是通过framebuffer来实现的,所以我们先来介绍一下framebuffer。

Linux FrameBuffer 本质上只是提供了对图形设备的硬件抽象,在开发者看来,FrameBuffer 是一块显示缓存,往显示缓存中写入特定格式的数据就意味着向屏幕输出内容。所以说FrameBuffer就是一块白板。例如对于初始化为16 位色的FrameBuffer 来说, FrameBuffer中的两个字节代表屏幕上一个点,从上到下,从左至右,屏幕位置与内存地址是顺序的线性关系。帧缓存有个地址,是在内存里。我们通过不停的向frame buffer中写入数据, 显示控制器就自动的从frame buffer中取数据并显示出来。全部的图形都共享内存中同一个帧缓存。

方法三:Android截屏实现思路

Android系统是基于Linux内核的,所以也存在framebuffer这个设备,我们要实现截屏的话只要能获取到framebuffer中的数据,然后把数据转换成就可以了,android中的framebuffer数据是存放在 /dev/graphics/fb0 文件中的,所以我们只需要来获取这个文件的数据就可以得到当前屏幕的内容。

现在我们的测试代码运行时候是通过RC(remote controller)方式来运行被测应用的,那就需要在PC机上来访问模拟器或者真机上的framebuffer数据,这个的话可以通过android的ADB命令来实现。

 注意:

 1、需要在AndroidManifestxml中加入代码:android:sharedUserId="androiduidsystem"。

2、由于调用了@hide的API,所以编译得时候请使用makefile编译。或者通过在Eclipse中添加Jar文件通过编译。

3、此代码只在Android40中使用过,23的就没去做测试了。

补充说明:

利用TakeScreenShotService截图Android手机一般都自带有手机屏幕截图的功能:在手机任何界面(当然手机要是开机点亮状态),通过按组合键,屏幕闪一下,然后咔嚓一声,截图的照片会保存到当前手机的图库中,

对手机android源码中通过组合键屏幕截图的整个流程有个大体了解了,在改动中熟悉按键的捕获原理,并且清楚调用的截屏函数接口即可。

以上就是关于WKWebView 整个网页截屏全部的内容,包括:WKWebView 整个网页截屏、如何在Android里面使用代码截屏、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/10089681.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-05
下一篇2023-05-05

发表评论

登录后才能评论

评论列表(0条)

    保存