NAME

    Raylib::FFI - Perl FFI bindings for raylib

SYNOPSIS

        use 5.38.2;
        use lib qw(lib);
        use Raylib::FFI; # defaults to exporting all the functions
        use constant Color => 'Raylib::FFI::Color';
    
        InitWindow( 800, 600, "Testing!" );
        SetTargetFPS(60);
        while ( !WindowShouldClose() ) {
            my $x = GetScreenWidth() / 2;
            my $y = GetScreenHeight() / 2;
            BeginDrawing();
            ClearBackground( Color->new( r => 0, g => 0, b => 0, a => 0 ) );
            DrawFPS( 0, 0 );
            DrawText( "Hello, world!",
                $x, $y, 20, Color->new( r => 255, g => 255, b => 255, a => 255 ) );
            EndDrawing();
        }
        CloseWindow();

DESCRIPTION

    This module provides Perl bindings for the raylib library using
    FFI::Platyus. This is functional but very low level. You probably want
    to use Raylib::App instead.

    This module was based on the Raylib 5.0.0 API. See
    http://www.raylib.com.

TYPES

 Raylib::FFI::Vector2D

    X and Y coordinates

 Raylib::FFI::Vector3D

    X, Y and Z coordinates

 Raylib::FFI::Vector4D

    X, Y, Z and W coordinates

 Raylib::FFI::Matrix

    Matrix, 4x4 components, column major, OpenGL style, right-handed

 Raylib::FFI::Color

    Color, 4 components, R8G8B8A8 (32bit)

 Raylib::FFI::Rectangle

    Rectangle, 4 components

 Raylib::FFI::Image

    Image, pixel data stored in CPU memory (RAM)

 Raylib::FFI::Texture

    Texture, tex data stored in GPU memory (VRAM)

 Raylib::FFI::RenderTexture

    RenderTexture, fbo for texture rendering

 Raylib::FFI::NPatchInfo

    NPatchInfo, n-patch layout info

 Raylib::FFI::GlyphInfo

    GlyphInfo, font characters glyphs info

 Raylib::FFI::Font

    Font, font texture and characters glyphs info

 Raylib::FFI::Camera3D

    Camera3D, defines a camera position/orientation in 3D space

 Raylib::FFI::Camera2D

    Camera2D, defines a camera position and rotation in 2D space

 Raylib::FFI::Mesh

    Mesh, vertext data and vao/vbo

 Raylib::FFI::Shader

    Shader

 Raylib::FFI::MaterialMap

    MaterialMap

 Raylib::FFI::Material

    Material, includes shader and maps

 Raylib::FFI::Transform

    Transform, vertex transformation data

 Raylib::FFI::BoneInfo

    Bone, skeletal animation bone

 Raylib::FFI::Model

    Model, meshes, materials and animation data

 Raylib::FFI::ModelAnimation

    ModelAnimation, animation data

 Raylib::FFI::Ray

    Ray, ray for raycasting

 Raylib::FFI::RayCollision

    RayCollision, ray hit information

 Raylib::FFI::BoundingBox

    Bounding Box

 Raylib::FFI::Wave

    Wave, audio wave data

 Raylib::FFI::AudioStream

    AudioStream, custom audio stream

 Raylib::FFI::Sound

    Sound

 Raylib::FFI::Music

    Music, audio stream, anything longer than ~10 seconds should be
    streamed

 Raylib::FFI::VrDeviceInfo

    VrDeviceInfo, Head-Mounted-Display device parameters

 Raylib::FFI::VrStereoConfig

    VrStereoConfig, VR stereo rendering configuration for simulator

FUNCTIONS

    All functions are exported lexically by default. To export only
    specific functions simply liste them in the use statement.

 InitWindow( $width, $height, $title )

    Initialize window and OpenGL context.

 CloseWindow()

    Close window and unload OpenGL context.

 WindowShouldClose() : bool

    Check if application should close (KEY_ESCAPE pressed or windows close
    icon clicked).

 IsWindowValid() : bool

    Check if window has been initialized successfully.

 IsWindowFullscreen() : bool

    Check if window is currently fullscreen.

 IsWindowHidden() : bool

    Check if window is currently hidden.

 IsWindowMinimized() : bool

    Check if window is currently minimized.

 IsWindowMaximized() : bool

    Check if window is currently maximized.

 IsWindowFocused() : bool

    Check if window is currently focused.

 IsWindowResized() : bool

    Check if window has been resized last frame.

 IsWindowState( $flag ) : bool

    Check if one specific window flag is enabled.

 SetWindowState( $flags )

    Set window configuration state using flags.

 ClearWindowState( $flags )

    Clear window configuration state flags.

 ToggleFullscreen()

    Toggle window state: fullscreen/windowed (only PLATFORM_DESKTOP).

 ToggleBorderlessWindowed()

    Toggle window state: borderless/fullscreen (only PLATFORM_DESKTOP).

 MaximizeWindow()

    Set window state: maximized, if resizable (only PLATFORM_DESKTOP).

 MinimizeWindow()

    Set window state: minimized, if resizable (only PLATFORM_DESKTOP).

 RestoreWindow()

    Restore window state: if resizable (only PLATFORM_DESKTOP).

 SetWindowIcon( $image )

    Set icon for window (single image, RBGA 32bit, only PLATFORM_DESKTOP).

 SetWindowIcons( $images )

    Set icons for window (multiple images, RGBA 32bit, only
    PLATFORM_DESKTOP).

 SetWindowTitle( $title )

    Set title for window (only PLATFORM_DESKTOP).

 SetWindowPosition( $x, $y )

    Set window position on screen (only PLATFORM_DESKTOP).

 SetWindowMonitor( $monitor )

    Set monitor for the current window.

 SetWindowMinSize( $width, $height )

    Set window minimum dimensions (for FLAG_WINDOW_RESIZABLE).

 SetWindowMaxSize( $width, $height )

    Set window maximum dimensions (for FLAG_WINDOW_RESIZABLE).

 SetWindowSize( $width, $height )

    Set window dimensions.

 SetWindowOpacity( $opacity )

    Set window opacity [0.0f..1.0f]

 SetWindowFocused()

    Set window focused

 GetScreenWidth() : int

    Get current screen width.

 GetScreenHeight() : int

    Get current screen height.

 GetRenderWidth() : int

    Get current render width (it considers HiDPI).

 GetRenderHeight() : int

    Get current render height (it considers HiDPI).

 GetMonitorCount() : int

    Get number of connected monitors.

 GetCurrentMonitor() : int

    Get current connected monitor.

 GetMonitorPosition( $monitor ) : Raylib::FFI::Vector2D

    Get specified monitor position in screen space.

 GetMonitorWidth( $monitor ) : int

    Get specified monitor width (current video mode used by monitor).

 GetMonitorHeight( $monitor ) : int

    Get specified monitor height (current video mode used by monitor).

 GetMonitorPhysicalWidth( $monitor ) : int

    Get specified monitor physical width in millimetres.

 GetMonitorPhysicalHeight( $monitor ) : int

    Get specified monitor physical height in millimetres.

 GetMonitorRefreshRate( $monitor ) : int

    Get specified monitor refresh rate.

 GetWindowPosition() : Raylib::FFI::Vector2D

    Get window position XY on monitor.

 GetWindowScaleDPI() : Raylib::FFI::Vector2D

    Get window scale factor on HiDPI monitors.

 GetMonitorName( $monitor ) : string

    Get the human-readable, UTF-8 encoded name of the monitor.

 SetClipboardText( $text )

    Set clipboard text content.

 GetClipboardText() : string

    Get clipboard text content.

 GetClipboardImage() : Raylib::FFI::Image

    Get clipboard image content.

 EnableEventWaiting()

    Enable waiting for events on EndDrawing, automatic event polling.

 DisableEventWaiting()

    Disable waiting for events on EndDrawing, manual event polling.

 ShowCursor()

    Show cursor.

 HideCursor()

    Hide cursor.

 IsCursorHidden() : bool

    Check if cursor is not visible.

 EnableCursor()

    Enable cursor (unlock cursor).

 DisableCursor()

    Disable cursor (lock cursor).

 IsCursorOnScreen() : bool

    Check if cursor is on the screen.

 ClearBackground( $color )

    Set background color (framebuffer clear color).

 BeginDrawing()

    Setup canvas (framebuffer) to start drawing

 EndDrawing()

    End canvas drawing and swap buffers (double buffering).

 BeginMode2D( $camera )

    Begin 2D mode with custom camera (2D).

 EndMode2D()

    Ends 2D mode with custom camera.

 BeginMode3D( $camera )

    Begin 3D mode with custom camera (3D).

 EndMode3D()

    Ends 3D mode and returns to default 2D orthographic mode.

 BeginTextureMode( $renderTexture )

    Begin drawing to render texture.

 EndTextureMode()

    Ends drawing to render texture.

 BeginShaderMode( $shader )

    Begin custom shader drawing.

 EndShaderMode()

    End custom shader drawing (use default shader).

 BeginBlendMode( $mode )

    Begin blending mode (alpha, additive, multiplied, subtract, custom)

 EndBlendMode()

    End blending mode (reset to default: alpha blending)

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

    Begin scissor mode (define screen area for following drawing
    operations)

 EndScissorMode()

    End scissor mode.

 BeginVrStereoMode( $config )

    Begin stereo rendering (requires VR simulator)

 EndVrStereoMode()

    End stereo rendering.

 LoadVrStereoConfig( $config )

    Load VR stereo config for VR simulator.

 UnloadVrStereoConfig( $config )

    Unload VR stereo config for VR simulator.

 LoadShader( $vsFileName, $fsFileName ) : Raylib::FFI::Shader

    Load shader from files and bind default locations.

 LoadShaderFromMemory( $vsCode, $fsCode ) : Raylib::FFI::Shader

    Load shader from code strings and bind default locations.

 IsShaderValid( $shader ) : bool

    Check if a shader is valid.

 GetShaderLocation( $shader, $uniformName ) : int

    Get shader uniform location.

 GetShaderLocationAttrib( $shader, $attribName ) : int

    Get shader attribute location.

 SetShaderValue( $shader, $locIndex, $value, $uniformType )

    Set shader uniform value

 SetShaderValueV( $shader, $locIndex, $value, $uniformType )

    Set shader uniform value vector

 SetShaderValueMatrix( $shader, $locIndex, $matrix )

    Set shader uniform value matrix (matrix 4x4)

 SetShaderValueTexture( $shader, $locIndex, $texture )

    Set shader uniform value for texture (sampler2d)

 UnloadShader( $shader )

    Unload shader from GPU memory (VRAM).

 GetMouseRay( $position, $camera ) : Raylib::FFI::Ray # DEPRECATED

    Get a ray trace from screen space (i.e. mouse position)

 GetWorldToScreenEx( $position, $camera, $width, $height ) :
 Raylib::FFI::Vector2D

    Get size position for a 3d world space position

 GetWorldToScreen2D( $position, $camera) : Raylib::FFI::Vector2D

    Get the screen space position for a 2d camera world space position

 GetScreenToWorld2D( $position, $camera) : Raylib::FFI::Vector2D;

    Get the world space position for a 2d camera screen space position

 GetCameraMatrix( $camera ) : Raylib::FFI::Matrix;

    Get camera transform matrix (view matrix)

 GetCameraMatrix2D( $camera ) : Raylib::FFI::Matrix;

    Get camera 2d transform matrix

 SetTargetFPS( $fps )

    Set target FPS (maximum)

 GetFrameTime() : float

    Get time in seconds for last frame drawn (delta time)

 GetTime() : double

    Get elapsed time in seconds since InitWindow()

 GetFPS() : int

    Get current FPS

 SwapScreenBuffer()

    NOTE: This function is intended for advanced users that want full
    control over the frame processing. default EndDrawing() does this job:
    draws everything + SwapScreenBuffer() + manage frame timing +
    PollInputEvents(). To avoid that behaviour and control frame processes
    manually, enable in config.h: SUPPORT_CUSTOM_FRAME_CONTROL

    Swap backbuffer with frontbuffer (screen drawing)

 PollInputEvents()

    NOTE: This function is intended for advanced users that want full
    control over the frame processing. default EndDrawing() does this job:
    draws everything + SwapScreenBuffer() + manage frame timing +
    PollInputEvents(). To avoid that behaviour and control frame processes
    manually, enable in config.h: SUPPORT_CUSTOM_FRAME_CONTROL

    Register all input events

 WaitTime( $seconds )

    NOTE: This function is intended for advanced users that want full
    control over the frame processing. default EndDrawing() does this job:
    draws everything + SwapScreenBuffer() + manage frame timing +
    PollInputEvents(). To avoid that behaviour and control frame processes
    manually, enable in config.h: SUPPORT_CUSTOM_FRAME_CONTROL

    Wait for some time (halt program execution)

 TakeScreenshot( $fileName )

    Takes a screenshot of current screen (filename extension defines
    format)

 SetConfigFlags( $flags )

    Setup init configuration flags (view FLAGS)

 OpenURL( $url )

    Open URL with default system browser (if available)

 TraceLog( $logLevel, $text )

    Show trace log messages (LOG_DEBUG, LOG_INFO, LOG_WARNING,
    LOG_ERROR...)

 SetTraceLogLevel( $logLevel )

    Set the current threshold (minimum) log level

 IsKeyPressed( $key ) : bool

    Check if a key has been pressed once

 IsKeyPressedRepeat( $key ) : bool

    Check if a key has been pressed again (Only PLATFORM_DESKTOP)

 IsKeyDown( $key ) : bool

    Check if a key is being pressed

 IsKeyReleased( $key ) : bool

    Check if a key has been released once

 IsKeyUp( $key ) : bool

    Check if a key is NOT being pressed

 GetKeyPressed() : int

    Get latest key pressed. Returns 0 if no key was pressed during the last
    frame

 GetCharPressed() : int

    Get char pressed (unicode), call it multiple times for chars queued,
    returns 0 when the queue is empty

 SetExitKey( $key )

    Set a custom key to exit program (default is ESC)

 IsGamepadAvailable( $gamepad ) : bool

    Check if a gamepad is available

 GetGamepadName( $gamepad ) : string

    Get gamepad internal name id

 IsGamepadButtonPressed( $gamepad, $button ) : bool

    Check if a gamepad button has been pressed once

 IsGamepadButtonDown( $gamepad, $button ) : bool

    Check if a gamepad button is being pressed

 IsGamepadButtonReleased( $gamepad, $button ) : bool

    Check if a gamepad button has been released once

 IsGamepadButtonUp( $gamepad, $button ) : bool

    Check if a gamepad button is NOT being pressed

 GetGamepadButtonPressed() : int

    Get the last gamepad button pressed

 GetGamepadAxisCount( $gamepad ) : int

    Get gamepad axis count for a gamepad

 GetGamepadAxisMovement( $gamepad, $axis ) : float

    Get axis movement value for a gamepad axis

 SetGamepadMappings( $mappings )

    Set internal gamepad mappings

 IsMouseButtonPressed( $button ) : bool

    Check if a mouse button has been pressed once

 IsMouseButtonDown( $button ) : bool

    Check if a mouse button is being pressed

 IsMouseButtonReleased( $button ) : bool

    Check if a mouse button has been released once

 IsMouseButtonUp( $button ) : bool

    Check if a mouse button is NOT being pressed

 GetMouseX() : int

    Get mouse position X

 GetMouseY() : int

    Get mouse position Y

 GetMousePosition() : Raylib::FFI::Vector2D

    Get mouse position XY

 GetMouseDelta() : Raylib::FFI::Vector2D

    Get mouse delta between frames

 SetMousePosition( $x, $y )

    Set mouse position XY

 SetMouseOffset( $offsetX, $offsetY )

    Set mouse offset

 SetMouseScale( $scaleX, $scaleY )

    Set mouse scaling

 GetMouseWheelMove() : int

    Get mouse wheel movement for X or Y, whichever is larger

 GetMouseWheelMoveV() : Raylib::FFI::Vector2D

    Get mouse wheel movement for both X and Y

 SetMouseCursor( $cursor )

    Set mouse cursor

 GetTouchX() : int

    Get touch position X for touch point 0 (relative to screen size).

 GetTouchY() : int

    Get touch position Y for touch point 0 (relative to screen size).

 GetTouchPosition( $index ) : Raylib::FFI::Vector2D

    Get touch position XY for a touch point index (relative to screen
    size).

 GetTouchPointId( $index ) : int

    Get touch point identifier for given index.

 GetTouchPointCount() : int

    Get number of touch points

 SetGesturesEnabled( $flags )

    Enable a set of gestures using flags

 IsGestureDetected( $gesture ) : bool

    Check if a gesture have been detected

 GetGestureDetected() : int

    Get latest detected gesture

 GetGestureHoldDuration() : float

    Get gesture hold time in milliseconds

 GetGestureDragVector() : Raylib::FFI::Vector2D

    Get gesture drag vector

 GetGestureDragAngle() : float

    Get gesture drag angle

 GetGesturePinchVector() : Raylib::FFI::Vector2D

    Get gesture pinch delta

 GetGesturePinchAngle() : float

    Get gesture pinch angle

 UpdateCamera( $camera )

    Update camera position for selected mode

 UpdateCameraPro( $camera, $dest, $rotation, $zoom )

    Uppdate camera movement/rotation

 SetShapesTexture( $texture, $rec )

    Set texture and rectangle to be used on shapes drawing

 GetShapesTextureRec() : Raylib::FF::Rectangle

    Get texture rectangle to be used on shapes drawing

 DrawPixel( $posX, $posY, $color )

    Draw a pixel

 DrawPixelV( $position, $color )

    Draw a pixel (Vector version)

 DrawLine( $startPosX, $startPosY, $endPosX, $endPosY, $color )

    Draw a line

 DrawLineV( $startPos, $endPos, $color )

    Draw a line (using gl lines)

 DrawLineEx( $startPos, $endPos, $thick, $color )

    Draw a line (using triangles/quads)

 DrawLineStrip( $points, $pointCount, $color )

    Draw lines sequence (using gl lines)

 DrawLineBezier( $startPos, $endPos, $thick, $color )

    Draw line segment cubic-bezier in-out interpolation

 DrawCircle( $centerX, $centerY, $radius, $color )

    Draw a color-filled circle

 DrawCircleSector( $center, $radius, $startAngle, $endAngle, $segments,
 $color )

    Draw a piece of a circle

 DrawCircleSectorLines( $center, $radius, $startAngle, $endAngle,
 $segments, $color )

    Draw circle sector outline

 DrawCircleGradient( $centerX, $centerY, $radius, $color1, $color2 )

    Draw a gradient-filled circle

 DrawCircleV( $center, $radius, $color )

    Draw a color-filled circle (Vector version)

 DrawCircleLines( $centerX, $centerY, $radius, $color )

    Draw circle outline

 DrawCircleLinesV( $center, $radius, $color )

    Draw circle outline (Vector version)

 DrawEllipse( $centerX, $centerY, $radiusH, $radiusV, $color )

    Draw ellipse

 DrawEllipseLines( $centerX, $centerY, $radiusH, $radiusV, $color )

    Draw ellipse outline

 DrawRing( $center, $innerRadius, $outerRadius, $startAngle, $endAngle,
 $segments, $color )

    Draw ring

 DrawRingLines( $center, $innerRadius, $outerRadius, $startAngle,
 $endAngle, $segments, $color )

    Draw ring outline

 DrawRectangle( $posX, $posY, $width, $height, $color )

    Draw a color-filled rectangle

 DrawRectangleV( $position, $size, $color )

    Draw a color-filled rectangle (Vector version)

 DrawRectangleRec( $rec, $color )

    Draw a color-filled rectangle

 DrawRectanglePro( $rec, $origin, $rotation, $color )

    Draw a color-filled rectangle with pro parameters

 DrawRectangleGradientV( $posX, $posY, $width, $height, $color1, $color2 )

    Draw a vertical-gradient-filled rectangle

 DrawRectangleGradientH( $posX, $posY, $width, $height, $color1, $color2 )

    Draw a horizontal-gradient-filled rectangle

 DrawRectangleGradientEx( $rec, $col1, $col2, $col3, $col4 )

    Draw a gradient-filled rectangle with custom vertex colors

 DrawRectangleLines( $posX, $posY, $width, $height, $color )

    Draw rectangle outline

 DrawRectangleLinesEx( $rec, $lineThick, $color )

    Draw rectangle outline with extended parameters

 DrawRectangleRounded( $rec, $roundness, $segments, $color )

    Draw rectangle with rounded edges

 DrawRectangleRoundedLines( $rec, $roundness, $segments, $lineThick, $color
 )

    Draw rectangle lines with rounded edges

 DrawTriangle( $v1, $v2, $v3 )

    Draw a color-filled triangle (vertex in counter-clockwise order!)

 DrawTriangleLines( $v1, $v2, $v3 )

    Draw triangle outline (vertex in counter-clockwise order!)

 DrawTriangleFan( $points, $pointCount )

    Draw a triangle fan defined by points (first vertex is the center)

 DrawTriangleStrip( $points, $pointCount )

    Draw a triangle strip defined by points

 DrawPoly( $center, $sides, $radius, $rotation, $color )

    Draw a regular polygon (Vector version)

 DrawPolyLines( $center, $sides, $radius, $rotation, $color )

    Draw a polygon outline of n sides

 DrawPolyLinesEx( $center, $sides, $radius, $rotation, $lineThick, $color )

    Draw a polygon outline of n sides with extended parameters

 DrawSplineLinear( $points, $pointCount, $color )

    Draw spline: Linear, minimum 2 points

 DrawSplineBasis( $points, $pointCount, $color )

    Draw spline: B-Spline, minimum 4 points

 DrawSplineCatmullRom( $points, $pointCount, $color )

    Draw spline: Catmull-Rom, minimum 4 points

 DrawSplineBezierQuadratic( $points, $pointCount, $color )

    Draw spline: Quadratic Bezier, minimum 3 points (1 control point): [p1,
    c2, p3, c4...]

 DrawSplineBezierCubic( $points, $pointCount, $color )

    Draw spline: Cubic Bezier, minimum 4 points (2 control points): [p1,
    c2, c3, p4, c5, c6...]

 DrawSplineSegmentLinear( $p1, $p2, $color )

    Draw spline segment: Linear, 2 points

 DrawSplineSegmentBasis( $p1, $p2, $color )

    Draw spline segment: B-Spline, 4 points

 DrawSplineSegmentCatmullRom( $p1, $p2, $color )

    Draw spline segment: Catmull-Rom, 4 points

 DrawSplineSegmentBezierQuadratic( $p1, $p2, $p3, $color )

    Draw spline segment: Quadratic Bezier, 2 points, 1 control point

 DrawSplineSegmentBezierCubic( $p1, $p2, $p3, $p4, $color )

    Draw spline segment: Cubic Bezier, 2 points, 2 control points

 GetSplinePointLinear( $points, $pointCount, $t ) : Raylib::FFI::Vector2D

    Get (evaluate) spline point: Linear Spline segment point evaluation
    functions, for a given t [0.0f .. 1.0f]

 GetSplinePointBasis( $points, $pointCount, $t ) : Raylib::FFI::Vector2D

    Get (evaluate) spline point: B-Spline Spline segment point evaluation
    functions, for a given t [0.0f .. 1.0f]

 GetSplinePointCatmullRom( $points, $pointCount, $t ) :
 Raylib::FFI::Vector2D

    Get (evaluate) spline point: Catmull-Rom Spline segment point
    evaluation functions, for a given t [0.0f .. 1.0f]

 GetSplinePointBezierQuad( $points, $pointCount, $t ) :
 Raylib::FFI::Vector2D

    Get (evaluate) spline point: Quadratic Bezier Spline segment point
    evaluation functions, for a given t [0.0f .. 1.0f]

 GetSplinePointBezierCubic( $points, $pointCount, $t ) :
 Raylib::FFI::Vector2D

    Get (evaluate) spline point: Cubic Bezier Spline segment point
    evaluation functions, for a given t [0.0f .. 1.0f]

 CheckCollisionRecs( $rec1, $rec2 ) : bool

    Check collision between two rectangles

 CheckCollisionCircles( $center1, $radius1, $center2, $radius2 ) : bool

    Check collision between two circles

 CheckCollisionCircleRec( $center, $radius, $rec ) : bool

    Check collision between circle and rectangle

 CheckCollisionPointRec( $point, $rec ) : bool

    Check if point is inside rectangle

 CheckCollisionPointCircle( $point, $center, $radius ) : bool

    Check if point is inside circle

 CheckCollisionPointTriangle( $point, $p1, $p2, $p3 ) : bool

    Check if point is inside a triangle

 CheckCollisionPointPoly( $point, $poly, $polyCount ) : bool

    Check if point is within a polygon described by array of vertices

 CheckCollisionLines( $startPos1, $endPos1, $startPos2, $endPos2,
 $collisionPoint ) : bool

    Check the collision between two lines defined by two points each,
    returns collision point by reference

 CheckCollisionPointLine( $point, $p1, $p2, $threshold ) : bool

    Check if point belongs to line created between two points [p1] and [p2]
    with defined margin in pixels [threshold]

 GetCollisionRec( $rec1, $rec2 ) : Raylib::FFI::Rectangle

    Get collision rectangle for two rectangles collision

 LoadImage( $fileName ) : Raylib::FFI::Image

    Load image from file into CPU memory (RAM) NOTE: This function does not
    require GPU access

 LoadImageRaw( $fileName, $width, $height, $format, $headerSize ) :
 Raylib::FFI::Image

    Load image from RAW file data NOTE: This function does not require GPU
    access

 LoadImageSvg( $string, $width, $height ) : Raylib::FFI::Image

    Load image from SVG file data or string with specified size NOTE: This
    function does not require GPU access

 LoadImageAnim( $fileName, $frames ) : Raylib::FFI::Image

    Load image sequence from file (frames appended to image.data) NOTE:
    This function does not require GPU access

 LoadImageFromMemory( $fileType, $fileData, $dataSize ) :
 Raylib::FFI::Image

    Load image from memory buffer, fileType refers to extension: i.e.
    '.png' NOTE: This function does not require GPU access

 LoadImageFromTexture( $texture ) : Raylib::FFI::Image

    Load image from GPU texture data NOTE: This function requires GPU
    access

 LoadImageFromScreen() : Raylib::FFI::Image

    Load image from screen buffer and (screenshot) NOTE: This function
    requires GPU access

 IsImageValid( $image ) : bool

    Check if an image is ready

 UnloadImage( $image )

    Unload image from CPU memory (RAM)

 ExportImage( $image, $fileName ) : bool

    Export image data to file, returns true on success

 GenImageColor( $width, $height, $color ) : Raylib::FFI::Image

    Generate image: plain color

 GenImageGradientLinear( $width, $height, $top, $bottom ) :
 Raylib::FFI::Image

    Generate image: linear gradient, direction in degrees [0..360],
    0=Vertical gradient

 GenImageGradientRadial( $width, $height, $density, $inner, $outer ) :
 Raylib::FFI::Image

    Generate image: radial gradient

 GenImageGradientSquare( $width, $height, $left, $right, $top, $bottom ) :
 Raylib::FFI::Image

    Generate image: square gradient

 GenImageChecked( $width, $height, $checksX, $checksY, $col1, $col2 ) :
 Raylib::FFI::Image

    Generate image: checked

 GenImageWhiteNoise( $width, $height, $factor ) : Raylib::FFI::Image

    Generate image: white noise

 GenImagePerlinNoise( $width, $height, $offsetX, $offsetY, $scale ) :
 Raylib::FFI::Image

    Generate image: perlin noise

 GenImageCellular( $width, $height, $tileSize ) : Raylib::FFI::Image

    Generate image: cellular algorithm, bigger tileSize means bigger cells

 GenImageText( $width, $height, $text ) : Raylib::FFI::Image

    Generate image: grayscale image from text

 ImageCopy( $image ) : Raylib::FFI::Image

    Create an image duplicate (useful for transformations)

 ImageFromImage( $image, $rec, $rec2 ) : Raylib::FFI::Image

    Create an image from another image region

 ImageText( $text, $fontSize, $color ) : Raylib::FFI::Image

    Create an image from text (default font)

 ImageTextEx($font, $text, $fontSize, $spacing, $tint) : Raylib::FFI::Image

    Create an image from text (custom sprite font)

 ImageFormat( $image, $format )

    Convert image data to desired format

 ImageToPOT( $image )

    Convert image to POT (power-of-two)

 ImageCrop( $image, $crop )

    Crop an image to a defined rectangle

 ImageAlphaCrop( $image, $threshold )

    Crop image depending on alpha value

 ImageAlphaClear( $image, $color, $threshold )

    Clear alpha channel to desired color

 ImageAlphaMask( $image, $mask )

    Apply alpha mask to image

 ImageAlphaPremultiply( $image )

    Premultiply alpha channel

 ImageBlurGaussian( $image, $blurSize, $threshold )

    Apply Gaussian blur using a box blur approximation

 ImageResize( $image, $newWidth, $newHeight )

    Resize image (Bicubic scaling algorithm)

 ImageResizeNN( $image, $newWidth, $newHeight )

    Resize image (Nearest-Neighbor scaling algorithm)

 ImageResizeCanvas( $image, $newWidth, $newHeight, $offsetX, $offsetY,
 $fill )

    Resize canvas and fill with color

 ImageMipmaps( $image )

    Compute all mipmap levels for a provided image

 ImageDither( $image, $rBpp, $gBpp, $bBpp, $aBpp )

    Dither image data to 16bpp or lower (Floyd-Steinberg dithering)

 ImageFlipVertical( $image )

    Flip image vertically

 ImageFlipHorizontal( $image )

    Flip image horizontally

 ImageRotate( $image, $rotation )

    Rotate image

 ImageRotateCW( $image )

    Rotate image clockwise 90deg

 ImageRotateCCW( $image )

    Rotate image counter-clockwise 90deg

 ImageColorTint( $image, $color )

    Modify image color: tint

 ImageColorInvert( $image )

    Modify image color: invert

 ImageColorGrayscale( $image )

    Modify image color: grayscale

 ImageColorContrast( $image, $contrast )

    Modify image color: contrast (-100 to 100)

 ImageColorBrightness( $image, $brightness )

    Modify image color: brightness (-255 to 255)

 ImageColorReplace( $image, $color, $replace )

    Modify image color: replace color

 LoadImageColors( $image ) : Raylib::FFI::Color*

    Load color data from image as a Color array (RGBA - 32bit)

 LoadImagePalette( $image, $maxPaletteSize ) : Raylib::FFI::Color*

    Load colors palette from image as a Color array (RGBA - 32bit)

 UnloadImageColors( $colors )

    Unload color data loaded with LoadImageColors()

 UnloadImagePalette( $colors )

    Unload colors palette loaded with LoadImagePalette()

 GetImageAlphaBorder( $image, $threshold ) : Raylib::FFI::Rectangle

    Get image alpha border rectangle

 GetImageColor( $image, $x, $y ) : Raylib::FFI::Color

    Get image pixel color at (x, y) position

 ImageClearBackground( $image, $color )

    Clear image background with given color

 ImageDrawPixel( $image, $posX, $posY, $color )

    Draw pixel within an image

 ImageDrawPixelV( $image, $position, $color )

    Draw pixel within an image (Vector version)

 ImageDrawLine( $image, $startX, $startY, $endX, $endY, $color )

    Draw line within an image

 ImageDrawLineV( $image, $start, $end, $color )

    aw line within an image (Vector version)

 ImageDrawCircle( $image, $centerX, $centerY, $radius, $color )

    Draw a filled circle within an image

 ImageDrawCircleV( $image, $center, $radius, $color )

    Draw a filled circle within an image (Vector version)

 ImageDrawCircleLines( $image, $centerX, $centerY, $radius, $color )

    Draw circle outline within an image

 ImageDrawRectangle( $image, $posX, $posY, $width, $height, $color )

    Draw circle outline within an image (Vector version)

 ImageDrawRectangleV( $image, $position, $size, $color )

    Draw rectangle within an image

 ImageDrawRectangleV($image, $position, $size, $color)

    Draw rectangle within an image (Vector version)

 ImageDrawRectangleRec( $image, $rec, $color )

    Draw rectangle within an image

 ImageDrawRectangleLines( $image, $rec, $thick, $color )

    Draw rectangle lines within an image

 ImageDraw( $dst, $src, $srcRec, $dstRec, $tint )

    Draw a source image within a destination image (tint applied to source)

 ImageDrawText( $dst, $text, $posX, $posY, $fontSize, $color )

    Draw text (using default font) within an image (destination)

 ImageDrawTextEx( $dst, $text, $position, $fontSize, $spacing, $tint )

    Draw text (custom sprite font) within an image (destination)

 LoadTexture( $fileName ) : Raylib::FFI::Texture2D

    Load texture from file into GPU memory (VRAM) NOTE: This function
    requires GPU access

 LoadTextureFromImage( $image ) : Raylib::FFI::Texture2D

    Load texture from image data NOTE: This function requires GPU access

 LoadTextureCubemap( $image, $layout ) : Raylib::FFI::TextureCubemap

    Load cubemap from image, multiple image cubemap layouts supported NOTE:
    This function requires GPU access

 LoadRenderTexture( $width, $height ) : Raylib::FFI::RenderTexture2D

    Load texture for rendering (framebuffer) NOTE: This function requires
    GPU access

 IsTextureValid( $texture ) : bool

    Check if a texture is valid

 UnloadTexture( $texture )

    Unload texture from GPU memory (VRAM)

 IsReanderTextureValid( $renderTexture ) : bool

    Check if a render texture is ready

 UnloadRenderTexture( $renderTexture )

    Unload render texture from GPU memory (VRAM)

 UpdateTexture( $texture, $pixels )

    Update GPU texture with new data

 UpdateTextureRec( $texture, $rec, $pixels )

    Update GPU texture rectangle with new data

 GenTextureMipmaps( $texture )

    Generate GPU mipmaps for a texture

 SetTextureFilter( $texture, $filter )

    Set texture scaling filter mode

 SetTextureWrap( $texture, $wrap )

    Set texture wrapping mode

 DrawTexture( $texture, $posX, $posY, $tint )

    Draw a Texture2D

 DrawTextureV( $texture, $position, $tint )

    Draw a Texture2D with position defined as Vector2

 DrawTextureEx( $texture, $position, $rotation, $tint )

    Draw a Texture2D with extended parameters

 DrawTextureRec( $texture, $source, $position, $tint )

    Draw a part of a texture defined by a rectangle

 DrawTexturePro( $texture, $source, $dest, $origin, $rotation, $tint )

    Draw a part of a texture defined by a rectangle with 'pro' parameters

 DrawTextureNPatch( $texture, $nPatchInfo, $dest, $origin, $rotation, $tint
 )

    Draws a texture (or part of it) that stretches or shrinks nicely

 Fade( $color, $alpha ) : Raylib::FFI::Color

    Get color with alpha applied

 ColorToInt( $color ) : int

    Get hexadecimal value for a Color

 ColorNormalize( $color ) : Raylib::FFI::Vector4

    Get Color normalized as float [0..1]

 ColorToHSV( $color ) : Raylib::FFI::Vector3

    Get HSV values for a Color

 ColorFromHSV( $hsv ) : Raylib::FFI::Color

    Get Color from HSV values. Hue [0..360], Saturation [0..1], Value
    [0..1]

 ColorTint( $color ) : int

    Get Color multiplied with another color

 ColorBrightness( $color, $factor ) : Raylib::FFI::Color

    Get Color with brightness correction, brightness factor [0..1]

 ColorContrast( $color, $contrast ) : Raylib::FFI::Color

    Get Color with contrast correction, contrast factor [0..1]

 ColorAlpha( $color, $alpha ) : Raylib::FFI::Color

    Get src alpha-blended into dst color with tint

 ColorAlphaBlend( $dst, $src, $tint ) : Raylib::FFI::Color

    Get Color structure from hexadecimal value

 GetColor( $hexValue ) : Raylib::FFI::Color

    Get Color structure from hexadecimal value

 GetPixelColor( $srcPtr, $format ) : Raylib::FFI::Color

    Get Color from a source pixel pointer of certain format

 SetPixelColor( $dstPtr, $color, $format )

    Set color formatted into destination pixel pointer

 GetPixelDataSize( $width, $height, $format ) : int

    Get pixel data size in bytes for certain format

 GetFontDefault() : Raylib::FFI::Font

    Get the default Font

 LoadFont( $fileName ) : Raylib::FFI::Font

    Load font from file into GPU memory (VRAM)

 LoadFontEx( $fileName, $fontSize, $fontChars, $glyphCount ) :
 Raylib::FFI::Font

    Load font from file with extended parameters, use undef for codepoints
    and 0 for codepointCount to load the default character set

 LoadFontFromImage( $image, $fontSize, $fontChars, $glyphCount ) :
 Raylib::FFI::Font

    Load font from Image (XNA style)

 LoadFontFromMemory( $fileType, $fileData, $dataSize, $fontSize,
 $fontChars, $glyphCount ) : Raylib::FFI::Font

    Load font from memory buffer, fileType refers to extension: i.e. '.ttf'

 IsFontValid( $font ) : bool

    Check if a font is valid.

 LoadFontData( $fileData, $dataSize, $fontSize, $fontChars, $glyphCount,
 $type ) : Raylib::FFI::GlyphInfo

    Load font data for further use

 GenImageFontAtlas( $glyphs, $glyphCount, $fontSize, $padding, $packMethod
 ) : Raylib::FFI::Image

    Generate image font atlas using chars info

 UnloadFontData( $glyphs, $glyphCount )

    Unload font chars info data (RAM)

 UnloadFont( $font )

    Unload font from GPU memory (VRAM)

 DrawFPS( $posX, $posY )

    Draw current FPS

 DrawText( $text, $posX, $posY, $fontSize, $color )

    Draw text (using default font)

 DrawTextEx( $font, $text, $position, $fontSize, $spacing, $tint )

    Draw text using font and additional parameters

 DrawTextPro( $font, $text, $position, $origin, $rotation, $fontSize,
 $spacing, $tint )

    Draw text using Font and pro parameters (rotation)

 DrawTextCodepoint( $font, $codepoint, $position, $fontSize, $tint )

    Draw one character (codepoint)

 DrawTextCodepoints( $font, $codepoints, $count, $position, $fontSize,
 $spacing, $tint )

    Draw multiple character (codepoint)

 SetTextLineSpacing( $spacing )

    Set vertical line spacing when drawing with line-breaks

 MeasureText( $text, $fontSize ) : int

    Measure string width for default font

 MeasureTextEx( $font, $text, $fontSize, $spacing ) : Raylib::FFI::Vector2D

    Measure string size for Font

 GetGlyphIndex( $font, $codepoint ) : int

    Get glyph index position in font for a codepoint (unicode character),
    fallback to '?' if not found

 GetGlyphInfo( $font, $codepoint ) : Raylib::FFI::GlyphInfo

    Get glyph font info data for a codepoint (unicode character), fallback
    to '?' if not found

 GetGlyphAtlasRec( $font, $codepoint ) : Raylib::FFI::Rectangle

    Get glyph rectangle in font atlas for a codepoint (unicode character),
    fallback to '?' if not found

 LoadCodepoints( $text, $count ) : int

    Load all codepoints from a UTF-8 text string, codepoints count returned
    by parameter

 UnloadCodepoints( $codepoints, $count )

    Unload codepoints data from memory

 GetCodepointCount( $text ) : int

    Get total number of codepoints in a UTF-8 encoded string

 GetCodepoint( $text, $index ) : int

    Get next codepoint in a UTF-8 encoded string, 0x3f('?') is returned on
    failure

 GetCodepointNext( $text, $index ) : int

    Get next codepoint in a UTF-8 encoded string, 0x3f('?') is returned on
    failure

 GetCodepointPrevious( $text, $index ) : int

    Get previous codepoint in a UTF-8 encoded string, 0x3f('?') is returned
    on failure

 CodepointToUtf8( $codepoint, $byteSize ) : string

    Encode one codepoint into UTF-8 byte array (array length returned as
    parameter)

 TextToInteger( $text ) : int

    Get integer value from text (negative values not supported)

 DrawLine3D( $startPos, $endPos, $color )

    Draw a line in 3D world space

 DrawPoint3D( $position, $color )

    Draw a point in 3D space, actually a small line

 DrawCircle3D( $center, $radius, $rotationAxis, $rotationAngle, $color )

    Draw a circle in 3D world space

 DrawTriangle3D( $v1, $v2, $v3, $color )

    Draw a triangle in 3D space

 DrawTriangleStrip3D( $points, $pointCount, $color )

    Draw a triangle strip defined by points

 DrawCube( $position, $width, $height, $length, $color )

    Draw cube

 DrawCubeV( $position, $size, $color )

    Draw cube (Vector version)

 DrawCubeWires( $position, $width, $height, $length, $color )

    Draw cube wires

    Draw sphere

    Draw sphere with extended parameters

    Draw sphere wires

 DrawCylinder( $position, $radiusTop, $radiusBottom, $height, $slices,
 $color )

    Draw a cylinder/cone

 DrawCylinderEx( $position, $radiusTop, $radiusBottom, $height, $slices,
 $color )

    Draw cylinder with base at startPos and top at endPos

 DrawCylinderWires( $position, $radiusTop, $radiusBottom, $height, $slices,
 $color )

    Draw cylinder/cone wires

 DrawCylinderWiresEx($startPos, $endPos, $startRadius, $endRadius, $sides,
 $color)

    Draw a cylinder with base at startPos and top at endPos

 DrawCapsule( $startPos, $endPos, $radius, $slices, $segments, $color )

    Draw a capsule with the center of its sphere caps at startPos and
    endPos

 DrawCapsuleWires($startPos, $endPos, $radius, $slices, $rings, $color)

    Draw capsule wireframe with the center of its sphere caps at startPos
    and endPos

 DrawPlane($centerPos, $size, $color)

    Draw a plane XZ

 DrawRay( $ray, $color )

    Draw a ray line

 DrawGrid( $slices, $color )

    Draw a grid (centered at (0, 0, 0))

 LoadModel( $fileName ) : Raylib::FFI::Model

    Load model from files (meshes and materials)

 LoadModelFromMesh( $mesh ) : Raylib::FFI::Model

    Load model from generated mesh (default material)

 IsModelValid( $model ) : bool

    Check if an model is ready

 UnloadModel( $model )

    Unload model (including meshes) from memory (RAM and/or VRAM)

 GetModelBoundingBox( $model ) : Raylib::FFI::BoundingBox

    Compute model bounding box limits (considering all meshes)

 DrawModel( $model, $position, $scale, $tint )

    Draw a model (with texture if set)

 DrawModelEx( $model, $position, $rotationAxis, $rotationAngle, $scale,
 $tint )

    Draw a model with extended parameters

 DrawModelWires( $model, $position, $scale, $tint )

    Draw model wires (with texture if set)

 DrawModelWiresEx( $model, $position, $rotationAxis, $rotationAngle,
 $scale, $tint )

    Draw model wires (with texture if set) with extended parameters

 DrawBoundingBox( $box, $color )

    Draw bounding box (wires)

 DrawBillboard( $camera, $texture, $position, $size, $tint )

    Draw a billboard texture

 DrawBillboardRec( $camera, $texture, $source, $position, $size, $tint )

    Draw a billboard texture defined by source

 DrawBillboardPro( $camera, $texture, $source, $position, $up, $size,
 $origin, $rotation, $tint )

    Draw a billboard texture defined by source and rotation

 UploadMesh( $mesh, $dynamic )

    Upload mesh vertex data in GPU and provide VAO/VBO ids

 UnloadMesh( $mesh )

    Unload mesh from CPU and GPU

 DrawMesh( $mesh, $material, $transform )

    Draw a 3d mesh with material and transform

 GetMeshBoundingBox( $mesh ) : Raylib::FFI::BoundingBox

    Compute mesh bounding box limits

 GenMeshTangents( $mesh )

    Compute mesh tangents

 ExportMesh( $mesh, $fileName ) : bool

    Export mesh data to file, returns true on success

 GenMeshPoly( $sides, $radius ) : Raylib::FFI::Mesh

    Generate polygonal mesh

 GenMeshPlane( $width, $length, $resX, $resZ ) : Raylib::FFI::Mesh

    Generate plane mesh (with subdivisions)

 GenMeshCube( $width, $height, $length ) : Raylib::FFI::Mesh

    Generate cuboid mesh

 GenMeshSphere( $radius, $rings, $slices ) : Raylib::FFI::Mesh

    Generate sphere mesh

 GenMeshHemiSphere( $radius, $rings, $segments ) : Raylib::FFI::Mesh

    Generate half-sphere mesh (no bottom cap)

 GenMeshCylinder( $radius, $height, $slices ) : Raylib::FFI::Mesh

    Generate cylinder mesh

 GenMeshCone( $radius, $height, $slices ) : Raylib::FFI::Mesh

    Generate cone/pyramid mesh

 GenMeshTorus( $radius, $size, $radSeg, $sides ) : Raylib::FFI::Mesh

    Generate torus mesh

 GenMeshKnot( $radius, $size, $radSeg, $sides ) : Raylib::FFI::Mesh

    Generate trefoil knot mesh

 GenMeshHeightmap( $heightmap, $size ) : Raylib::FFI::Mesh

    Generate heightmap mesh from image data ($heightmap)

 GenMeshCubicmap( $cubicmap, $cubeSize ) : Raylib::FFI::Mesh

    Generate cubes-based map mesh from image data

 LoadMaterials( $fileName, $materialCount ) : Raylib::FFI::Material

    Load materials from model file

 LoadMaterialDefault() : Raylib::FFI::Material

    Load default material (Supports: Diffuse Maps, Specular Maps, Normal
    Maps)

 IsMaterialValid( $material ) : bool

    Check if a material is ready

 UnloadMaterial( $material )

    Unload material from GPU memory (VRAM)

 SetMaterialTexture( $material, $mapType, $texture )

    Set texture for a material map type (MAT_MAP_DIFFUSE,
    MAT_MAP_SPECULAR...)

 SetModelMeshMaterial( $model, $meshId, $materialId )

    Set material for a mesh

 LoadModelAnimations( $fileName, $animCount ) : Raylib::FFI::ModelAnimation

    Load model animations from file

 UpdateModelAnimation( $model, $anim, $frame )

    Update model animation pose

 UnloadModelAnimation( $anim )

    Unload animation data

 UnloadModelAnimations( $model, $animCount )

    Unload animation array data

 IsModelAnimationValid( $model, $anim ) : bool

    Check model animation skeleton match

 CheckCollisionSpheres( $centerA, $radiusA, $centerB, $radiusB ) : bool

    Check collision between two spheres

 CheckCollisionBoxes( $box1, $box2 ) : bool

    Check collision between two bounding boxes

 CheckCollisionBoxSphere( $box, $center, $radius ) : bool

    Check collision between box and sphere

 GetRayCollisionSphere( $ray, $center, $radius ) :
 Raylib::FFI::RayCollision

    Get collision info between ray and sphere

 GetRayCollisionBox( $ray, $box ) : Raylib::FFI::RayCollision

    Get collision info between ray and box

 GetRayCollisionMesh( $ray, $mesh, $transform ) : Raylib::FFI::RayCollision

    Get collision info between ray and mesh

 GetRayCollisionTriangle( $ray, $p1, $p2, $p3 ) : Raylib::FFI::RayCollision

    Get collision info between ray and triangle

 GetRayCollisionQuad( $ray, $p1, $p2, $p3, $p4 ) :
 Raylib::FFI::RayCollision

    Get collision info between ray and quad

 InitAudioDevice()

    Initialize audio device and context

 CloseAudioDevice()

    Close the audio device and context

 IsAudioDeviceValid() : bool

    Check if audio device has been initialized successfully

 SetMasterVolume( $volume )

    Set master volume (listener)

 GetMasterVolume() : float

    Get master volume (listener)

 LoadWave( $fileName ) : Raylib::FFI::Wave

    Load wave data from file

 LoadWaveFromMemory( $fileType, $fileData, $dataSize ) : Raylib::FFI::Wave

    Load wave from memory buffer, fileType refers to extension: i.e. ".wav"

 LoadSound( $fileName ) : Raylib::FFI::Sound

    Load sound from file

 LoadSoundFromWave( $wave ) : Raylib::FFI::Sound

    Load sound from wave data

 LoadSoundAlias( $sound, $fileName ) : Raylib::FFI::Sound

    Create a new sound that shares the same sound data as another existing
    sound

 IsSoundValid( $sound ) : bool

    Check if a sound is ready

 UpdateSound( $sound, $data )

    Update sound buffer with new data

 UnloadWave( $wave )

    Unload wave data

 UnloadSound( $sound )

    Unload sound

 ExportWave( $wave, $fileName ) : bool

    Export wave data to file, return true on success

 PlaySound( $sound )

    Play a sound

 StopSound( $sound )

    Stop playing a sound

 PauseSound( $sound )

    Pause a sound

 ResumeSound( $sound )

    Resume a paused sound

 IsSoundPlaying( $sound ) : bool

    Check if a sound is currently playing

 SetSoundVolume( $sound, $volume )

    Set volume for a sound (1.0 is max level)

 SetSoundPitch( $sound, $pitch )

    Set pitch for a sound (1.0 is base level)

 SetSoundPan( $sound, $pan )

    Set pan for a sound (0.5 is center)

 WaveCopy( $wave ) : Raylib::FFI::Wave

    Copy a wave to a new wave

 WaveCrop( $wave, $initFrame, $finalFrame )

    Crop a wave to defined samples range

 WaveFormat( $wave, $sampleRate, $sampleSize, $channels )

    Convert wave data to desired format

 LoadWaveSamples( $wave ) : float*

    Load samples data from wave as a 32bit float array

 UnloadWaveSamples( $samples )

    Unload samples data loaded with LoadWaveSamples()

 LoadMusicStream( $fileName ) : Raylib::FFI::Music

    Load music stream from file

 LoadMusicStreamFromMemory( $fileType, $data, $dataSize ) :
 Raylib::FFI::Music

    Load music stream from data

 IsMusicValid( $music ) : bool

    Check if music stream is ready

 UnloadMusicStream( $music )

    Unload music stream

 PlayMusicStream( $music )

    Start music playing

 IsMusicStreamPlaying( $music ) : bool

    Check if music is playing

 UpdateMusicStream( $music )

    Update buffers for music streaming

 StopMusicStream( $music )

    Stop music playing

 PauseMusicStream( $music )

    Pause music playing

 ResumeMusicStream( $music )

    Resume music playing

 SeekMusicStream( $music, $position )

    Seek music to a position (in seconds)

 SetMusicVolume( $music, $volume )

    Set volume for music (1.0 is max level)

 SetMusicPitch( $music, $pitch )

    Set pitch for a music (1.0 is base level)

 SetMusicPan( $music, $pan )

    Set pan for a music (0.5 is center)

 GetMusicTimeLength( $music ) : float

    Get music time length (in seconds)

 GetMusicTimePlayed( $music ) : float

    Get current music time played (in seconds)

 LoadAudioStream( $sampleRate, $sampleSize, $channels ) :
 Raylib::FFI::AudioStream

    Load audio stream (to stream raw audio pcm data)

 IsAudioStreamValid( $audioStream ) : bool

    Check if an audio stream is valid

 UnloadAudioStream( $audioStream )

    Unload audio stream

 UpdateAudioStream( $audioStream, $data, $frameCount )

    Update audio stream buffers with data

 IsAudioStreamProcessed( $audioStream ) : bool

    Check if any audio stream buffers requires refill

 PlayAudioStream( $audioStream )

    Play audio stream

 PauseAudioStream( $audioStream )

    Pause audio stream

 ResumeAudioStream( $audioStream )

    Resume audio stream

 IsAudioStreamPlaying( $audioStream ) : bool

    Check if audio stream is playing

 StopAudioStream( $audioStream )

    Stop audio stream

 SetAudioStreamVolume( $audioStream, $volume )

    Set volume for audio stream (1.0 is max level)

 SetAudioStreamPitch( $audioStream, $pitch )

    Set pitch for audio stream (1.0 is base level)

 SetAudioStreamPan( $audioStream, $pan )

    Set pan for audio stream (0.5 is center)

 SetAudioStreamBufferSizeDefault( $size )

    Default size for new audio streams

KNOWN ISSUES

    Also, this module was put together very quickly, and it's not very well
    tested. There may be differences between the documentation and the
    underlying library. The library is correct, please let me know if you
    find any issues.

SEE ALSO

    http://www.raylib.com

    Graphics::Raylib

    Alien::raylib

AUTHOR

    Chris Prather <chris@prather.org>

    Based on the work of:

    Ahmad Fatoum <athreef@cpan.org>, http://a3f.at

COPYRIGHT AND LICENSE

    This software is copyright (c) 2024 by Chris Prather.

    This is free software; you can redistribute it and/or modify it under
    the same terms as the Perl 5 programming language system itself.

RAYLIB LICENSE

    This is an unofficial wrapper of http://www.raylib.com.

    raylib is Copyright (c) 2013-2016 Ramon Santamaria and available under
    the terms of the zlib/libpng license. Refer to LICENSE
    <https://github.com/raysan5/raylib/blob/5.0/LICENSE> for full terms.

POD ERRORS

    Hey! The above document had some coding errors, which are explained
    below:

    Around line 2732:

      Unknown directive: =head

    Around line 2736:

      Unknown directive: =head

    Around line 2740:

      Unknown directive: =head