Linux and UNIX Man Pages

Linux & Unix Commands - Search Man Pages

sdl::video(3) [suse man page]

SDL::Video(3)						User Contributed Perl Documentation					     SDL::Video(3)

NAME
SDL::Video - a SDL perl extension SYNOPSIS
$video = new SDL::Video ( -name => 'pr0n.mpg' ); DESCRIPTION
"SDL::Video" adds support for MPEG video to your SDL Perl application. Videos are objects bound to surfaces, whose playback is controled through the object's interface. METHODS o "SDL::Video::error()" returns any error messages associated with playback o "SDL::Video::audio(bool)" enables or disables audio playback, (on by default) o "SDL::Video::video(bool)" enables or disable video playback, (on by default) o "SDL::Video::loop(bool)" enables or disable playback looping (off by default) o "SDL::Video::volume(int)" set the volume as per the mixer volume o "SDL::Video:display(surface)" binds the clip to a display surface o "SDL::Video::scale([x,y]|[surface]|int)" scales the clip by either x,y factors, scales to the image dimensions, or a single scalar. o "SDL::Video::play()" plays the video clip, call "SDL::Video::display()" before playing o "SDL::Video::pause()" pauses video playback o "SDL::Video::stop()" stops video playback o "SDL::Video::rewind()" resets the clip to the beginning o "SDL::Video::seek(offset)" seeks to a particular byte offset o "SDL::Video::skip(time)" skips to a particular time o "SDL::Video::region(rect)" takes a SDL::Rect and defines the display area o "SDL::Video::frame(int)" renders a specific frame to the screen o "SDL::Video::info()" returns a new "SDL::MPEG" object reflecting the current status o "SDL::Video::status()" returns either SMPEG_PLAYING or SMPEG_STOPPED or SMPEG_ERROR AUTHOR
David J. Goehrig SEE ALSO
perl(1) SDL::Surface(3) SDL::MPEG(3) perl v5.12.1 2010-07-05 SDL::Video(3)

Check Out this Related Man Page

pods::SDL::Cookbook::PDL(3pm)				User Contributed Perl Documentation			     pods::SDL::Cookbook::PDL(3pm)

NAME
SDL::CookBook::PDL -- CookBook for SDL + PDL PDL provides great number crunching capabilities to Perl and SDL provides game-developer quality real-time bitmapping and sound. You can use PDL and SDL ''together'' to create real-time, responsive animations and simulations. In this section we will go through the pleasures and pitfalls of working with both powerhouse libraries. CATEGORY Cookbook Creating a SDL Surface piddle PDL's core type is a piddle. Once a piddle is provided to PDL it can go do a numerous amounts of things. Please see the example in 'examples/cookbook/pdl.pl' that came with this module. Creating a simple piddle First lets get the right modules. use PDL; use SDL::Rect; use SDL::Video; use SDL::Surface; use SDL::PixelFormat; Suppose you want a surface of size (200,400) and 32 bit (RGBA). my ( $bytes_per_pixel, $width, $height ) = ( 4, 200, 400 ); Define the $width, $height and $bytes_per_pixel. Your $bytes_per_pixel is the number of bits (in this case 32) divided by 8 bits per byte. Therefore for our 32 bpp we have 4 Bpp; my $piddle = zeros( byte, $bytes_per_pixel, $width, $height ); Create a normal $piddle with zeros, byte format and the Bpp x width x height dimensions. my $pointer = $piddle->get_dataref(); Here is where we get the actual data the piddle is pointing to. We will have SDL create a new surface from this function. my $surface = SDL::Surface->new_from( $pointer, $width, $height, 32, $width * $bytes_per_pixel ); Using the same dimensions we create the surface using new_form. The width * Bpp is the scanline (pitch) of the surface in bytes. warn "Made surface of $width, $height and ". $surface->format->BytesPerPixel; return ( $piddle, $surface ); Finally make sure that the surface actually has the correct dimensions we gave. NOTE: $surface->format->BytesPerPixel must return 1,2,3,4. !! Now you can blit and use the surface as needed; and do PDL operations as required. Operating on the Surface safely To make sure SDL is in sync with the data. You must call SDL::Video::lock before doing PDL operations on the piddle. SDL::Video::lock_surface($surface); $piddle->mslice( 'X', [ rand(400), rand(400), 1 ], [ rand(200), rand(200), 1 ] ) .= pdl( rand(225), rand(225), rand(255), 255 ); After that you can unlock the surface to blit. SDL::Video::unlock_surface($surface); Error due to BPP at blitting When blitting the new surface check for the return value to see if there has been a problem. my $b = SDL::Video::blit_surface( $surface, SDL::Rect->new( 0, 0, $surface->w, $surface->h ), $app, SDL::Rect->new( ( $app->w - $surface->w ) / 2, ( $app->h - $surface->h ) / 2, $app->w, $app->h ) ); die "Could not blit: " . SDL::get_error() if ( $b == -1 ); If the error message is 'Blit combination not supported' that means that the BPP is incorrect or inconsistent with the dimensions. After that a simple update_rect will so your new surface on the screen. AUTHORS
See "AUTHORS" in SDL. perl v5.14.2 2012-05-28 pods::SDL::Cookbook::PDL(3pm)
Man Page