Index: build/android/screenshot.py |
diff --git a/build/android/screenshot.py b/build/android/screenshot.py |
index 839fb55d91eee07dae45da34686b8e72d68a5e2c..88f46f79a448b642a6c17f4a58b248f941102393 100755 |
--- a/build/android/screenshot.py |
+++ b/build/android/screenshot.py |
@@ -1,105 +1,11 @@ |
#!/usr/bin/env python |
- |
-# Copyright (c) 2012 The Chromium Authors. All rights reserved. |
+# Copyright 2015 The Chromium Authors. All rights reserved. |
# Use of this source code is governed by a BSD-style license that can be |
# found in the LICENSE file. |
-"""Takes a screenshot or a screen video capture from an Android device.""" |
- |
-import logging |
-import optparse |
-import os |
import sys |
-from devil.android import device_blacklist |
-from devil.android import device_errors |
-from devil.android import device_utils |
-from pylib import screenshot |
- |
-def _PrintMessage(heading, eol='\n'): |
- sys.stdout.write('%s%s' % (heading, eol)) |
- sys.stdout.flush() |
- |
- |
-def _CaptureScreenshot(device, host_file): |
- host_file = device.TakeScreenshot(host_file) |
- _PrintMessage('Screenshot written to %s' % os.path.abspath(host_file)) |
- |
- |
-def _CaptureVideo(device, host_file, options): |
- size = (tuple(int(i) for i in options.size.split('x')) if options.size |
- else None) |
- recorder = screenshot.VideoRecorder(device, |
- megabits_per_second=options.bitrate, |
- size=size, |
- rotate=options.rotate) |
- try: |
- recorder.Start() |
- _PrintMessage('Recording. Press Enter to stop...', eol='') |
- raw_input() |
- finally: |
- recorder.Stop() |
- host_file = recorder.Pull(host_file) |
- _PrintMessage('Video written to %s' % os.path.abspath(host_file)) |
- |
- |
-def main(): |
- # Parse options. |
- parser = optparse.OptionParser(description=__doc__, |
- usage='screenshot.py [options] [filename]') |
- parser.add_option('-d', '--device', metavar='ANDROID_DEVICE', help='Serial ' |
- 'number of Android device to use.', default=None) |
- parser.add_option('--blacklist-file', help='Device blacklist JSON file.') |
- parser.add_option('-f', '--file', help='Save result to file instead of ' |
- 'generating a timestamped file name.', metavar='FILE') |
- parser.add_option('-v', '--verbose', help='Verbose logging.', |
- action='store_true') |
- video_options = optparse.OptionGroup(parser, 'Video capture') |
- video_options.add_option('--video', help='Enable video capturing. Requires ' |
- 'Android KitKat or later', action='store_true') |
- video_options.add_option('-b', '--bitrate', help='Bitrate in megabits/s, ' |
- 'from 0.1 to 100 mbps, %default mbps by default.', |
- default=4, type='float') |
- video_options.add_option('-r', '--rotate', help='Rotate video by 90 degrees.', |
- default=False, action='store_true') |
- video_options.add_option('-s', '--size', metavar='WIDTHxHEIGHT', |
- help='Frame size to use instead of the device ' |
- 'screen size.', default=None) |
- parser.add_option_group(video_options) |
- |
- (options, args) = parser.parse_args() |
- |
- if len(args) > 1: |
- parser.error('Too many positional arguments.') |
- host_file = args[0] if args else options.file |
- |
- if options.verbose: |
- logging.getLogger().setLevel(logging.DEBUG) |
- |
- blacklist = (device_blacklist.Blacklist(options.blacklist_file) |
- if options.blacklist_file |
- else None) |
- |
- devices = device_utils.DeviceUtils.HealthyDevices(blacklist) |
- if options.device: |
- device = next((d for d in devices if d == options.device), None) |
- if not device: |
- raise device_errors.DeviceUnreachableError(options.device) |
- else: |
- if len(devices) > 1: |
- parser.error('Multiple devices are attached. ' |
- 'Please specify device serial number with --device.') |
- elif len(devices) == 1: |
- device = devices[0] |
- else: |
- raise device_errors.NoDevicesError() |
- |
- if options.video: |
- _CaptureVideo(device, host_file, options) |
- else: |
- _CaptureScreenshot(device, host_file) |
- return 0 |
- |
+from devil.android.tools import screenshot |
if __name__ == '__main__': |
- sys.exit(main()) |
+ sys.exit(screenshot.main()) |