Imager-Search
view release on metacpan or search on metacpan
lib/Imager/Search/Driver.pm view on Meta::CPAN
package Imager::Search::Driver;
=pod
=head1 NAME
Imager::Search::Driver - Abstract imlementation of a Imager::Search driver
=head1 SYNOPSIS
# Create the search
my $search = Imager::Search::Driver->new(
driver => 'HTML24',
big => $large_imager_object,
small => $small_imager_object,
);
# Run the search
my $found = $search->find_first;
# Handle the result
print "Found at row " . $found->top . " and column " . $found->left;
=head1 DESCRIPTION
Given two images (we'll call them Big and Small), where Small is
contained within Big zero or more times, determine the pixel locations
of Small within Big.
For example, given a screen shot or a rendered webpage, locate the
position of a known icon or picture within the larger image.
The intent is to provide functionality for use in various testing
scenarios, or desktop gui automation, and so on.
=head1 METHODS
=cut
use 5.006;
use strict;
use Carp ();
use Params::Util qw{ _STRING _CODELIKE _SCALAR _INSTANCE };
use Imager ();
use vars qw{$VERSION};
BEGIN {
$VERSION = '1.01';
}
use Imager::Search::Match ();
#####################################################################
# Constructor and Accessors
=pod
=head2 new
my $driver = Imager::Search::Driver->new;
The C<new> constructor takes a new search driver object.
Returns a new B<Imager::Search::Driver> object, or croaks on error.
=cut
sub new {
my $class = shift;
# Apply the default driver
if ( $class eq 'Imager::Search::Driver' ) {
require Imager::Search::Driver::HTML24;
return Imager::Search::Driver::HTML24->new(@_);
}
# Create the object
my $self = bless { @_ }, $class;
return $self;
}
#####################################################################
# Driver API Methods
=pod
( run in 1.316 second using v1.01-cache-2.11-cpan-ceb78f64989 )