各种各样的安卓截图方法

本帖已被设为精华帖!,

今天准备写一下 安卓手机截图的各种方法,再不写我怕以后我自己都会忘记了

差不多从做手机测试开始就开始接触手机的截图方法,陆陆续续的大概有2年了。

本篇文章不适合以下人群

  1. 伸手党
  2. 不喜欢寻根究底的人

本人已知截图的方法

  • minicap截图 来自项目openstf 直接读取屏幕缓冲区
  • adbd的framebuffer
  • screencap截图 (具体分为rawrgba和png两种)
  • uiautomator自动化工具截图
  • 摄像头截图

应该还有其他的方法,只是欢迎留言提醒我

minicap

https://github.com/openstf/minicap 速度快,兼容性也还不错,仅次于screencap

具体使用方法还是参考我上面链接的比较好

adbd framebuffer

adbd的framebuffer就不提了,根据一篇文章中的描述 http://blog.csdn.net/joson_wang/article/details/50420106

framebuffer service通过直接读framebuffer 设备(/dev/graphics/fb0)来截屏,在较新版本的Android中,framebuffer service则调用截屏工具screencap来截屏。

screencap png

这种方法简单,但是缺点就是速度太慢

方法

/system/bin/screencap -p screen.png

执行完之后,adb pull下来就可以了

screencap rawrgba

速度稍微好一些,需要做进一步的处理

关于screencap的rawrgba具体的格式,可以参考 http://stackoverflow.com/questions/22034959/what-format-does-adb-screencap-sdcard-screenshot-raw-produce-without-p-f

为了方便阅读,我直接把关键内容贴到这里

Format:

4 bytes as uint32 - width
4 bytes as uint32 - height
4 bytes as uint32 - pixel format
(width * heigth * bytespp) bytes as byte array - image data, where bytespp is bytes per pixels and depend on pixel format. Usually bytespp is 4.
Info from source code of screencap.

For your example:

00000000 d0 02 00 00 00 05 00 00 01 00 00 00 1e 1e 1e ff
d0 02 00 00 - width - uint32 0x000002d0 = 720
00 05 00 00 - height - uint32 0x00000500 = 1280
01 00 00 00 - pixel format - uint32 0x00000001 = 1 = PixelFormat.RGBA_8888 => bytespp = 4 => RGBA
1e 1e 1e ff - first pixel data - R = 0x1e; G = 0x1e; B = 0x1e; A = 0xff;
Pixels with data stored in array of bytes with size 720*1280*4.

uiautomator 截图

这篇文章讲的还不错 http://www.cnblogs.com/fsw-blog/p/4549793.html

核心代码就一行

UiDevice.getInstance().takeScreenshot(new File("/sdcard/screen.png"));

摄像头截图

清晰度取决于摄像头的清晰度,通常来说清晰度都不高,不适合用于自动化中的图像识别,但是好处就是速度快,非常的快

先来张整体设计图

各种各样的安卓截图方法

因为摄像头获取到的图片区域往往比较大,所以要先进性预处理

原图

各种各样的安卓截图方法

处理后的图

各种各样的安卓截图方法

我当时为了简单,就是先手动选择屏幕周围的4个点,然后用opencv做了一下处理,代码也很简单,我直接贴出来了

width = 1920 # screen width
height = 1080 # screen height
image = {do it you self} # opencv image object

pts = [[10, 10], [15, 900], [10, 600], [900, 600]] # leftTop, rightTop, leftBottom, rightBottom
pts1 = np.float32(pts)
pts2 = np.float32([[0, 0], [width, 0], [0, height], [width, height]])
M = cv2.getPerspectiveTransform(pts1, pts2)

image = cv2.warpPerspective(image, M, (width, height))
# show image here

* 注:本文来自网络投稿,不代表本站立场,如若侵犯版权,请及时知会删除