Provided by: libnet-vnc-perl_0.40-3_all bug

NAME

       Net::VNC - A simple VNC client

SYNOPSIS

         use Net::VNC;

         my $vnc = Net::VNC->new({hostname => $hostname, password => $password});
         $vnc->depth(24);
         $vnc->login;

         print $vnc->name . ": " . $vnc->width . ' x ' . $vnc->height . "\n";

         my $image = $vnc->capture;
         $image->save("out.png");

DESCRIPTION

       Virtual Network Computing (VNC) is a desktop sharing system which uses the RFB (Remote
       FrameBuffer) protocol to remotely control another computer. This module acts as a VNC
       client and communicates to a VNC server using the RFB protocol, allowing you to capture
       the screen of the remote computer.

       This module dies upon connection errors (with a timeout of 15 seconds) and protocol
       errors.

       This implementation is based largely on the RFB Protocol Specification,
       <http://www.realvnc.com/docs/rfbproto.pdf>.  That document has an error in the DES
       encryption description, which is clarified via
       <http://www.vidarholen.net/contents/junk/vnc.html>.

METHODS

   new
       The constructor. Given a hostname and a password returns a Net::VNC object:

         my $vnc = Net::VNC->new({hostname => $hostname, password => $password});

       Optionally, you can also specify a port, which defaults to 5900. For ARD (Apple Remote
       Desktop) authentication you must also specify a username.  You must also install
       Crypt::GCrypt::MPI and Crypt::Random.

   login
       Logs into the remote computer:

         $vnc->login;

   name
       Returns the name of the remote computer:

         print $vnc->name . ": " . $vnc->width . ' x ' . $vnc->height . "\n";

   width
       Returns the width of the remote screen:

         print $vnc->name . ": " . $vnc->width . ' x ' . $vnc->height . "\n";

   height
       Returns the height of the remote screen:

         print $vnc->name . ": " . $vnc->width . ' x ' . $vnc->height . "\n";

   capture
       Captures the screen of the remote computer, returning an Image::Imlib2 object:

         my $image = $vnc->capture;
         $image->save("out.png");

       You may call capture() multiple times.  Each time, the $image buffer is overwritten with
       the updated screen.  So, to create a series of ten screen shots:

         for my $n (1..10) {
           my $filename = sprintf 'snapshot%02d.png', $n++;
           $vnc->capture()->save($filename);
           print "Wrote $filename\n";
         }

   depth
       Specify the bit depth for the screen.  The supported choices are 24, 16 or 8.  If
       unspecified, the server's default value is used.  This property should be set before the
       call to login().

   save_bandwidth
       Accepts a boolean, defaults to false.  Specifies whether to use more CPU-intensive
       algorithms to compress the VNC datastream.  LAN or localhost connections may prefer to
       leave this false.  This property should be set before the call to login().

   list_encodings
       Returns a list of encoding number/encoding name pairs.  This can be used as a class method
       like so:

          my %encodings = Net::VNC->list_encodings();

   send_key_event_down
       Send a key down event. The keys are the same as the corresponding ASCII value. Other
       common keys:

         BackSpace 0xff08
         Tab 0xff09
         Return or Enter 0xff0d
         Escape 0xff1b
         Insert 0xff63
         Delete 0xffff
         Home 0xff50
         End 0xff57
         Page Up 0xff55
         Page Down 0xff56
         Left 0xff51
         Up 0xff52
         Right 0xff53
         Down 0xff54
         F1 0xffbe
         F2 0xffbf
         F3 0xffc0
         F4 0xffc1
         ... ...
         F12 0xffc9
         Shift (left) 0xffe1
         Shift (right) 0xffe2
         Control (left) 0xffe3
         Control (right) 0xffe4
         Meta (left) 0xffe7
         Meta (right) 0xffe8
         Alt (left) 0xffe9
         Alt (right) 0xffea

         $vnc->send_key_event_down('A');

   send_key_event_up
       Send a key up event:

         $vnc->send_key_event_up('A');

   send_key_event
       Send a key down event followed by a key up event:

         $vnc->send_key_event('A');

   send_key_event_string
       Send key events for every character in a string:

         $vnc->send_key_event_string('Hello');

   send_pointer_event( $button_mask, $x, $y )
       Send pointer event (usually a mouse). This is used to move the pointer or make clicks or
       drags.

       It is easier to call the "mouse_move" or <mouse_click> methods instead.

   mouse_move_to($x, $y)
       Send the pointer to the given position. The cursor instantly jumps there instead of
       smoothly moving to there.

   mouse_click
       Click on current pointer position.

   mouse_right_click
       Right-click on current pointer position.

BUGS AND LIMITATIONS

   Bit depth
       We do not yet support 8-bit true-colour mode, which is commonly supported by servers but
       is rarely employed by clients.

   Byte order
       We have currently tested this package against servers with the same byte order as the
       client.  This might break with a little-endian server/big-endian client or vice versa.
       We're working on tests for those latter cases.  Testing and patching help would be
       appreciated.

   Efficiency
       We've implemented a subset of the data compression algorithms supported by most VNC
       servers.  We hope to add more of the high-compression transfer encodings in the future.

AUTHORS

       Leon Brocard acme@astray.com

       Chris Dolan clotho@cpan.org

       Apple Remote Desktop authentication based on LibVNCServer

       Maurice Castro maurice@ipexchange.com.au

       Many thanks for Foxtons Ltd for giving Leon the opportunity to write the original version
       of this module.

       Copyright (C) 2006, Leon Brocard

       This module is free software; you can redistribute it or modify it under the same terms as
       Perl itself.