NAME

Win32::Capture - Capture screen and manipulate it with Win32::GUI::DIBitmap instance.

SYNOPSIS

use Win32::Capture;

$image = CaptureScreen(); # Capture whole screen.
$image->SaveToFile('screenshot.png');

# or

$image = CaptureRect($x, $y, $width, $height); # Capture a portion of window.
$image->SaveToFile('screenshot.png');

# or

@hwnds = FindWindowLike('CPAN');  # Invoke helper function to get HWND array.

if ($#hwnds<0) {
     print "Not found";
} else {
      foreach (@hwnds) {
          my $image = CaptureWindowRect($_, 2, 0, 0, 400, 300);
          $image->SaveToFile("$_.jpg", JPEG_QUALITYSUPERB);
      }
}

DESCRIPTION

The purposes of package are similar to Win32::Screenshot. But you can manipulate screen shot image with Win32::GUI::DIBitmap instance.

Screen capture functions

All of these functions are returning a new Win32::GUI::DIBitmap instance on success or undef (a.k.a undefined variables) on failure. All functions are exported by default.

CaptureRect($x, $y, $width, $height)

Capture a portion of the screen. The [0, 0] coordinate is on the upper-left corner of the screen. The [$x, $y] defines the the upper-left corner of the rectangle to be captured.

CaptureScreen()

Capture whole screen include taskbar.

CaptureWindow($hWND, $dur, $flag)

Capture whole window include title bar and window border, or client window region only.

Set $dur to wait for a while before capturing.

TIPS: Invoke FindWindowLike($text) helper function to find $hWND value.

$flag = 0 : Entire window will be captured (with border)
$flag = 1 : Only client window region will be captured.
CaptureWindowRect($hWND, $dur, $x, $y, $width, $height)

Capture a portion of the window.

TIPS: Invoke FindWindowLike($text) helper function to find $hWND value.

Capturing helper function

FindWindowLike($text)
@hwnds = FindWindowLike('CPAN');

if ($#hwnds<0) {
     print "Not found";
} else {
      foreach (@hwnds) {
          my $image = CaptureWindowRect($_, 2, 0, 0, 400, 300);
          $image->SaveToFile("$_.jpg", JPEG_QUALITYSUPERB);
      }
}

The $text argument stands for a part of window title. FindWindowLike will return an array holds HWND elements.

SEE ALSO

Win32::Screenshot

Some documentation refer from here.

Win32::GUI::DIBitmap

The raw data from the screen will be loaded into Win32::GUI::DIBitmap instance.

See Win32::GUI::DIBitmap for more details.

MSDN

http://msdn.microsoft.com/library

AUTHOR

Lilo Huang

COPYRIGHT AND LICENSE

Copyright 2014 by Lilo Huang All Rights Reserved.

You can use this module under the same terms as Perl itself.