NAME

Win32::Capture - Capature Win32 screen with lightweight Win32::GUI::DIBitmap.

SYNOPSIS

use Win32::Capture;


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

#or

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

#or

@WIN = FindWindowLike('CPAN'); # Find the HWND to be captured.

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

DESCRIPTION

The package is similar to Win32::Screenshot, also using Win32 API function, but with Image Process in Win32::GUI::DIBitmap to let you capture the screen, a window or a part of it. The Capture*(...) functions returns a new Win32::GUI::DIBitmap object which you can easily use to modify the screenshot or to store it in the file.

Screen capture functions

All these functions return a new Win32::GUI::DIBitmap object on success or undef on failure. These function are exported by default.

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

Captures part of the screen. The [0, 0] coordinate is the upper-left corner of the screen. The [$x, $y] defines the the upper-left corner of the rectangle to be captured.

CaptureScreen( )

Captures whole screen including the taskbar.

CaptureWindow( $HWND , $sec , $flag )

Captures whole window including title and border or only for Client Window. The second parameter is how many time wait for the Window be Changed to Top.

TIPS: You can using FindWindowLike to find the HWND.

flag = 0 : All the window is capture (with border)
flag = 1 : Only the Client window is capture
CaptureWindowRect( $HWND , $sec , $x, $y, $width, $height )

Captures a part of the window. Pass the window handle with the function parameter. The second parameter is how many time wait for the Window be Changed to Top.

TIPS: You can using FindWindowLike to find the HWND element(s).

Capturing helper functions

Functions for find the Window HWND to capture.

FindWindowLike( $pattern )
@WIN = FindWindowLike('CPAN');

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

The parameter is a part of window title, and FindWindowLike will Return an Array including HWND.

SEE ALSO

Win32::Screenshot

Some documentation refer from here.

Win32::GUI::DIBitmap

The raw data from the screen are loaded into Win32::GUI::DIBitmap object. You have a lot of possibilities what to do with the captured image.

MSDN

http://msdn.microsoft.com/library

AUTHOR

Lilo Huang

COPYRIGHT AND LICENSE

Copyright 2006 by Lilo Huang All Rights Reserved.

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