NAME
Win32::Capture - Capature screen and manipulate it with 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 portion 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 functions of package are similar to Win32::Screenshot. But you can manipulate screen shot image with Win32::GUI::DIBitmap
Screen capture functions
All of these functions are returning a new Win32::GUI::DIBitmap instance on success or undef on failure. These 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, $sleepTime, $flag)
-
Capture whole window include title and border parts, or client window region only.
TIPS: Use FindWindowLike to find the HWND.
$flag = 0 : Entire window will be captured (with border) $flag = 1 : Only the client window region will be captured.
- CaptureWindowRect($HWND, $sleepTime, $x, $y, $width, $height)
-
Capture a portion of the window.
TIPS: Use FindWindowLike helper function to find $HWND value.
Capturing helper function
- FindWindowLike($pattern)
-
@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 $pattern argument stands for a part of window title. FindWindowLike will return an array with HWND elements.
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.