raylib 5.6.0.0.dev1__cp312-cp312-win32.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,1469 @@
1
+ /**********************************************************************************************
2
+ *
3
+ * raylib v5.6-dev - A simple and easy-to-use library to enjoy videogames programming (www.raylib.com)
4
+ *
5
+ * FEATURES:
6
+ * - NO external dependencies, all required libraries included with raylib
7
+ * - Multiplatform: Windows, Linux, FreeBSD, OpenBSD, NetBSD, DragonFly,
8
+ * MacOS, Haiku, Android, Raspberry Pi, DRM native, HTML5
9
+ * - Written in plain C code (C99) in PascalCase/camelCase notation
10
+ * - Hardware accelerated with OpenGL (1.1, 2.1, 3.3, 4.3, ES2, ES3 - choose at compile)
11
+ * - Unique OpenGL abstraction layer (usable as standalone module): [rlgl]
12
+ * - Multiple Fonts formats supported (TTF, OTF, FNT, BDF, Sprite fonts)
13
+ * - Outstanding texture formats support, including compressed formats (DXT, ETC, ASTC)
14
+ * - Full 3d support for 3d Shapes, Models, Billboards, Heightmaps and more!
15
+ * - Flexible Materials system, supporting classic maps and PBR maps
16
+ * - Animated 3D models supported (skeletal bones animation) (IQM, M3D, GLTF)
17
+ * - Shaders support, including Model shaders and Postprocessing shaders
18
+ * - Powerful math module for Vector, Matrix and Quaternion operations: [raymath]
19
+ * - Audio loading and playing with streaming support (WAV, OGG, MP3, FLAC, QOA, XM, MOD)
20
+ * - VR stereo rendering with configurable HMD device parameters
21
+ * - Bindings to multiple programming languages available!
22
+ *
23
+ * NOTES:
24
+ * - One default Font is loaded on InitWindow()->LoadFontDefault() [core, text]
25
+ * - One default Texture2D is loaded on rlglInit(), 1x1 white pixel R8G8B8A8 [rlgl] (OpenGL 3.3 or ES2)
26
+ * - One default Shader is loaded on rlglInit()->rlLoadShaderDefault() [rlgl] (OpenGL 3.3 or ES2)
27
+ * - One default RenderBatch is loaded on rlglInit()->rlLoadRenderBatch() [rlgl] (OpenGL 3.3 or ES2)
28
+ *
29
+ * DEPENDENCIES (included):
30
+ * [rcore][GLFW] rglfw (Camilla Löwy - github.com/glfw/glfw) for window/context management and input
31
+ * [rcore][RGFW] rgfw (ColleagueRiley - github.com/ColleagueRiley/RGFW) for window/context management and input
32
+ * [rlgl] glad/glad_gles2 (David Herberth - github.com/Dav1dde/glad) for OpenGL 3.3 extensions loading
33
+ * [raudio] miniaudio (David Reid - github.com/mackron/miniaudio) for audio device/context management
34
+ *
35
+ * OPTIONAL DEPENDENCIES (included):
36
+ * [rcore] sinfl (Micha Mettke) for DEFLATE decompression algorithm
37
+ * [rcore] sdefl (Micha Mettke) for DEFLATE compression algorithm
38
+ * [rcore] rprand (Ramon Santamaria) for pseudo-random numbers generation
39
+ * [rtextures] qoi (Dominic Szablewski - https://phoboslab.org) for QOI image manage
40
+ * [rtextures] stb_image (Sean Barret) for images loading (BMP, TGA, PNG, JPEG, HDR...)
41
+ * [rtextures] stb_image_write (Sean Barret) for image writing (BMP, TGA, PNG, JPG)
42
+ * [rtextures] stb_image_resize2 (Sean Barret) for image resizing algorithms
43
+ * [rtextures] stb_perlin (Sean Barret) for Perlin Noise image generation
44
+ * [rtext] stb_truetype (Sean Barret) for ttf fonts loading
45
+ * [rtext] stb_rect_pack (Sean Barret) for rectangles packing
46
+ * [rmodels] par_shapes (Philip Rideout) for parametric 3d shapes generation
47
+ * [rmodels] tinyobj_loader_c (Syoyo Fujita) for models loading (OBJ, MTL)
48
+ * [rmodels] cgltf (Johannes Kuhlmann) for models loading (glTF)
49
+ * [rmodels] m3d (bzt) for models loading (M3D, https://bztsrc.gitlab.io/model3d)
50
+ * [rmodels] vox_loader (Johann Nadalutti) for models loading (VOX)
51
+ * [raudio] dr_wav (David Reid) for WAV audio file loading
52
+ * [raudio] dr_flac (David Reid) for FLAC audio file loading
53
+ * [raudio] dr_mp3 (David Reid) for MP3 audio file loading
54
+ * [raudio] stb_vorbis (Sean Barret) for OGG audio loading
55
+ * [raudio] jar_xm (Joshua Reisenauer) for XM audio module loading
56
+ * [raudio] jar_mod (Joshua Reisenauer) for MOD audio module loading
57
+ * [raudio] qoa (Dominic Szablewski - https://phoboslab.org) for QOA audio manage
58
+ *
59
+ *
60
+ * LICENSE: zlib/libpng
61
+ *
62
+ * raylib is licensed under an unmodified zlib/libpng license, which is an OSI-certified,
63
+ * BSD-like license that allows static linking with closed source software:
64
+ *
65
+ * Copyright (c) 2013-2025 Ramon Santamaria (@raysan5)
66
+ *
67
+ * This software is provided "as-is", without any express or implied warranty. In no event
68
+ * will the authors be held liable for any damages arising from the use of this software.
69
+ *
70
+ * Permission is granted to anyone to use this software for any purpose, including commercial
71
+ * applications, and to alter it and redistribute it freely, subject to the following restrictions:
72
+ *
73
+ * 1. The origin of this software must not be misrepresented; you must not claim that you
74
+ * wrote the original software. If you use this software in a product, an acknowledgment
75
+ * in the product documentation would be appreciated but is not required.
76
+ *
77
+ * 2. Altered source versions must be plainly marked as such, and must not be misrepresented
78
+ * as being the original software.
79
+ *
80
+ * 3. This notice may not be removed or altered from any source distribution.
81
+ *
82
+ **********************************************************************************************/
83
+ // Function specifiers in case library is build/used as a shared library
84
+ // NOTE: Microsoft specifiers to tell compiler that symbols are imported/exported from a .dll
85
+ // NOTE: visibility("default") attribute makes symbols "visible" when compiled with -fvisibility=hidden
86
+ //----------------------------------------------------------------------------------
87
+ // Defines and Macros
88
+ //----------------------------------------------------------------------------------
89
+ // Allow custom memory allocators
90
+ // NOTE: Require recompiling raylib sources
91
+ // NOTE: MSVC C++ compiler does not support compound literals (C99 feature)
92
+ // Plain structures in C++ (without constructors) can be initialized with { }
93
+ // This is called aggregate initialization (C++11 feature)
94
+ // Some compilers (mostly macos clang) default to C++98,
95
+ // where aggregate initialization can't be used
96
+ // So, give a more clear error stating how to fix this
97
+ // NOTE: Set some defines with some data types declared by raylib
98
+ // Other modules (raymath, rlgl) also require some of those types, so,
99
+ // to be able to use those other modules as standalone (not depending on raylib)
100
+ // this defines are very useful for internal check and avoid type (re)definitions
101
+ // Some Basic Colors
102
+ // NOTE: Custom raylib color palette for amazing visuals on WHITE background
103
+ //----------------------------------------------------------------------------------
104
+ // Types and Structures Definition
105
+ //----------------------------------------------------------------------------------
106
+ // Boolean type
107
+ // Vector2, 2 components
108
+ typedef struct Vector2 {
109
+ float x; // Vector x component
110
+ float y; // Vector y component
111
+ } Vector2;
112
+ // Vector3, 3 components
113
+ typedef struct Vector3 {
114
+ float x; // Vector x component
115
+ float y; // Vector y component
116
+ float z; // Vector z component
117
+ } Vector3;
118
+ // Vector4, 4 components
119
+ typedef struct Vector4 {
120
+ float x; // Vector x component
121
+ float y; // Vector y component
122
+ float z; // Vector z component
123
+ float w; // Vector w component
124
+ } Vector4;
125
+ // Quaternion, 4 components (Vector4 alias)
126
+ typedef Vector4 Quaternion;
127
+ // Matrix, 4x4 components, column major, OpenGL style, right-handed
128
+ typedef struct Matrix {
129
+ float m0, m4, m8, m12; // Matrix first row (4 components)
130
+ float m1, m5, m9, m13; // Matrix second row (4 components)
131
+ float m2, m6, m10, m14; // Matrix third row (4 components)
132
+ float m3, m7, m11, m15; // Matrix fourth row (4 components)
133
+ } Matrix;
134
+ // Color, 4 components, R8G8B8A8 (32bit)
135
+ typedef struct Color {
136
+ unsigned char r; // Color red value
137
+ unsigned char g; // Color green value
138
+ unsigned char b; // Color blue value
139
+ unsigned char a; // Color alpha value
140
+ } Color;
141
+ // Rectangle, 4 components
142
+ typedef struct Rectangle {
143
+ float x; // Rectangle top-left corner position x
144
+ float y; // Rectangle top-left corner position y
145
+ float width; // Rectangle width
146
+ float height; // Rectangle height
147
+ } Rectangle;
148
+ // Image, pixel data stored in CPU memory (RAM)
149
+ typedef struct Image {
150
+ void *data; // Image raw data
151
+ int width; // Image base width
152
+ int height; // Image base height
153
+ int mipmaps; // Mipmap levels, 1 by default
154
+ int format; // Data format (PixelFormat type)
155
+ } Image;
156
+ // Texture, tex data stored in GPU memory (VRAM)
157
+ typedef struct Texture {
158
+ unsigned int id; // OpenGL texture id
159
+ int width; // Texture base width
160
+ int height; // Texture base height
161
+ int mipmaps; // Mipmap levels, 1 by default
162
+ int format; // Data format (PixelFormat type)
163
+ } Texture;
164
+ // Texture2D, same as Texture
165
+ typedef Texture Texture2D;
166
+ // TextureCubemap, same as Texture
167
+ typedef Texture TextureCubemap;
168
+ // RenderTexture, fbo for texture rendering
169
+ typedef struct RenderTexture {
170
+ unsigned int id; // OpenGL framebuffer object id
171
+ Texture texture; // Color buffer attachment texture
172
+ Texture depth; // Depth buffer attachment texture
173
+ } RenderTexture;
174
+ // RenderTexture2D, same as RenderTexture
175
+ typedef RenderTexture RenderTexture2D;
176
+ // NPatchInfo, n-patch layout info
177
+ typedef struct NPatchInfo {
178
+ Rectangle source; // Texture source rectangle
179
+ int left; // Left border offset
180
+ int top; // Top border offset
181
+ int right; // Right border offset
182
+ int bottom; // Bottom border offset
183
+ int layout; // Layout of the n-patch: 3x3, 1x3 or 3x1
184
+ } NPatchInfo;
185
+ // GlyphInfo, font characters glyphs info
186
+ typedef struct GlyphInfo {
187
+ int value; // Character value (Unicode)
188
+ int offsetX; // Character offset X when drawing
189
+ int offsetY; // Character offset Y when drawing
190
+ int advanceX; // Character advance position X
191
+ Image image; // Character image data
192
+ } GlyphInfo;
193
+ // Font, font texture and GlyphInfo array data
194
+ typedef struct Font {
195
+ int baseSize; // Base size (default chars height)
196
+ int glyphCount; // Number of glyph characters
197
+ int glyphPadding; // Padding around the glyph characters
198
+ Texture2D texture; // Texture atlas containing the glyphs
199
+ Rectangle *recs; // Rectangles in texture for the glyphs
200
+ GlyphInfo *glyphs; // Glyphs info data
201
+ } Font;
202
+ // Camera, defines position/orientation in 3d space
203
+ typedef struct Camera3D {
204
+ Vector3 position; // Camera position
205
+ Vector3 target; // Camera target it looks-at
206
+ Vector3 up; // Camera up vector (rotation over its axis)
207
+ float fovy; // Camera field-of-view aperture in Y (degrees) in perspective, used as near plane height in world units in orthographic
208
+ int projection; // Camera projection: CAMERA_PERSPECTIVE or CAMERA_ORTHOGRAPHIC
209
+ } Camera3D;
210
+ typedef Camera3D Camera; // Camera type fallback, defaults to Camera3D
211
+ // Camera2D, defines position/orientation in 2d space
212
+ typedef struct Camera2D {
213
+ Vector2 offset; // Camera offset (screen space offset from window origin)
214
+ Vector2 target; // Camera target (world space target point that is mapped to screen space offset)
215
+ float rotation; // Camera rotation in degrees (pivots around target)
216
+ float zoom; // Camera zoom (scaling around target), must not be set to 0, set to 1.0f for no scale
217
+ } Camera2D;
218
+ // Mesh, vertex data and vao/vbo
219
+ typedef struct Mesh {
220
+ int vertexCount; // Number of vertices stored in arrays
221
+ int triangleCount; // Number of triangles stored (indexed or not)
222
+ // Vertex attributes data
223
+ float *vertices; // Vertex position (XYZ - 3 components per vertex) (shader-location = 0)
224
+ float *texcoords; // Vertex texture coordinates (UV - 2 components per vertex) (shader-location = 1)
225
+ float *texcoords2; // Vertex texture second coordinates (UV - 2 components per vertex) (shader-location = 5)
226
+ float *normals; // Vertex normals (XYZ - 3 components per vertex) (shader-location = 2)
227
+ float *tangents; // Vertex tangents (XYZW - 4 components per vertex) (shader-location = 4)
228
+ unsigned char *colors; // Vertex colors (RGBA - 4 components per vertex) (shader-location = 3)
229
+ unsigned short *indices; // Vertex indices (in case vertex data comes indexed)
230
+ // Animation vertex data
231
+ float *animVertices; // Animated vertex positions (after bones transformations)
232
+ float *animNormals; // Animated normals (after bones transformations)
233
+ unsigned char *boneIds; // Vertex bone ids, max 255 bone ids, up to 4 bones influence by vertex (skinning) (shader-location = 6)
234
+ float *boneWeights; // Vertex bone weight, up to 4 bones influence by vertex (skinning) (shader-location = 7)
235
+ Matrix *boneMatrices; // Bones animated transformation matrices
236
+ int boneCount; // Number of bones
237
+ // OpenGL identifiers
238
+ unsigned int vaoId; // OpenGL Vertex Array Object id
239
+ unsigned int *vboId; // OpenGL Vertex Buffer Objects id (default vertex data)
240
+ } Mesh;
241
+ // Shader
242
+ typedef struct Shader {
243
+ unsigned int id; // Shader program id
244
+ int *locs; // Shader locations array (RL_MAX_SHADER_LOCATIONS)
245
+ } Shader;
246
+ // MaterialMap
247
+ typedef struct MaterialMap {
248
+ Texture2D texture; // Material map texture
249
+ Color color; // Material map color
250
+ float value; // Material map value
251
+ } MaterialMap;
252
+ // Material, includes shader and maps
253
+ typedef struct Material {
254
+ Shader shader; // Material shader
255
+ MaterialMap *maps; // Material maps array (MAX_MATERIAL_MAPS)
256
+ float params[4]; // Material generic parameters (if required)
257
+ } Material;
258
+ // Transform, vertex transformation data
259
+ typedef struct Transform {
260
+ Vector3 translation; // Translation
261
+ Quaternion rotation; // Rotation
262
+ Vector3 scale; // Scale
263
+ } Transform;
264
+ // Bone, skeletal animation bone
265
+ typedef struct BoneInfo {
266
+ char name[32]; // Bone name
267
+ int parent; // Bone parent
268
+ } BoneInfo;
269
+ // Model, meshes, materials and animation data
270
+ typedef struct Model {
271
+ Matrix transform; // Local transform matrix
272
+ int meshCount; // Number of meshes
273
+ int materialCount; // Number of materials
274
+ Mesh *meshes; // Meshes array
275
+ Material *materials; // Materials array
276
+ int *meshMaterial; // Mesh material number
277
+ // Animation data
278
+ int boneCount; // Number of bones
279
+ BoneInfo *bones; // Bones information (skeleton)
280
+ Transform *bindPose; // Bones base transformation (pose)
281
+ } Model;
282
+ // ModelAnimation
283
+ typedef struct ModelAnimation {
284
+ int boneCount; // Number of bones
285
+ int frameCount; // Number of animation frames
286
+ BoneInfo *bones; // Bones information (skeleton)
287
+ Transform **framePoses; // Poses array by frame
288
+ char name[32]; // Animation name
289
+ } ModelAnimation;
290
+ // Ray, ray for raycasting
291
+ typedef struct Ray {
292
+ Vector3 position; // Ray position (origin)
293
+ Vector3 direction; // Ray direction (normalized)
294
+ } Ray;
295
+ // RayCollision, ray hit information
296
+ typedef struct RayCollision {
297
+ bool hit; // Did the ray hit something?
298
+ float distance; // Distance to the nearest hit
299
+ Vector3 point; // Point of the nearest hit
300
+ Vector3 normal; // Surface normal of hit
301
+ } RayCollision;
302
+ // BoundingBox
303
+ typedef struct BoundingBox {
304
+ Vector3 min; // Minimum vertex box-corner
305
+ Vector3 max; // Maximum vertex box-corner
306
+ } BoundingBox;
307
+ // Wave, audio wave data
308
+ typedef struct Wave {
309
+ unsigned int frameCount; // Total number of frames (considering channels)
310
+ unsigned int sampleRate; // Frequency (samples per second)
311
+ unsigned int sampleSize; // Bit depth (bits per sample): 8, 16, 32 (24 not supported)
312
+ unsigned int channels; // Number of channels (1-mono, 2-stereo, ...)
313
+ void *data; // Buffer data pointer
314
+ } Wave;
315
+ // Opaque structs declaration
316
+ // NOTE: Actual structs are defined internally in raudio module
317
+ typedef struct rAudioBuffer rAudioBuffer;
318
+ typedef struct rAudioProcessor rAudioProcessor;
319
+ // AudioStream, custom audio stream
320
+ typedef struct AudioStream {
321
+ rAudioBuffer *buffer; // Pointer to internal data used by the audio system
322
+ rAudioProcessor *processor; // Pointer to internal data processor, useful for audio effects
323
+ unsigned int sampleRate; // Frequency (samples per second)
324
+ unsigned int sampleSize; // Bit depth (bits per sample): 8, 16, 32 (24 not supported)
325
+ unsigned int channels; // Number of channels (1-mono, 2-stereo, ...)
326
+ } AudioStream;
327
+ // Sound
328
+ typedef struct Sound {
329
+ AudioStream stream; // Audio stream
330
+ unsigned int frameCount; // Total number of frames (considering channels)
331
+ } Sound;
332
+ // Music, audio stream, anything longer than ~10 seconds should be streamed
333
+ typedef struct Music {
334
+ AudioStream stream; // Audio stream
335
+ unsigned int frameCount; // Total number of frames (considering channels)
336
+ bool looping; // Music looping enable
337
+ int ctxType; // Type of music context (audio filetype)
338
+ void *ctxData; // Audio context data, depends on type
339
+ } Music;
340
+ // VrDeviceInfo, Head-Mounted-Display device parameters
341
+ typedef struct VrDeviceInfo {
342
+ int hResolution; // Horizontal resolution in pixels
343
+ int vResolution; // Vertical resolution in pixels
344
+ float hScreenSize; // Horizontal size in meters
345
+ float vScreenSize; // Vertical size in meters
346
+ float eyeToScreenDistance; // Distance between eye and display in meters
347
+ float lensSeparationDistance; // Lens separation distance in meters
348
+ float interpupillaryDistance; // IPD (distance between pupils) in meters
349
+ float lensDistortionValues[4]; // Lens distortion constant parameters
350
+ float chromaAbCorrection[4]; // Chromatic aberration correction parameters
351
+ } VrDeviceInfo;
352
+ // VrStereoConfig, VR stereo rendering configuration for simulator
353
+ typedef struct VrStereoConfig {
354
+ Matrix projection[2]; // VR projection matrices (per eye)
355
+ Matrix viewOffset[2]; // VR view offset matrices (per eye)
356
+ float leftLensCenter[2]; // VR left lens center
357
+ float rightLensCenter[2]; // VR right lens center
358
+ float leftScreenCenter[2]; // VR left screen center
359
+ float rightScreenCenter[2]; // VR right screen center
360
+ float scale[2]; // VR distortion scale
361
+ float scaleIn[2]; // VR distortion scale in
362
+ } VrStereoConfig;
363
+ // File path list
364
+ typedef struct FilePathList {
365
+ unsigned int capacity; // Filepaths max entries
366
+ unsigned int count; // Filepaths entries count
367
+ char **paths; // Filepaths entries
368
+ } FilePathList;
369
+ // Automation event
370
+ typedef struct AutomationEvent {
371
+ unsigned int frame; // Event frame
372
+ unsigned int type; // Event type (AutomationEventType)
373
+ int params[4]; // Event parameters (if required)
374
+ } AutomationEvent;
375
+ // Automation event list
376
+ typedef struct AutomationEventList {
377
+ unsigned int capacity; // Events max entries (MAX_AUTOMATION_EVENTS)
378
+ unsigned int count; // Events entries count
379
+ AutomationEvent *events; // Events entries
380
+ } AutomationEventList;
381
+ //----------------------------------------------------------------------------------
382
+ // Enumerators Definition
383
+ //----------------------------------------------------------------------------------
384
+ // System/Window config flags
385
+ // NOTE: Every bit registers one state (use it with bit masks)
386
+ // By default all flags are set to 0
387
+ typedef enum {
388
+ FLAG_VSYNC_HINT = 0x00000040, // Set to try enabling V-Sync on GPU
389
+ FLAG_FULLSCREEN_MODE = 0x00000002, // Set to run program in fullscreen
390
+ FLAG_WINDOW_RESIZABLE = 0x00000004, // Set to allow resizable window
391
+ FLAG_WINDOW_UNDECORATED = 0x00000008, // Set to disable window decoration (frame and buttons)
392
+ FLAG_WINDOW_HIDDEN = 0x00000080, // Set to hide window
393
+ FLAG_WINDOW_MINIMIZED = 0x00000200, // Set to minimize window (iconify)
394
+ FLAG_WINDOW_MAXIMIZED = 0x00000400, // Set to maximize window (expanded to monitor)
395
+ FLAG_WINDOW_UNFOCUSED = 0x00000800, // Set to window non focused
396
+ FLAG_WINDOW_TOPMOST = 0x00001000, // Set to window always on top
397
+ FLAG_WINDOW_ALWAYS_RUN = 0x00000100, // Set to allow windows running while minimized
398
+ FLAG_WINDOW_TRANSPARENT = 0x00000010, // Set to allow transparent framebuffer
399
+ FLAG_WINDOW_HIGHDPI = 0x00002000, // Set to support HighDPI
400
+ FLAG_WINDOW_MOUSE_PASSTHROUGH = 0x00004000, // Set to support mouse passthrough, only supported when FLAG_WINDOW_UNDECORATED
401
+ FLAG_BORDERLESS_WINDOWED_MODE = 0x00008000, // Set to run program in borderless windowed mode
402
+ FLAG_MSAA_4X_HINT = 0x00000020, // Set to try enabling MSAA 4X
403
+ FLAG_INTERLACED_HINT = 0x00010000 // Set to try enabling interlaced video format (for V3D)
404
+ } ConfigFlags;
405
+ // Trace log level
406
+ // NOTE: Organized by priority level
407
+ typedef enum {
408
+ LOG_ALL = 0, // Display all logs
409
+ LOG_TRACE, // Trace logging, intended for internal use only
410
+ LOG_DEBUG, // Debug logging, used for internal debugging, it should be disabled on release builds
411
+ LOG_INFO, // Info logging, used for program execution info
412
+ LOG_WARNING, // Warning logging, used on recoverable failures
413
+ LOG_ERROR, // Error logging, used on unrecoverable failures
414
+ LOG_FATAL, // Fatal logging, used to abort program: exit(EXIT_FAILURE)
415
+ LOG_NONE // Disable logging
416
+ } TraceLogLevel;
417
+ // Keyboard keys (US keyboard layout)
418
+ // NOTE: Use GetKeyPressed() to allow redefining
419
+ // required keys for alternative layouts
420
+ typedef enum {
421
+ KEY_NULL = 0, // Key: NULL, used for no key pressed
422
+ // Alphanumeric keys
423
+ KEY_APOSTROPHE = 39, // Key: '
424
+ KEY_COMMA = 44, // Key: ,
425
+ KEY_MINUS = 45, // Key: -
426
+ KEY_PERIOD = 46, // Key: .
427
+ KEY_SLASH = 47, // Key: /
428
+ KEY_ZERO = 48, // Key: 0
429
+ KEY_ONE = 49, // Key: 1
430
+ KEY_TWO = 50, // Key: 2
431
+ KEY_THREE = 51, // Key: 3
432
+ KEY_FOUR = 52, // Key: 4
433
+ KEY_FIVE = 53, // Key: 5
434
+ KEY_SIX = 54, // Key: 6
435
+ KEY_SEVEN = 55, // Key: 7
436
+ KEY_EIGHT = 56, // Key: 8
437
+ KEY_NINE = 57, // Key: 9
438
+ KEY_SEMICOLON = 59, // Key: ;
439
+ KEY_EQUAL = 61, // Key: =
440
+ KEY_A = 65, // Key: A | a
441
+ KEY_B = 66, // Key: B | b
442
+ KEY_C = 67, // Key: C | c
443
+ KEY_D = 68, // Key: D | d
444
+ KEY_E = 69, // Key: E | e
445
+ KEY_F = 70, // Key: F | f
446
+ KEY_G = 71, // Key: G | g
447
+ KEY_H = 72, // Key: H | h
448
+ KEY_I = 73, // Key: I | i
449
+ KEY_J = 74, // Key: J | j
450
+ KEY_K = 75, // Key: K | k
451
+ KEY_L = 76, // Key: L | l
452
+ KEY_M = 77, // Key: M | m
453
+ KEY_N = 78, // Key: N | n
454
+ KEY_O = 79, // Key: O | o
455
+ KEY_P = 80, // Key: P | p
456
+ KEY_Q = 81, // Key: Q | q
457
+ KEY_R = 82, // Key: R | r
458
+ KEY_S = 83, // Key: S | s
459
+ KEY_T = 84, // Key: T | t
460
+ KEY_U = 85, // Key: U | u
461
+ KEY_V = 86, // Key: V | v
462
+ KEY_W = 87, // Key: W | w
463
+ KEY_X = 88, // Key: X | x
464
+ KEY_Y = 89, // Key: Y | y
465
+ KEY_Z = 90, // Key: Z | z
466
+ KEY_LEFT_BRACKET = 91, // Key: [
467
+ KEY_BACKSLASH = 92, // Key: '\'
468
+ KEY_RIGHT_BRACKET = 93, // Key: ]
469
+ KEY_GRAVE = 96, // Key: `
470
+ // Function keys
471
+ KEY_SPACE = 32, // Key: Space
472
+ KEY_ESCAPE = 256, // Key: Esc
473
+ KEY_ENTER = 257, // Key: Enter
474
+ KEY_TAB = 258, // Key: Tab
475
+ KEY_BACKSPACE = 259, // Key: Backspace
476
+ KEY_INSERT = 260, // Key: Ins
477
+ KEY_DELETE = 261, // Key: Del
478
+ KEY_RIGHT = 262, // Key: Cursor right
479
+ KEY_LEFT = 263, // Key: Cursor left
480
+ KEY_DOWN = 264, // Key: Cursor down
481
+ KEY_UP = 265, // Key: Cursor up
482
+ KEY_PAGE_UP = 266, // Key: Page up
483
+ KEY_PAGE_DOWN = 267, // Key: Page down
484
+ KEY_HOME = 268, // Key: Home
485
+ KEY_END = 269, // Key: End
486
+ KEY_CAPS_LOCK = 280, // Key: Caps lock
487
+ KEY_SCROLL_LOCK = 281, // Key: Scroll down
488
+ KEY_NUM_LOCK = 282, // Key: Num lock
489
+ KEY_PRINT_SCREEN = 283, // Key: Print screen
490
+ KEY_PAUSE = 284, // Key: Pause
491
+ KEY_F1 = 290, // Key: F1
492
+ KEY_F2 = 291, // Key: F2
493
+ KEY_F3 = 292, // Key: F3
494
+ KEY_F4 = 293, // Key: F4
495
+ KEY_F5 = 294, // Key: F5
496
+ KEY_F6 = 295, // Key: F6
497
+ KEY_F7 = 296, // Key: F7
498
+ KEY_F8 = 297, // Key: F8
499
+ KEY_F9 = 298, // Key: F9
500
+ KEY_F10 = 299, // Key: F10
501
+ KEY_F11 = 300, // Key: F11
502
+ KEY_F12 = 301, // Key: F12
503
+ KEY_LEFT_SHIFT = 340, // Key: Shift left
504
+ KEY_LEFT_CONTROL = 341, // Key: Control left
505
+ KEY_LEFT_ALT = 342, // Key: Alt left
506
+ KEY_LEFT_SUPER = 343, // Key: Super left
507
+ KEY_RIGHT_SHIFT = 344, // Key: Shift right
508
+ KEY_RIGHT_CONTROL = 345, // Key: Control right
509
+ KEY_RIGHT_ALT = 346, // Key: Alt right
510
+ KEY_RIGHT_SUPER = 347, // Key: Super right
511
+ KEY_KB_MENU = 348, // Key: KB menu
512
+ // Keypad keys
513
+ KEY_KP_0 = 320, // Key: Keypad 0
514
+ KEY_KP_1 = 321, // Key: Keypad 1
515
+ KEY_KP_2 = 322, // Key: Keypad 2
516
+ KEY_KP_3 = 323, // Key: Keypad 3
517
+ KEY_KP_4 = 324, // Key: Keypad 4
518
+ KEY_KP_5 = 325, // Key: Keypad 5
519
+ KEY_KP_6 = 326, // Key: Keypad 6
520
+ KEY_KP_7 = 327, // Key: Keypad 7
521
+ KEY_KP_8 = 328, // Key: Keypad 8
522
+ KEY_KP_9 = 329, // Key: Keypad 9
523
+ KEY_KP_DECIMAL = 330, // Key: Keypad .
524
+ KEY_KP_DIVIDE = 331, // Key: Keypad /
525
+ KEY_KP_MULTIPLY = 332, // Key: Keypad *
526
+ KEY_KP_SUBTRACT = 333, // Key: Keypad -
527
+ KEY_KP_ADD = 334, // Key: Keypad +
528
+ KEY_KP_ENTER = 335, // Key: Keypad Enter
529
+ KEY_KP_EQUAL = 336, // Key: Keypad =
530
+ // Android key buttons
531
+ KEY_BACK = 4, // Key: Android back button
532
+ KEY_MENU = 5, // Key: Android menu button
533
+ KEY_VOLUME_UP = 24, // Key: Android volume up button
534
+ KEY_VOLUME_DOWN = 25 // Key: Android volume down button
535
+ } KeyboardKey;
536
+ // Add backwards compatibility support for deprecated names
537
+ // Mouse buttons
538
+ typedef enum {
539
+ MOUSE_BUTTON_LEFT = 0, // Mouse button left
540
+ MOUSE_BUTTON_RIGHT = 1, // Mouse button right
541
+ MOUSE_BUTTON_MIDDLE = 2, // Mouse button middle (pressed wheel)
542
+ MOUSE_BUTTON_SIDE = 3, // Mouse button side (advanced mouse device)
543
+ MOUSE_BUTTON_EXTRA = 4, // Mouse button extra (advanced mouse device)
544
+ MOUSE_BUTTON_FORWARD = 5, // Mouse button forward (advanced mouse device)
545
+ MOUSE_BUTTON_BACK = 6, // Mouse button back (advanced mouse device)
546
+ } MouseButton;
547
+ // Mouse cursor
548
+ typedef enum {
549
+ MOUSE_CURSOR_DEFAULT = 0, // Default pointer shape
550
+ MOUSE_CURSOR_ARROW = 1, // Arrow shape
551
+ MOUSE_CURSOR_IBEAM = 2, // Text writing cursor shape
552
+ MOUSE_CURSOR_CROSSHAIR = 3, // Cross shape
553
+ MOUSE_CURSOR_POINTING_HAND = 4, // Pointing hand cursor
554
+ MOUSE_CURSOR_RESIZE_EW = 5, // Horizontal resize/move arrow shape
555
+ MOUSE_CURSOR_RESIZE_NS = 6, // Vertical resize/move arrow shape
556
+ MOUSE_CURSOR_RESIZE_NWSE = 7, // Top-left to bottom-right diagonal resize/move arrow shape
557
+ MOUSE_CURSOR_RESIZE_NESW = 8, // The top-right to bottom-left diagonal resize/move arrow shape
558
+ MOUSE_CURSOR_RESIZE_ALL = 9, // The omnidirectional resize/move cursor shape
559
+ MOUSE_CURSOR_NOT_ALLOWED = 10 // The operation-not-allowed shape
560
+ } MouseCursor;
561
+ // Gamepad buttons
562
+ typedef enum {
563
+ GAMEPAD_BUTTON_UNKNOWN = 0, // Unknown button, just for error checking
564
+ GAMEPAD_BUTTON_LEFT_FACE_UP, // Gamepad left DPAD up button
565
+ GAMEPAD_BUTTON_LEFT_FACE_RIGHT, // Gamepad left DPAD right button
566
+ GAMEPAD_BUTTON_LEFT_FACE_DOWN, // Gamepad left DPAD down button
567
+ GAMEPAD_BUTTON_LEFT_FACE_LEFT, // Gamepad left DPAD left button
568
+ GAMEPAD_BUTTON_RIGHT_FACE_UP, // Gamepad right button up (i.e. PS3: Triangle, Xbox: Y)
569
+ GAMEPAD_BUTTON_RIGHT_FACE_RIGHT, // Gamepad right button right (i.e. PS3: Circle, Xbox: B)
570
+ GAMEPAD_BUTTON_RIGHT_FACE_DOWN, // Gamepad right button down (i.e. PS3: Cross, Xbox: A)
571
+ GAMEPAD_BUTTON_RIGHT_FACE_LEFT, // Gamepad right button left (i.e. PS3: Square, Xbox: X)
572
+ GAMEPAD_BUTTON_LEFT_TRIGGER_1, // Gamepad top/back trigger left (first), it could be a trailing button
573
+ GAMEPAD_BUTTON_LEFT_TRIGGER_2, // Gamepad top/back trigger left (second), it could be a trailing button
574
+ GAMEPAD_BUTTON_RIGHT_TRIGGER_1, // Gamepad top/back trigger right (first), it could be a trailing button
575
+ GAMEPAD_BUTTON_RIGHT_TRIGGER_2, // Gamepad top/back trigger right (second), it could be a trailing button
576
+ GAMEPAD_BUTTON_MIDDLE_LEFT, // Gamepad center buttons, left one (i.e. PS3: Select)
577
+ GAMEPAD_BUTTON_MIDDLE, // Gamepad center buttons, middle one (i.e. PS3: PS, Xbox: XBOX)
578
+ GAMEPAD_BUTTON_MIDDLE_RIGHT, // Gamepad center buttons, right one (i.e. PS3: Start)
579
+ GAMEPAD_BUTTON_LEFT_THUMB, // Gamepad joystick pressed button left
580
+ GAMEPAD_BUTTON_RIGHT_THUMB // Gamepad joystick pressed button right
581
+ } GamepadButton;
582
+ // Gamepad axes
583
+ typedef enum {
584
+ GAMEPAD_AXIS_LEFT_X = 0, // Gamepad left stick X axis
585
+ GAMEPAD_AXIS_LEFT_Y = 1, // Gamepad left stick Y axis
586
+ GAMEPAD_AXIS_RIGHT_X = 2, // Gamepad right stick X axis
587
+ GAMEPAD_AXIS_RIGHT_Y = 3, // Gamepad right stick Y axis
588
+ GAMEPAD_AXIS_LEFT_TRIGGER = 4, // Gamepad back trigger left, pressure level: [1..-1]
589
+ GAMEPAD_AXIS_RIGHT_TRIGGER = 5 // Gamepad back trigger right, pressure level: [1..-1]
590
+ } GamepadAxis;
591
+ // Material map index
592
+ typedef enum {
593
+ MATERIAL_MAP_ALBEDO = 0, // Albedo material (same as: MATERIAL_MAP_DIFFUSE)
594
+ MATERIAL_MAP_METALNESS, // Metalness material (same as: MATERIAL_MAP_SPECULAR)
595
+ MATERIAL_MAP_NORMAL, // Normal material
596
+ MATERIAL_MAP_ROUGHNESS, // Roughness material
597
+ MATERIAL_MAP_OCCLUSION, // Ambient occlusion material
598
+ MATERIAL_MAP_EMISSION, // Emission material
599
+ MATERIAL_MAP_HEIGHT, // Heightmap material
600
+ MATERIAL_MAP_CUBEMAP, // Cubemap material (NOTE: Uses GL_TEXTURE_CUBE_MAP)
601
+ MATERIAL_MAP_IRRADIANCE, // Irradiance material (NOTE: Uses GL_TEXTURE_CUBE_MAP)
602
+ MATERIAL_MAP_PREFILTER, // Prefilter material (NOTE: Uses GL_TEXTURE_CUBE_MAP)
603
+ MATERIAL_MAP_BRDF // Brdf material
604
+ } MaterialMapIndex;
605
+ // Shader location index
606
+ typedef enum {
607
+ SHADER_LOC_VERTEX_POSITION = 0, // Shader location: vertex attribute: position
608
+ SHADER_LOC_VERTEX_TEXCOORD01, // Shader location: vertex attribute: texcoord01
609
+ SHADER_LOC_VERTEX_TEXCOORD02, // Shader location: vertex attribute: texcoord02
610
+ SHADER_LOC_VERTEX_NORMAL, // Shader location: vertex attribute: normal
611
+ SHADER_LOC_VERTEX_TANGENT, // Shader location: vertex attribute: tangent
612
+ SHADER_LOC_VERTEX_COLOR, // Shader location: vertex attribute: color
613
+ SHADER_LOC_MATRIX_MVP, // Shader location: matrix uniform: model-view-projection
614
+ SHADER_LOC_MATRIX_VIEW, // Shader location: matrix uniform: view (camera transform)
615
+ SHADER_LOC_MATRIX_PROJECTION, // Shader location: matrix uniform: projection
616
+ SHADER_LOC_MATRIX_MODEL, // Shader location: matrix uniform: model (transform)
617
+ SHADER_LOC_MATRIX_NORMAL, // Shader location: matrix uniform: normal
618
+ SHADER_LOC_VECTOR_VIEW, // Shader location: vector uniform: view
619
+ SHADER_LOC_COLOR_DIFFUSE, // Shader location: vector uniform: diffuse color
620
+ SHADER_LOC_COLOR_SPECULAR, // Shader location: vector uniform: specular color
621
+ SHADER_LOC_COLOR_AMBIENT, // Shader location: vector uniform: ambient color
622
+ SHADER_LOC_MAP_ALBEDO, // Shader location: sampler2d texture: albedo (same as: SHADER_LOC_MAP_DIFFUSE)
623
+ SHADER_LOC_MAP_METALNESS, // Shader location: sampler2d texture: metalness (same as: SHADER_LOC_MAP_SPECULAR)
624
+ SHADER_LOC_MAP_NORMAL, // Shader location: sampler2d texture: normal
625
+ SHADER_LOC_MAP_ROUGHNESS, // Shader location: sampler2d texture: roughness
626
+ SHADER_LOC_MAP_OCCLUSION, // Shader location: sampler2d texture: occlusion
627
+ SHADER_LOC_MAP_EMISSION, // Shader location: sampler2d texture: emission
628
+ SHADER_LOC_MAP_HEIGHT, // Shader location: sampler2d texture: height
629
+ SHADER_LOC_MAP_CUBEMAP, // Shader location: samplerCube texture: cubemap
630
+ SHADER_LOC_MAP_IRRADIANCE, // Shader location: samplerCube texture: irradiance
631
+ SHADER_LOC_MAP_PREFILTER, // Shader location: samplerCube texture: prefilter
632
+ SHADER_LOC_MAP_BRDF, // Shader location: sampler2d texture: brdf
633
+ SHADER_LOC_VERTEX_BONEIDS, // Shader location: vertex attribute: boneIds
634
+ SHADER_LOC_VERTEX_BONEWEIGHTS, // Shader location: vertex attribute: boneWeights
635
+ SHADER_LOC_BONE_MATRICES, // Shader location: array of matrices uniform: boneMatrices
636
+ SHADER_LOC_VERTEX_INSTANCE_TX // Shader location: vertex attribute: instanceTransform
637
+ } ShaderLocationIndex;
638
+ // Shader uniform data type
639
+ typedef enum {
640
+ SHADER_UNIFORM_FLOAT = 0, // Shader uniform type: float
641
+ SHADER_UNIFORM_VEC2, // Shader uniform type: vec2 (2 float)
642
+ SHADER_UNIFORM_VEC3, // Shader uniform type: vec3 (3 float)
643
+ SHADER_UNIFORM_VEC4, // Shader uniform type: vec4 (4 float)
644
+ SHADER_UNIFORM_INT, // Shader uniform type: int
645
+ SHADER_UNIFORM_IVEC2, // Shader uniform type: ivec2 (2 int)
646
+ SHADER_UNIFORM_IVEC3, // Shader uniform type: ivec3 (3 int)
647
+ SHADER_UNIFORM_IVEC4, // Shader uniform type: ivec4 (4 int)
648
+ SHADER_UNIFORM_UINT, // Shader uniform type: unsigned int
649
+ SHADER_UNIFORM_UIVEC2, // Shader uniform type: uivec2 (2 unsigned int)
650
+ SHADER_UNIFORM_UIVEC3, // Shader uniform type: uivec3 (3 unsigned int)
651
+ SHADER_UNIFORM_UIVEC4, // Shader uniform type: uivec4 (4 unsigned int)
652
+ SHADER_UNIFORM_SAMPLER2D // Shader uniform type: sampler2d
653
+ } ShaderUniformDataType;
654
+ // Shader attribute data types
655
+ typedef enum {
656
+ SHADER_ATTRIB_FLOAT = 0, // Shader attribute type: float
657
+ SHADER_ATTRIB_VEC2, // Shader attribute type: vec2 (2 float)
658
+ SHADER_ATTRIB_VEC3, // Shader attribute type: vec3 (3 float)
659
+ SHADER_ATTRIB_VEC4 // Shader attribute type: vec4 (4 float)
660
+ } ShaderAttributeDataType;
661
+ // Pixel formats
662
+ // NOTE: Support depends on OpenGL version and platform
663
+ typedef enum {
664
+ PIXELFORMAT_UNCOMPRESSED_GRAYSCALE = 1, // 8 bit per pixel (no alpha)
665
+ PIXELFORMAT_UNCOMPRESSED_GRAY_ALPHA, // 8*2 bpp (2 channels)
666
+ PIXELFORMAT_UNCOMPRESSED_R5G6B5, // 16 bpp
667
+ PIXELFORMAT_UNCOMPRESSED_R8G8B8, // 24 bpp
668
+ PIXELFORMAT_UNCOMPRESSED_R5G5B5A1, // 16 bpp (1 bit alpha)
669
+ PIXELFORMAT_UNCOMPRESSED_R4G4B4A4, // 16 bpp (4 bit alpha)
670
+ PIXELFORMAT_UNCOMPRESSED_R8G8B8A8, // 32 bpp
671
+ PIXELFORMAT_UNCOMPRESSED_R32, // 32 bpp (1 channel - float)
672
+ PIXELFORMAT_UNCOMPRESSED_R32G32B32, // 32*3 bpp (3 channels - float)
673
+ PIXELFORMAT_UNCOMPRESSED_R32G32B32A32, // 32*4 bpp (4 channels - float)
674
+ PIXELFORMAT_UNCOMPRESSED_R16, // 16 bpp (1 channel - half float)
675
+ PIXELFORMAT_UNCOMPRESSED_R16G16B16, // 16*3 bpp (3 channels - half float)
676
+ PIXELFORMAT_UNCOMPRESSED_R16G16B16A16, // 16*4 bpp (4 channels - half float)
677
+ PIXELFORMAT_COMPRESSED_DXT1_RGB, // 4 bpp (no alpha)
678
+ PIXELFORMAT_COMPRESSED_DXT1_RGBA, // 4 bpp (1 bit alpha)
679
+ PIXELFORMAT_COMPRESSED_DXT3_RGBA, // 8 bpp
680
+ PIXELFORMAT_COMPRESSED_DXT5_RGBA, // 8 bpp
681
+ PIXELFORMAT_COMPRESSED_ETC1_RGB, // 4 bpp
682
+ PIXELFORMAT_COMPRESSED_ETC2_RGB, // 4 bpp
683
+ PIXELFORMAT_COMPRESSED_ETC2_EAC_RGBA, // 8 bpp
684
+ PIXELFORMAT_COMPRESSED_PVRT_RGB, // 4 bpp
685
+ PIXELFORMAT_COMPRESSED_PVRT_RGBA, // 4 bpp
686
+ PIXELFORMAT_COMPRESSED_ASTC_4x4_RGBA, // 8 bpp
687
+ PIXELFORMAT_COMPRESSED_ASTC_8x8_RGBA // 2 bpp
688
+ } PixelFormat;
689
+ // Texture parameters: filter mode
690
+ // NOTE 1: Filtering considers mipmaps if available in the texture
691
+ // NOTE 2: Filter is accordingly set for minification and magnification
692
+ typedef enum {
693
+ TEXTURE_FILTER_POINT = 0, // No filter, just pixel approximation
694
+ TEXTURE_FILTER_BILINEAR, // Linear filtering
695
+ TEXTURE_FILTER_TRILINEAR, // Trilinear filtering (linear with mipmaps)
696
+ TEXTURE_FILTER_ANISOTROPIC_4X, // Anisotropic filtering 4x
697
+ TEXTURE_FILTER_ANISOTROPIC_8X, // Anisotropic filtering 8x
698
+ TEXTURE_FILTER_ANISOTROPIC_16X, // Anisotropic filtering 16x
699
+ } TextureFilter;
700
+ // Texture parameters: wrap mode
701
+ typedef enum {
702
+ TEXTURE_WRAP_REPEAT = 0, // Repeats texture in tiled mode
703
+ TEXTURE_WRAP_CLAMP, // Clamps texture to edge pixel in tiled mode
704
+ TEXTURE_WRAP_MIRROR_REPEAT, // Mirrors and repeats the texture in tiled mode
705
+ TEXTURE_WRAP_MIRROR_CLAMP // Mirrors and clamps to border the texture in tiled mode
706
+ } TextureWrap;
707
+ // Cubemap layouts
708
+ typedef enum {
709
+ CUBEMAP_LAYOUT_AUTO_DETECT = 0, // Automatically detect layout type
710
+ CUBEMAP_LAYOUT_LINE_VERTICAL, // Layout is defined by a vertical line with faces
711
+ CUBEMAP_LAYOUT_LINE_HORIZONTAL, // Layout is defined by a horizontal line with faces
712
+ CUBEMAP_LAYOUT_CROSS_THREE_BY_FOUR, // Layout is defined by a 3x4 cross with cubemap faces
713
+ CUBEMAP_LAYOUT_CROSS_FOUR_BY_THREE // Layout is defined by a 4x3 cross with cubemap faces
714
+ } CubemapLayout;
715
+ // Font type, defines generation method
716
+ typedef enum {
717
+ FONT_DEFAULT = 0, // Default font generation, anti-aliased
718
+ FONT_BITMAP, // Bitmap font generation, no anti-aliasing
719
+ FONT_SDF // SDF font generation, requires external shader
720
+ } FontType;
721
+ // Color blending modes (pre-defined)
722
+ typedef enum {
723
+ BLEND_ALPHA = 0, // Blend textures considering alpha (default)
724
+ BLEND_ADDITIVE, // Blend textures adding colors
725
+ BLEND_MULTIPLIED, // Blend textures multiplying colors
726
+ BLEND_ADD_COLORS, // Blend textures adding colors (alternative)
727
+ BLEND_SUBTRACT_COLORS, // Blend textures subtracting colors (alternative)
728
+ BLEND_ALPHA_PREMULTIPLY, // Blend premultiplied textures considering alpha
729
+ BLEND_CUSTOM, // Blend textures using custom src/dst factors (use rlSetBlendFactors())
730
+ BLEND_CUSTOM_SEPARATE // Blend textures using custom rgb/alpha separate src/dst factors (use rlSetBlendFactorsSeparate())
731
+ } BlendMode;
732
+ // Gesture
733
+ // NOTE: Provided as bit-wise flags to enable only desired gestures
734
+ typedef enum {
735
+ GESTURE_NONE = 0, // No gesture
736
+ GESTURE_TAP = 1, // Tap gesture
737
+ GESTURE_DOUBLETAP = 2, // Double tap gesture
738
+ GESTURE_HOLD = 4, // Hold gesture
739
+ GESTURE_DRAG = 8, // Drag gesture
740
+ GESTURE_SWIPE_RIGHT = 16, // Swipe right gesture
741
+ GESTURE_SWIPE_LEFT = 32, // Swipe left gesture
742
+ GESTURE_SWIPE_UP = 64, // Swipe up gesture
743
+ GESTURE_SWIPE_DOWN = 128, // Swipe down gesture
744
+ GESTURE_PINCH_IN = 256, // Pinch in gesture
745
+ GESTURE_PINCH_OUT = 512 // Pinch out gesture
746
+ } Gesture;
747
+ // Camera system modes
748
+ typedef enum {
749
+ CAMERA_CUSTOM = 0, // Camera custom, controlled by user (UpdateCamera() does nothing)
750
+ CAMERA_FREE, // Camera free mode
751
+ CAMERA_ORBITAL, // Camera orbital, around target, zoom supported
752
+ CAMERA_FIRST_PERSON, // Camera first person
753
+ CAMERA_THIRD_PERSON // Camera third person
754
+ } CameraMode;
755
+ // Camera projection
756
+ typedef enum {
757
+ CAMERA_PERSPECTIVE = 0, // Perspective projection
758
+ CAMERA_ORTHOGRAPHIC // Orthographic projection
759
+ } CameraProjection;
760
+ // N-patch layout
761
+ typedef enum {
762
+ NPATCH_NINE_PATCH = 0, // Npatch layout: 3x3 tiles
763
+ NPATCH_THREE_PATCH_VERTICAL, // Npatch layout: 1x3 tiles
764
+ NPATCH_THREE_PATCH_HORIZONTAL // Npatch layout: 3x1 tiles
765
+ } NPatchLayout;
766
+ // Callbacks to hook some internal functions
767
+ // WARNING: These callbacks are intended for advanced users
768
+ typedef void (*TraceLogCallback)(int logLevel, const char *text, void * args); // Logging: Redirect trace log messages
769
+ typedef unsigned char *(*LoadFileDataCallback)(const char *fileName, int *dataSize); // FileIO: Load binary data
770
+ typedef bool (*SaveFileDataCallback)(const char *fileName, void *data, int dataSize); // FileIO: Save binary data
771
+ typedef char *(*LoadFileTextCallback)(const char *fileName); // FileIO: Load text data
772
+ typedef bool (*SaveFileTextCallback)(const char *fileName, const char *text); // FileIO: Save text data
773
+ //------------------------------------------------------------------------------------
774
+ // Global Variables Definition
775
+ //------------------------------------------------------------------------------------
776
+ // It's lonely here...
777
+ //------------------------------------------------------------------------------------
778
+ // Window and Graphics Device Functions (Module: core)
779
+ //------------------------------------------------------------------------------------
780
+ // Window-related functions
781
+ void InitWindow(int width, int height, const char *title); // Initialize window and OpenGL context
782
+ void CloseWindow(void); // Close window and unload OpenGL context
783
+ bool WindowShouldClose(void); // Check if application should close (KEY_ESCAPE pressed or windows close icon clicked)
784
+ bool IsWindowReady(void); // Check if window has been initialized successfully
785
+ bool IsWindowFullscreen(void); // Check if window is currently fullscreen
786
+ bool IsWindowHidden(void); // Check if window is currently hidden
787
+ bool IsWindowMinimized(void); // Check if window is currently minimized
788
+ bool IsWindowMaximized(void); // Check if window is currently maximized
789
+ bool IsWindowFocused(void); // Check if window is currently focused
790
+ bool IsWindowResized(void); // Check if window has been resized last frame
791
+ bool IsWindowState(unsigned int flag); // Check if one specific window flag is enabled
792
+ void SetWindowState(unsigned int flags); // Set window configuration state using flags
793
+ void ClearWindowState(unsigned int flags); // Clear window configuration state flags
794
+ void ToggleFullscreen(void); // Toggle window state: fullscreen/windowed, resizes monitor to match window resolution
795
+ void ToggleBorderlessWindowed(void); // Toggle window state: borderless windowed, resizes window to match monitor resolution
796
+ void MaximizeWindow(void); // Set window state: maximized, if resizable
797
+ void MinimizeWindow(void); // Set window state: minimized, if resizable
798
+ void RestoreWindow(void); // Restore window from being minimized/maximized
799
+ void SetWindowIcon(Image image); // Set icon for window (single image, RGBA 32bit)
800
+ void SetWindowIcons(Image *images, int count); // Set icon for window (multiple images, RGBA 32bit)
801
+ void SetWindowTitle(const char *title); // Set title for window
802
+ void SetWindowPosition(int x, int y); // Set window position on screen
803
+ void SetWindowMonitor(int monitor); // Set monitor for the current window
804
+ void SetWindowMinSize(int width, int height); // Set window minimum dimensions (for FLAG_WINDOW_RESIZABLE)
805
+ void SetWindowMaxSize(int width, int height); // Set window maximum dimensions (for FLAG_WINDOW_RESIZABLE)
806
+ void SetWindowSize(int width, int height); // Set window dimensions
807
+ void SetWindowOpacity(float opacity); // Set window opacity [0.0f..1.0f]
808
+ void SetWindowFocused(void); // Set window focused
809
+ void *GetWindowHandle(void); // Get native window handle
810
+ int GetScreenWidth(void); // Get current screen width
811
+ int GetScreenHeight(void); // Get current screen height
812
+ int GetRenderWidth(void); // Get current render width (it considers HiDPI)
813
+ int GetRenderHeight(void); // Get current render height (it considers HiDPI)
814
+ int GetMonitorCount(void); // Get number of connected monitors
815
+ int GetCurrentMonitor(void); // Get current monitor where window is placed
816
+ Vector2 GetMonitorPosition(int monitor); // Get specified monitor position
817
+ int GetMonitorWidth(int monitor); // Get specified monitor width (current video mode used by monitor)
818
+ int GetMonitorHeight(int monitor); // Get specified monitor height (current video mode used by monitor)
819
+ int GetMonitorPhysicalWidth(int monitor); // Get specified monitor physical width in millimetres
820
+ int GetMonitorPhysicalHeight(int monitor); // Get specified monitor physical height in millimetres
821
+ int GetMonitorRefreshRate(int monitor); // Get specified monitor refresh rate
822
+ Vector2 GetWindowPosition(void); // Get window position XY on monitor
823
+ Vector2 GetWindowScaleDPI(void); // Get window scale DPI factor
824
+ const char *GetMonitorName(int monitor); // Get the human-readable, UTF-8 encoded name of the specified monitor
825
+ void SetClipboardText(const char *text); // Set clipboard text content
826
+ const char *GetClipboardText(void); // Get clipboard text content
827
+ Image GetClipboardImage(void); // Get clipboard image content
828
+ void EnableEventWaiting(void); // Enable waiting for events on EndDrawing(), no automatic event polling
829
+ void DisableEventWaiting(void); // Disable waiting for events on EndDrawing(), automatic events polling
830
+ // Cursor-related functions
831
+ void ShowCursor(void); // Shows cursor
832
+ void HideCursor(void); // Hides cursor
833
+ bool IsCursorHidden(void); // Check if cursor is not visible
834
+ void EnableCursor(void); // Enables cursor (unlock cursor)
835
+ void DisableCursor(void); // Disables cursor (lock cursor)
836
+ bool IsCursorOnScreen(void); // Check if cursor is on the screen
837
+ // Drawing-related functions
838
+ void ClearBackground(Color color); // Set background color (framebuffer clear color)
839
+ void BeginDrawing(void); // Setup canvas (framebuffer) to start drawing
840
+ void EndDrawing(void); // End canvas drawing and swap buffers (double buffering)
841
+ void BeginMode2D(Camera2D camera); // Begin 2D mode with custom camera (2D)
842
+ void EndMode2D(void); // Ends 2D mode with custom camera
843
+ void BeginMode3D(Camera3D camera); // Begin 3D mode with custom camera (3D)
844
+ void EndMode3D(void); // Ends 3D mode and returns to default 2D orthographic mode
845
+ void BeginTextureMode(RenderTexture2D target); // Begin drawing to render texture
846
+ void EndTextureMode(void); // Ends drawing to render texture
847
+ void BeginShaderMode(Shader shader); // Begin custom shader drawing
848
+ void EndShaderMode(void); // End custom shader drawing (use default shader)
849
+ void BeginBlendMode(int mode); // Begin blending mode (alpha, additive, multiplied, subtract, custom)
850
+ void EndBlendMode(void); // End blending mode (reset to default: alpha blending)
851
+ void BeginScissorMode(int x, int y, int width, int height); // Begin scissor mode (define screen area for following drawing)
852
+ void EndScissorMode(void); // End scissor mode
853
+ void BeginVrStereoMode(VrStereoConfig config); // Begin stereo rendering (requires VR simulator)
854
+ void EndVrStereoMode(void); // End stereo rendering (requires VR simulator)
855
+ // VR stereo config functions for VR simulator
856
+ VrStereoConfig LoadVrStereoConfig(VrDeviceInfo device); // Load VR stereo config for VR simulator device parameters
857
+ void UnloadVrStereoConfig(VrStereoConfig config); // Unload VR stereo config
858
+ // Shader management functions
859
+ // NOTE: Shader functionality is not available on OpenGL 1.1
860
+ Shader LoadShader(const char *vsFileName, const char *fsFileName); // Load shader from files and bind default locations
861
+ Shader LoadShaderFromMemory(const char *vsCode, const char *fsCode); // Load shader from code strings and bind default locations
862
+ bool IsShaderValid(Shader shader); // Check if a shader is valid (loaded on GPU)
863
+ int GetShaderLocation(Shader shader, const char *uniformName); // Get shader uniform location
864
+ int GetShaderLocationAttrib(Shader shader, const char *attribName); // Get shader attribute location
865
+ void SetShaderValue(Shader shader, int locIndex, const void *value, int uniformType); // Set shader uniform value
866
+ void SetShaderValueV(Shader shader, int locIndex, const void *value, int uniformType, int count); // Set shader uniform value vector
867
+ void SetShaderValueMatrix(Shader shader, int locIndex, Matrix mat); // Set shader uniform value (matrix 4x4)
868
+ void SetShaderValueTexture(Shader shader, int locIndex, Texture2D texture); // Set shader uniform value and bind the texture (sampler2d)
869
+ void UnloadShader(Shader shader); // Unload shader from GPU memory (VRAM)
870
+ // Screen-space-related functions
871
+ Ray GetScreenToWorldRay(Vector2 position, Camera camera); // Get a ray trace from screen position (i.e mouse)
872
+ Ray GetScreenToWorldRayEx(Vector2 position, Camera camera, int width, int height); // Get a ray trace from screen position (i.e mouse) in a viewport
873
+ Vector2 GetWorldToScreen(Vector3 position, Camera camera); // Get the screen space position for a 3d world space position
874
+ Vector2 GetWorldToScreenEx(Vector3 position, Camera camera, int width, int height); // Get size position for a 3d world space position
875
+ Vector2 GetWorldToScreen2D(Vector2 position, Camera2D camera); // Get the screen space position for a 2d camera world space position
876
+ Vector2 GetScreenToWorld2D(Vector2 position, Camera2D camera); // Get the world space position for a 2d camera screen space position
877
+ Matrix GetCameraMatrix(Camera camera); // Get camera transform matrix (view matrix)
878
+ Matrix GetCameraMatrix2D(Camera2D camera); // Get camera 2d transform matrix
879
+ // Timing-related functions
880
+ void SetTargetFPS(int fps); // Set target FPS (maximum)
881
+ float GetFrameTime(void); // Get time in seconds for last frame drawn (delta time)
882
+ double GetTime(void); // Get elapsed time in seconds since InitWindow()
883
+ int GetFPS(void); // Get current FPS
884
+ // Custom frame control functions
885
+ // NOTE: Those functions are intended for advanced users that want full control over the frame processing
886
+ // By default EndDrawing() does this job: draws everything + SwapScreenBuffer() + manage frame timing + PollInputEvents()
887
+ // To avoid that behaviour and control frame processes manually, enable in config.h: SUPPORT_CUSTOM_FRAME_CONTROL
888
+ void SwapScreenBuffer(void); // Swap back buffer with front buffer (screen drawing)
889
+ void PollInputEvents(void); // Register all input events
890
+ void WaitTime(double seconds); // Wait for some time (halt program execution)
891
+ // Random values generation functions
892
+ void SetRandomSeed(unsigned int seed); // Set the seed for the random number generator
893
+ int GetRandomValue(int min, int max); // Get a random value between min and max (both included)
894
+ int *LoadRandomSequence(unsigned int count, int min, int max); // Load random values sequence, no values repeated
895
+ void UnloadRandomSequence(int *sequence); // Unload random values sequence
896
+ // Misc. functions
897
+ void TakeScreenshot(const char *fileName); // Takes a screenshot of current screen (filename extension defines format)
898
+ void SetConfigFlags(unsigned int flags); // Setup init configuration flags (view FLAGS)
899
+ void OpenURL(const char *url); // Open URL with default system browser (if available)
900
+ // NOTE: Following functions implemented in module [utils]
901
+ //------------------------------------------------------------------
902
+ void TraceLog(int logLevel, const char *text, ...); // Show trace log messages (LOG_DEBUG, LOG_INFO, LOG_WARNING, LOG_ERROR...)
903
+ void SetTraceLogLevel(int logLevel); // Set the current threshold (minimum) log level
904
+ void *MemAlloc(unsigned int size); // Internal memory allocator
905
+ void *MemRealloc(void *ptr, unsigned int size); // Internal memory reallocator
906
+ void MemFree(void *ptr); // Internal memory free
907
+ // Set custom callbacks
908
+ // WARNING: Callbacks setup is intended for advanced users
909
+ void SetTraceLogCallback(TraceLogCallback callback); // Set custom trace log
910
+ void SetLoadFileDataCallback(LoadFileDataCallback callback); // Set custom file binary data loader
911
+ void SetSaveFileDataCallback(SaveFileDataCallback callback); // Set custom file binary data saver
912
+ void SetLoadFileTextCallback(LoadFileTextCallback callback); // Set custom file text data loader
913
+ void SetSaveFileTextCallback(SaveFileTextCallback callback); // Set custom file text data saver
914
+ // Files management functions
915
+ unsigned char *LoadFileData(const char *fileName, int *dataSize); // Load file data as byte array (read)
916
+ void UnloadFileData(unsigned char *data); // Unload file data allocated by LoadFileData()
917
+ bool SaveFileData(const char *fileName, void *data, int dataSize); // Save data to file from byte array (write), returns true on success
918
+ bool ExportDataAsCode(const unsigned char *data, int dataSize, const char *fileName); // Export data to code (.h), returns true on success
919
+ char *LoadFileText(const char *fileName); // Load text data from file (read), returns a '\0' terminated string
920
+ void UnloadFileText(char *text); // Unload file text data allocated by LoadFileText()
921
+ bool SaveFileText(const char *fileName, const char *text); // Save text data to file (write), string must be '\0' terminated, returns true on success
922
+ //------------------------------------------------------------------
923
+ // File system functions
924
+ int FileRename(const char *fileName, const char *fileRename); // Rename file (if exists)
925
+ int FileRemove(const char *fileName); // Remove file (if exists)
926
+ int FileCopy(const char *srcPath, const char *dstPath); // Copy file from one path to another, dstPath created if it doesn't exist
927
+ int FileMove(const char *srcPath, const char *dstPath); // Move file from one directory to another, dstPath created if it doesn't exist
928
+ int FileTextReplace(const char *fileName, const char *search, const char *replacement); // Replace text in an existing file
929
+ int FileTextFindIndex(const char *fileName, const char *search); // Find text in existing file
930
+ bool FileExists(const char *fileName); // Check if file exists
931
+ bool DirectoryExists(const char *dirPath); // Check if a directory path exists
932
+ bool IsFileExtension(const char *fileName, const char *ext); // Check file extension (recommended include point: .png, .wav)
933
+ int GetFileLength(const char *fileName); // Get file length in bytes (NOTE: GetFileSize() conflicts with windows.h)
934
+ long GetFileModTime(const char *fileName); // Get file modification time (last write time)
935
+ const char *GetFileExtension(const char *fileName); // Get pointer to extension for a filename string (includes dot: '.png')
936
+ const char *GetFileName(const char *filePath); // Get pointer to filename for a path string
937
+ const char *GetFileNameWithoutExt(const char *filePath); // Get filename string without extension (uses static string)
938
+ const char *GetDirectoryPath(const char *filePath); // Get full path for a given fileName with path (uses static string)
939
+ const char *GetPrevDirectoryPath(const char *dirPath); // Get previous directory path for a given path (uses static string)
940
+ const char *GetWorkingDirectory(void); // Get current working directory (uses static string)
941
+ const char *GetApplicationDirectory(void); // Get the directory of the running application (uses static string)
942
+ int MakeDirectory(const char *dirPath); // Create directories (including full path requested), returns 0 on success
943
+ bool ChangeDirectory(const char *dirPath); // Change working directory, return true on success
944
+ bool IsPathFile(const char *path); // Check if a given path is a file or a directory
945
+ bool IsFileNameValid(const char *fileName); // Check if fileName is valid for the platform/OS
946
+ FilePathList LoadDirectoryFiles(const char *dirPath); // Load directory filepaths
947
+ FilePathList LoadDirectoryFilesEx(const char *basePath, const char *filter, bool scanSubdirs); // Load directory filepaths with extension filtering and recursive directory scan. Use 'DIR' in the filter string to include directories in the result
948
+ void UnloadDirectoryFiles(FilePathList files); // Unload filepaths
949
+ bool IsFileDropped(void); // Check if a file has been dropped into window
950
+ FilePathList LoadDroppedFiles(void); // Load dropped filepaths
951
+ void UnloadDroppedFiles(FilePathList files); // Unload dropped filepaths
952
+ // Compression/Encoding functionality
953
+ unsigned char *CompressData(const unsigned char *data, int dataSize, int *compDataSize); // Compress data (DEFLATE algorithm), memory must be MemFree()
954
+ unsigned char *DecompressData(const unsigned char *compData, int compDataSize, int *dataSize); // Decompress data (DEFLATE algorithm), memory must be MemFree()
955
+ char *EncodeDataBase64(const unsigned char *data, int dataSize, int *outputSize); // Encode data to Base64 string (includes NULL terminator), memory must be MemFree()
956
+ unsigned char *DecodeDataBase64(const char *text, int *outputSize); // Decode Base64 string (expected NULL terminated), memory must be MemFree()
957
+ unsigned int ComputeCRC32(unsigned char *data, int dataSize); // Compute CRC32 hash code
958
+ unsigned int *ComputeMD5(unsigned char *data, int dataSize); // Compute MD5 hash code, returns static int[4] (16 bytes)
959
+ unsigned int *ComputeSHA1(unsigned char *data, int dataSize); // Compute SHA1 hash code, returns static int[5] (20 bytes)
960
+ unsigned int *ComputeSHA256(unsigned char *data, int dataSize); // Compute SHA256 hash code, returns static int[8] (32 bytes)
961
+ // Automation events functionality
962
+ AutomationEventList LoadAutomationEventList(const char *fileName); // Load automation events list from file, NULL for empty list, capacity = MAX_AUTOMATION_EVENTS
963
+ void UnloadAutomationEventList(AutomationEventList list); // Unload automation events list from file
964
+ bool ExportAutomationEventList(AutomationEventList list, const char *fileName); // Export automation events list as text file
965
+ void SetAutomationEventList(AutomationEventList *list); // Set automation event list to record to
966
+ void SetAutomationEventBaseFrame(int frame); // Set automation event internal base frame to start recording
967
+ void StartAutomationEventRecording(void); // Start recording automation events (AutomationEventList must be set)
968
+ void StopAutomationEventRecording(void); // Stop recording automation events
969
+ void PlayAutomationEvent(AutomationEvent event); // Play a recorded automation event
970
+ //------------------------------------------------------------------------------------
971
+ // Input Handling Functions (Module: core)
972
+ //------------------------------------------------------------------------------------
973
+ // Input-related functions: keyboard
974
+ bool IsKeyPressed(int key); // Check if a key has been pressed once
975
+ bool IsKeyPressedRepeat(int key); // Check if a key has been pressed again
976
+ bool IsKeyDown(int key); // Check if a key is being pressed
977
+ bool IsKeyReleased(int key); // Check if a key has been released once
978
+ bool IsKeyUp(int key); // Check if a key is NOT being pressed
979
+ int GetKeyPressed(void); // Get key pressed (keycode), call it multiple times for keys queued, returns 0 when the queue is empty
980
+ int GetCharPressed(void); // Get char pressed (unicode), call it multiple times for chars queued, returns 0 when the queue is empty
981
+ const char *GetKeyName(int key); // Get name of a QWERTY key on the current keyboard layout (eg returns string 'q' for KEY_A on an AZERTY keyboard)
982
+ void SetExitKey(int key); // Set a custom key to exit program (default is ESC)
983
+ // Input-related functions: gamepads
984
+ bool IsGamepadAvailable(int gamepad); // Check if a gamepad is available
985
+ const char *GetGamepadName(int gamepad); // Get gamepad internal name id
986
+ bool IsGamepadButtonPressed(int gamepad, int button); // Check if a gamepad button has been pressed once
987
+ bool IsGamepadButtonDown(int gamepad, int button); // Check if a gamepad button is being pressed
988
+ bool IsGamepadButtonReleased(int gamepad, int button); // Check if a gamepad button has been released once
989
+ bool IsGamepadButtonUp(int gamepad, int button); // Check if a gamepad button is NOT being pressed
990
+ int GetGamepadButtonPressed(void); // Get the last gamepad button pressed
991
+ int GetGamepadAxisCount(int gamepad); // Get axis count for a gamepad
992
+ float GetGamepadAxisMovement(int gamepad, int axis); // Get movement value for a gamepad axis
993
+ int SetGamepadMappings(const char *mappings); // Set internal gamepad mappings (SDL_GameControllerDB)
994
+ void SetGamepadVibration(int gamepad, float leftMotor, float rightMotor, float duration); // Set gamepad vibration for both motors (duration in seconds)
995
+ // Input-related functions: mouse
996
+ bool IsMouseButtonPressed(int button); // Check if a mouse button has been pressed once
997
+ bool IsMouseButtonDown(int button); // Check if a mouse button is being pressed
998
+ bool IsMouseButtonReleased(int button); // Check if a mouse button has been released once
999
+ bool IsMouseButtonUp(int button); // Check if a mouse button is NOT being pressed
1000
+ int GetMouseX(void); // Get mouse position X
1001
+ int GetMouseY(void); // Get mouse position Y
1002
+ Vector2 GetMousePosition(void); // Get mouse position XY
1003
+ Vector2 GetMouseDelta(void); // Get mouse delta between frames
1004
+ void SetMousePosition(int x, int y); // Set mouse position XY
1005
+ void SetMouseOffset(int offsetX, int offsetY); // Set mouse offset
1006
+ void SetMouseScale(float scaleX, float scaleY); // Set mouse scaling
1007
+ float GetMouseWheelMove(void); // Get mouse wheel movement for X or Y, whichever is larger
1008
+ Vector2 GetMouseWheelMoveV(void); // Get mouse wheel movement for both X and Y
1009
+ void SetMouseCursor(int cursor); // Set mouse cursor
1010
+ // Input-related functions: touch
1011
+ int GetTouchX(void); // Get touch position X for touch point 0 (relative to screen size)
1012
+ int GetTouchY(void); // Get touch position Y for touch point 0 (relative to screen size)
1013
+ Vector2 GetTouchPosition(int index); // Get touch position XY for a touch point index (relative to screen size)
1014
+ int GetTouchPointId(int index); // Get touch point identifier for given index
1015
+ int GetTouchPointCount(void); // Get number of touch points
1016
+ //------------------------------------------------------------------------------------
1017
+ // Gestures and Touch Handling Functions (Module: rgestures)
1018
+ //------------------------------------------------------------------------------------
1019
+ void SetGesturesEnabled(unsigned int flags); // Enable a set of gestures using flags
1020
+ bool IsGestureDetected(unsigned int gesture); // Check if a gesture have been detected
1021
+ int GetGestureDetected(void); // Get latest detected gesture
1022
+ float GetGestureHoldDuration(void); // Get gesture hold time in seconds
1023
+ Vector2 GetGestureDragVector(void); // Get gesture drag vector
1024
+ float GetGestureDragAngle(void); // Get gesture drag angle
1025
+ Vector2 GetGesturePinchVector(void); // Get gesture pinch delta
1026
+ float GetGesturePinchAngle(void); // Get gesture pinch angle
1027
+ //------------------------------------------------------------------------------------
1028
+ // Camera System Functions (Module: rcamera)
1029
+ //------------------------------------------------------------------------------------
1030
+ void UpdateCamera(Camera *camera, int mode); // Update camera position for selected mode
1031
+ void UpdateCameraPro(Camera *camera, Vector3 movement, Vector3 rotation, float zoom); // Update camera movement/rotation
1032
+ //------------------------------------------------------------------------------------
1033
+ // Basic Shapes Drawing Functions (Module: shapes)
1034
+ //------------------------------------------------------------------------------------
1035
+ // Set texture and rectangle to be used on shapes drawing
1036
+ // NOTE: It can be useful when using basic shapes and one single font,
1037
+ // defining a font char white rectangle would allow drawing everything in a single draw call
1038
+ void SetShapesTexture(Texture2D texture, Rectangle source); // Set texture and rectangle to be used on shapes drawing
1039
+ Texture2D GetShapesTexture(void); // Get texture that is used for shapes drawing
1040
+ Rectangle GetShapesTextureRectangle(void); // Get texture source rectangle that is used for shapes drawing
1041
+ // Basic shapes drawing functions
1042
+ void DrawPixel(int posX, int posY, Color color); // Draw a pixel using geometry [Can be slow, use with care]
1043
+ void DrawPixelV(Vector2 position, Color color); // Draw a pixel using geometry (Vector version) [Can be slow, use with care]
1044
+ void DrawLine(int startPosX, int startPosY, int endPosX, int endPosY, Color color); // Draw a line
1045
+ void DrawLineV(Vector2 startPos, Vector2 endPos, Color color); // Draw a line (using gl lines)
1046
+ void DrawLineEx(Vector2 startPos, Vector2 endPos, float thick, Color color); // Draw a line (using triangles/quads)
1047
+ void DrawLineStrip(const Vector2 *points, int pointCount, Color color); // Draw lines sequence (using gl lines)
1048
+ void DrawLineBezier(Vector2 startPos, Vector2 endPos, float thick, Color color); // Draw line segment cubic-bezier in-out interpolation
1049
+ void DrawLineDashed(Vector2 startPos, Vector2 endPos, int dashSize, int spaceSize, Color color); // Draw a dashed line
1050
+ void DrawCircle(int centerX, int centerY, float radius, Color color); // Draw a color-filled circle
1051
+ void DrawCircleSector(Vector2 center, float radius, float startAngle, float endAngle, int segments, Color color); // Draw a piece of a circle
1052
+ void DrawCircleSectorLines(Vector2 center, float radius, float startAngle, float endAngle, int segments, Color color); // Draw circle sector outline
1053
+ void DrawCircleGradient(int centerX, int centerY, float radius, Color inner, Color outer); // Draw a gradient-filled circle
1054
+ void DrawCircleV(Vector2 center, float radius, Color color); // Draw a color-filled circle (Vector version)
1055
+ void DrawCircleLines(int centerX, int centerY, float radius, Color color); // Draw circle outline
1056
+ void DrawCircleLinesV(Vector2 center, float radius, Color color); // Draw circle outline (Vector version)
1057
+ void DrawEllipse(int centerX, int centerY, float radiusH, float radiusV, Color color); // Draw ellipse
1058
+ void DrawEllipseV(Vector2 center, float radiusH, float radiusV, Color color); // Draw ellipse (Vector version)
1059
+ void DrawEllipseLines(int centerX, int centerY, float radiusH, float radiusV, Color color); // Draw ellipse outline
1060
+ void DrawEllipseLinesV(Vector2 center, float radiusH, float radiusV, Color color); // Draw ellipse outline (Vector version)
1061
+ void DrawRing(Vector2 center, float innerRadius, float outerRadius, float startAngle, float endAngle, int segments, Color color); // Draw ring
1062
+ void DrawRingLines(Vector2 center, float innerRadius, float outerRadius, float startAngle, float endAngle, int segments, Color color); // Draw ring outline
1063
+ void DrawRectangle(int posX, int posY, int width, int height, Color color); // Draw a color-filled rectangle
1064
+ void DrawRectangleV(Vector2 position, Vector2 size, Color color); // Draw a color-filled rectangle (Vector version)
1065
+ void DrawRectangleRec(Rectangle rec, Color color); // Draw a color-filled rectangle
1066
+ void DrawRectanglePro(Rectangle rec, Vector2 origin, float rotation, Color color); // Draw a color-filled rectangle with pro parameters
1067
+ void DrawRectangleGradientV(int posX, int posY, int width, int height, Color top, Color bottom); // Draw a vertical-gradient-filled rectangle
1068
+ void DrawRectangleGradientH(int posX, int posY, int width, int height, Color left, Color right); // Draw a horizontal-gradient-filled rectangle
1069
+ void DrawRectangleGradientEx(Rectangle rec, Color topLeft, Color bottomLeft, Color bottomRight, Color topRight); // Draw a gradient-filled rectangle with custom vertex colors
1070
+ void DrawRectangleLines(int posX, int posY, int width, int height, Color color); // Draw rectangle outline
1071
+ void DrawRectangleLinesEx(Rectangle rec, float lineThick, Color color); // Draw rectangle outline with extended parameters
1072
+ void DrawRectangleRounded(Rectangle rec, float roundness, int segments, Color color); // Draw rectangle with rounded edges
1073
+ void DrawRectangleRoundedLines(Rectangle rec, float roundness, int segments, Color color); // Draw rectangle lines with rounded edges
1074
+ void DrawRectangleRoundedLinesEx(Rectangle rec, float roundness, int segments, float lineThick, Color color); // Draw rectangle with rounded edges outline
1075
+ void DrawTriangle(Vector2 v1, Vector2 v2, Vector2 v3, Color color); // Draw a color-filled triangle (vertex in counter-clockwise order!)
1076
+ void DrawTriangleLines(Vector2 v1, Vector2 v2, Vector2 v3, Color color); // Draw triangle outline (vertex in counter-clockwise order!)
1077
+ void DrawTriangleFan(const Vector2 *points, int pointCount, Color color); // Draw a triangle fan defined by points (first vertex is the center)
1078
+ void DrawTriangleStrip(const Vector2 *points, int pointCount, Color color); // Draw a triangle strip defined by points
1079
+ void DrawPoly(Vector2 center, int sides, float radius, float rotation, Color color); // Draw a regular polygon (Vector version)
1080
+ void DrawPolyLines(Vector2 center, int sides, float radius, float rotation, Color color); // Draw a polygon outline of n sides
1081
+ void DrawPolyLinesEx(Vector2 center, int sides, float radius, float rotation, float lineThick, Color color); // Draw a polygon outline of n sides with extended parameters
1082
+ // Splines drawing functions
1083
+ void DrawSplineLinear(const Vector2 *points, int pointCount, float thick, Color color); // Draw spline: Linear, minimum 2 points
1084
+ void DrawSplineBasis(const Vector2 *points, int pointCount, float thick, Color color); // Draw spline: B-Spline, minimum 4 points
1085
+ void DrawSplineCatmullRom(const Vector2 *points, int pointCount, float thick, Color color); // Draw spline: Catmull-Rom, minimum 4 points
1086
+ void DrawSplineBezierQuadratic(const Vector2 *points, int pointCount, float thick, Color color); // Draw spline: Quadratic Bezier, minimum 3 points (1 control point): [p1, c2, p3, c4...]
1087
+ void DrawSplineBezierCubic(const Vector2 *points, int pointCount, float thick, Color color); // Draw spline: Cubic Bezier, minimum 4 points (2 control points): [p1, c2, c3, p4, c5, c6...]
1088
+ void DrawSplineSegmentLinear(Vector2 p1, Vector2 p2, float thick, Color color); // Draw spline segment: Linear, 2 points
1089
+ void DrawSplineSegmentBasis(Vector2 p1, Vector2 p2, Vector2 p3, Vector2 p4, float thick, Color color); // Draw spline segment: B-Spline, 4 points
1090
+ void DrawSplineSegmentCatmullRom(Vector2 p1, Vector2 p2, Vector2 p3, Vector2 p4, float thick, Color color); // Draw spline segment: Catmull-Rom, 4 points
1091
+ void DrawSplineSegmentBezierQuadratic(Vector2 p1, Vector2 c2, Vector2 p3, float thick, Color color); // Draw spline segment: Quadratic Bezier, 2 points, 1 control point
1092
+ void DrawSplineSegmentBezierCubic(Vector2 p1, Vector2 c2, Vector2 c3, Vector2 p4, float thick, Color color); // Draw spline segment: Cubic Bezier, 2 points, 2 control points
1093
+ // Spline segment point evaluation functions, for a given t [0.0f .. 1.0f]
1094
+ Vector2 GetSplinePointLinear(Vector2 startPos, Vector2 endPos, float t); // Get (evaluate) spline point: Linear
1095
+ Vector2 GetSplinePointBasis(Vector2 p1, Vector2 p2, Vector2 p3, Vector2 p4, float t); // Get (evaluate) spline point: B-Spline
1096
+ Vector2 GetSplinePointCatmullRom(Vector2 p1, Vector2 p2, Vector2 p3, Vector2 p4, float t); // Get (evaluate) spline point: Catmull-Rom
1097
+ Vector2 GetSplinePointBezierQuad(Vector2 p1, Vector2 c2, Vector2 p3, float t); // Get (evaluate) spline point: Quadratic Bezier
1098
+ Vector2 GetSplinePointBezierCubic(Vector2 p1, Vector2 c2, Vector2 c3, Vector2 p4, float t); // Get (evaluate) spline point: Cubic Bezier
1099
+ // Basic shapes collision detection functions
1100
+ bool CheckCollisionRecs(Rectangle rec1, Rectangle rec2); // Check collision between two rectangles
1101
+ bool CheckCollisionCircles(Vector2 center1, float radius1, Vector2 center2, float radius2); // Check collision between two circles
1102
+ bool CheckCollisionCircleRec(Vector2 center, float radius, Rectangle rec); // Check collision between circle and rectangle
1103
+ bool CheckCollisionCircleLine(Vector2 center, float radius, Vector2 p1, Vector2 p2); // Check if circle collides with a line created betweeen two points [p1] and [p2]
1104
+ bool CheckCollisionPointRec(Vector2 point, Rectangle rec); // Check if point is inside rectangle
1105
+ bool CheckCollisionPointCircle(Vector2 point, Vector2 center, float radius); // Check if point is inside circle
1106
+ bool CheckCollisionPointTriangle(Vector2 point, Vector2 p1, Vector2 p2, Vector2 p3); // Check if point is inside a triangle
1107
+ bool CheckCollisionPointLine(Vector2 point, Vector2 p1, Vector2 p2, int threshold); // Check if point belongs to line created between two points [p1] and [p2] with defined margin in pixels [threshold]
1108
+ bool CheckCollisionPointPoly(Vector2 point, const Vector2 *points, int pointCount); // Check if point is within a polygon described by array of vertices
1109
+ bool CheckCollisionLines(Vector2 startPos1, Vector2 endPos1, Vector2 startPos2, Vector2 endPos2, Vector2 *collisionPoint); // Check the collision between two lines defined by two points each, returns collision point by reference
1110
+ Rectangle GetCollisionRec(Rectangle rec1, Rectangle rec2); // Get collision rectangle for two rectangles collision
1111
+ //------------------------------------------------------------------------------------
1112
+ // Texture Loading and Drawing Functions (Module: textures)
1113
+ //------------------------------------------------------------------------------------
1114
+ // Image loading functions
1115
+ // NOTE: These functions do not require GPU access
1116
+ Image LoadImage(const char *fileName); // Load image from file into CPU memory (RAM)
1117
+ Image LoadImageRaw(const char *fileName, int width, int height, int format, int headerSize); // Load image from RAW file data
1118
+ Image LoadImageAnim(const char *fileName, int *frames); // Load image sequence from file (frames appended to image.data)
1119
+ Image LoadImageAnimFromMemory(const char *fileType, const unsigned char *fileData, int dataSize, int *frames); // Load image sequence from memory buffer
1120
+ Image LoadImageFromMemory(const char *fileType, const unsigned char *fileData, int dataSize); // Load image from memory buffer, fileType refers to extension: i.e. '.png'
1121
+ Image LoadImageFromTexture(Texture2D texture); // Load image from GPU texture data
1122
+ Image LoadImageFromScreen(void); // Load image from screen buffer and (screenshot)
1123
+ bool IsImageValid(Image image); // Check if an image is valid (data and parameters)
1124
+ void UnloadImage(Image image); // Unload image from CPU memory (RAM)
1125
+ bool ExportImage(Image image, const char *fileName); // Export image data to file, returns true on success
1126
+ unsigned char *ExportImageToMemory(Image image, const char *fileType, int *fileSize); // Export image to memory buffer
1127
+ bool ExportImageAsCode(Image image, const char *fileName); // Export image as code file defining an array of bytes, returns true on success
1128
+ // Image generation functions
1129
+ Image GenImageColor(int width, int height, Color color); // Generate image: plain color
1130
+ Image GenImageGradientLinear(int width, int height, int direction, Color start, Color end); // Generate image: linear gradient, direction in degrees [0..360], 0=Vertical gradient
1131
+ Image GenImageGradientRadial(int width, int height, float density, Color inner, Color outer); // Generate image: radial gradient
1132
+ Image GenImageGradientSquare(int width, int height, float density, Color inner, Color outer); // Generate image: square gradient
1133
+ Image GenImageChecked(int width, int height, int checksX, int checksY, Color col1, Color col2); // Generate image: checked
1134
+ Image GenImageWhiteNoise(int width, int height, float factor); // Generate image: white noise
1135
+ Image GenImagePerlinNoise(int width, int height, int offsetX, int offsetY, float scale); // Generate image: perlin noise
1136
+ Image GenImageCellular(int width, int height, int tileSize); // Generate image: cellular algorithm, bigger tileSize means bigger cells
1137
+ Image GenImageText(int width, int height, const char *text); // Generate image: grayscale image from text data
1138
+ // Image manipulation functions
1139
+ Image ImageCopy(Image image); // Create an image duplicate (useful for transformations)
1140
+ Image ImageFromImage(Image image, Rectangle rec); // Create an image from another image piece
1141
+ Image ImageFromChannel(Image image, int selectedChannel); // Create an image from a selected channel of another image (GRAYSCALE)
1142
+ Image ImageText(const char *text, int fontSize, Color color); // Create an image from text (default font)
1143
+ Image ImageTextEx(Font font, const char *text, float fontSize, float spacing, Color tint); // Create an image from text (custom sprite font)
1144
+ void ImageFormat(Image *image, int newFormat); // Convert image data to desired format
1145
+ void ImageToPOT(Image *image, Color fill); // Convert image to POT (power-of-two)
1146
+ void ImageCrop(Image *image, Rectangle crop); // Crop an image to a defined rectangle
1147
+ void ImageAlphaCrop(Image *image, float threshold); // Crop image depending on alpha value
1148
+ void ImageAlphaClear(Image *image, Color color, float threshold); // Clear alpha channel to desired color
1149
+ void ImageAlphaMask(Image *image, Image alphaMask); // Apply alpha mask to image
1150
+ void ImageAlphaPremultiply(Image *image); // Premultiply alpha channel
1151
+ void ImageBlurGaussian(Image *image, int blurSize); // Apply Gaussian blur using a box blur approximation
1152
+ void ImageKernelConvolution(Image *image, const float *kernel, int kernelSize); // Apply custom square convolution kernel to image
1153
+ void ImageResize(Image *image, int newWidth, int newHeight); // Resize image (Bicubic scaling algorithm)
1154
+ void ImageResizeNN(Image *image, int newWidth, int newHeight); // Resize image (Nearest-Neighbor scaling algorithm)
1155
+ void ImageResizeCanvas(Image *image, int newWidth, int newHeight, int offsetX, int offsetY, Color fill); // Resize canvas and fill with color
1156
+ void ImageMipmaps(Image *image); // Compute all mipmap levels for a provided image
1157
+ void ImageDither(Image *image, int rBpp, int gBpp, int bBpp, int aBpp); // Dither image data to 16bpp or lower (Floyd-Steinberg dithering)
1158
+ void ImageFlipVertical(Image *image); // Flip image vertically
1159
+ void ImageFlipHorizontal(Image *image); // Flip image horizontally
1160
+ void ImageRotate(Image *image, int degrees); // Rotate image by input angle in degrees (-359 to 359)
1161
+ void ImageRotateCW(Image *image); // Rotate image clockwise 90deg
1162
+ void ImageRotateCCW(Image *image); // Rotate image counter-clockwise 90deg
1163
+ void ImageColorTint(Image *image, Color color); // Modify image color: tint
1164
+ void ImageColorInvert(Image *image); // Modify image color: invert
1165
+ void ImageColorGrayscale(Image *image); // Modify image color: grayscale
1166
+ void ImageColorContrast(Image *image, float contrast); // Modify image color: contrast (-100 to 100)
1167
+ void ImageColorBrightness(Image *image, int brightness); // Modify image color: brightness (-255 to 255)
1168
+ void ImageColorReplace(Image *image, Color color, Color replace); // Modify image color: replace color
1169
+ Color *LoadImageColors(Image image); // Load color data from image as a Color array (RGBA - 32bit)
1170
+ Color *LoadImagePalette(Image image, int maxPaletteSize, int *colorCount); // Load colors palette from image as a Color array (RGBA - 32bit)
1171
+ void UnloadImageColors(Color *colors); // Unload color data loaded with LoadImageColors()
1172
+ void UnloadImagePalette(Color *colors); // Unload colors palette loaded with LoadImagePalette()
1173
+ Rectangle GetImageAlphaBorder(Image image, float threshold); // Get image alpha border rectangle
1174
+ Color GetImageColor(Image image, int x, int y); // Get image pixel color at (x, y) position
1175
+ // Image drawing functions
1176
+ // NOTE: Image software-rendering functions (CPU)
1177
+ void ImageClearBackground(Image *dst, Color color); // Clear image background with given color
1178
+ void ImageDrawPixel(Image *dst, int posX, int posY, Color color); // Draw pixel within an image
1179
+ void ImageDrawPixelV(Image *dst, Vector2 position, Color color); // Draw pixel within an image (Vector version)
1180
+ void ImageDrawLine(Image *dst, int startPosX, int startPosY, int endPosX, int endPosY, Color color); // Draw line within an image
1181
+ void ImageDrawLineV(Image *dst, Vector2 start, Vector2 end, Color color); // Draw line within an image (Vector version)
1182
+ void ImageDrawLineEx(Image *dst, Vector2 start, Vector2 end, int thick, Color color); // Draw a line defining thickness within an image
1183
+ void ImageDrawCircle(Image *dst, int centerX, int centerY, int radius, Color color); // Draw a filled circle within an image
1184
+ void ImageDrawCircleV(Image *dst, Vector2 center, int radius, Color color); // Draw a filled circle within an image (Vector version)
1185
+ void ImageDrawCircleLines(Image *dst, int centerX, int centerY, int radius, Color color); // Draw circle outline within an image
1186
+ void ImageDrawCircleLinesV(Image *dst, Vector2 center, int radius, Color color); // Draw circle outline within an image (Vector version)
1187
+ void ImageDrawRectangle(Image *dst, int posX, int posY, int width, int height, Color color); // Draw rectangle within an image
1188
+ void ImageDrawRectangleV(Image *dst, Vector2 position, Vector2 size, Color color); // Draw rectangle within an image (Vector version)
1189
+ void ImageDrawRectangleRec(Image *dst, Rectangle rec, Color color); // Draw rectangle within an image
1190
+ void ImageDrawRectangleLines(Image *dst, Rectangle rec, int thick, Color color); // Draw rectangle lines within an image
1191
+ void ImageDrawTriangle(Image *dst, Vector2 v1, Vector2 v2, Vector2 v3, Color color); // Draw triangle within an image
1192
+ void ImageDrawTriangleEx(Image *dst, Vector2 v1, Vector2 v2, Vector2 v3, Color c1, Color c2, Color c3); // Draw triangle with interpolated colors within an image
1193
+ void ImageDrawTriangleLines(Image *dst, Vector2 v1, Vector2 v2, Vector2 v3, Color color); // Draw triangle outline within an image
1194
+ void ImageDrawTriangleFan(Image *dst, const Vector2 *points, int pointCount, Color color); // Draw a triangle fan defined by points within an image (first vertex is the center)
1195
+ void ImageDrawTriangleStrip(Image *dst, const Vector2 *points, int pointCount, Color color); // Draw a triangle strip defined by points within an image
1196
+ void ImageDraw(Image *dst, Image src, Rectangle srcRec, Rectangle dstRec, Color tint); // Draw a source image within a destination image (tint applied to source)
1197
+ void ImageDrawText(Image *dst, const char *text, int posX, int posY, int fontSize, Color color); // Draw text (using default font) within an image (destination)
1198
+ void ImageDrawTextEx(Image *dst, Font font, const char *text, Vector2 position, float fontSize, float spacing, Color tint); // Draw text (custom sprite font) within an image (destination)
1199
+ // Texture loading functions
1200
+ // NOTE: These functions require GPU access
1201
+ Texture2D LoadTexture(const char *fileName); // Load texture from file into GPU memory (VRAM)
1202
+ Texture2D LoadTextureFromImage(Image image); // Load texture from image data
1203
+ TextureCubemap LoadTextureCubemap(Image image, int layout); // Load cubemap from image, multiple image cubemap layouts supported
1204
+ RenderTexture2D LoadRenderTexture(int width, int height); // Load texture for rendering (framebuffer)
1205
+ bool IsTextureValid(Texture2D texture); // Check if a texture is valid (loaded in GPU)
1206
+ void UnloadTexture(Texture2D texture); // Unload texture from GPU memory (VRAM)
1207
+ bool IsRenderTextureValid(RenderTexture2D target); // Check if a render texture is valid (loaded in GPU)
1208
+ void UnloadRenderTexture(RenderTexture2D target); // Unload render texture from GPU memory (VRAM)
1209
+ void UpdateTexture(Texture2D texture, const void *pixels); // Update GPU texture with new data (pixels should be able to fill texture)
1210
+ void UpdateTextureRec(Texture2D texture, Rectangle rec, const void *pixels); // Update GPU texture rectangle with new data (pixels and rec should fit in texture)
1211
+ // Texture configuration functions
1212
+ void GenTextureMipmaps(Texture2D *texture); // Generate GPU mipmaps for a texture
1213
+ void SetTextureFilter(Texture2D texture, int filter); // Set texture scaling filter mode
1214
+ void SetTextureWrap(Texture2D texture, int wrap); // Set texture wrapping mode
1215
+ // Texture drawing functions
1216
+ void DrawTexture(Texture2D texture, int posX, int posY, Color tint); // Draw a Texture2D
1217
+ void DrawTextureV(Texture2D texture, Vector2 position, Color tint); // Draw a Texture2D with position defined as Vector2
1218
+ void DrawTextureEx(Texture2D texture, Vector2 position, float rotation, float scale, Color tint); // Draw a Texture2D with extended parameters
1219
+ void DrawTextureRec(Texture2D texture, Rectangle source, Vector2 position, Color tint); // Draw a part of a texture defined by a rectangle
1220
+ void DrawTexturePro(Texture2D texture, Rectangle source, Rectangle dest, Vector2 origin, float rotation, Color tint); // Draw a part of a texture defined by a rectangle with 'pro' parameters
1221
+ void DrawTextureNPatch(Texture2D texture, NPatchInfo nPatchInfo, Rectangle dest, Vector2 origin, float rotation, Color tint); // Draws a texture (or part of it) that stretches or shrinks nicely
1222
+ // Color/pixel related functions
1223
+ bool ColorIsEqual(Color col1, Color col2); // Check if two colors are equal
1224
+ Color Fade(Color color, float alpha); // Get color with alpha applied, alpha goes from 0.0f to 1.0f
1225
+ unsigned int ColorToInt(Color color); // Get hexadecimal value for a Color (0xRRGGBBAA)
1226
+ Vector4 ColorNormalize(Color color); // Get Color normalized as float [0..1]
1227
+ Color ColorFromNormalized(Vector4 normalized); // Get Color from normalized values [0..1]
1228
+ Vector3 ColorToHSV(Color color); // Get HSV values for a Color, hue [0..360], saturation/value [0..1]
1229
+ Color ColorFromHSV(float hue, float saturation, float value); // Get a Color from HSV values, hue [0..360], saturation/value [0..1]
1230
+ Color ColorTint(Color color, Color tint); // Get color multiplied with another color
1231
+ Color ColorBrightness(Color color, float factor); // Get color with brightness correction, brightness factor goes from -1.0f to 1.0f
1232
+ Color ColorContrast(Color color, float contrast); // Get color with contrast correction, contrast values between -1.0f and 1.0f
1233
+ Color ColorAlpha(Color color, float alpha); // Get color with alpha applied, alpha goes from 0.0f to 1.0f
1234
+ Color ColorAlphaBlend(Color dst, Color src, Color tint); // Get src alpha-blended into dst color with tint
1235
+ Color ColorLerp(Color color1, Color color2, float factor); // Get color lerp interpolation between two colors, factor [0.0f..1.0f]
1236
+ Color GetColor(unsigned int hexValue); // Get Color structure from hexadecimal value
1237
+ Color GetPixelColor(void *srcPtr, int format); // Get Color from a source pixel pointer of certain format
1238
+ void SetPixelColor(void *dstPtr, Color color, int format); // Set color formatted into destination pixel pointer
1239
+ int GetPixelDataSize(int width, int height, int format); // Get pixel data size in bytes for certain format
1240
+ //------------------------------------------------------------------------------------
1241
+ // Font Loading and Text Drawing Functions (Module: text)
1242
+ //------------------------------------------------------------------------------------
1243
+ // Font loading/unloading functions
1244
+ Font GetFontDefault(void); // Get the default Font
1245
+ Font LoadFont(const char *fileName); // Load font from file into GPU memory (VRAM)
1246
+ Font LoadFontEx(const char *fileName, int fontSize, const int *codepoints, int codepointCount); // Load font from file with extended parameters, use NULL for codepoints and 0 for codepointCount to load the default character set, font size is provided in pixels height
1247
+ Font LoadFontFromImage(Image image, Color key, int firstChar); // Load font from Image (XNA style)
1248
+ Font LoadFontFromMemory(const char *fileType, const unsigned char *fileData, int dataSize, int fontSize, const int *codepoints, int codepointCount); // Load font from memory buffer, fileType refers to extension: i.e. '.ttf'
1249
+ bool IsFontValid(Font font); // Check if a font is valid (font data loaded, WARNING: GPU texture not checked)
1250
+ GlyphInfo *LoadFontData(const unsigned char *fileData, int dataSize, int fontSize, const int *codepoints, int codepointCount, int type, int *glyphCount); // Load font data for further use
1251
+ Image GenImageFontAtlas(const GlyphInfo *glyphs, Rectangle **glyphRecs, int glyphCount, int fontSize, int padding, int packMethod); // Generate image font atlas using chars info
1252
+ void UnloadFontData(GlyphInfo *glyphs, int glyphCount); // Unload font chars info data (RAM)
1253
+ void UnloadFont(Font font); // Unload font from GPU memory (VRAM)
1254
+ bool ExportFontAsCode(Font font, const char *fileName); // Export font as code file, returns true on success
1255
+ // Text drawing functions
1256
+ void DrawFPS(int posX, int posY); // Draw current FPS
1257
+ void DrawText(const char *text, int posX, int posY, int fontSize, Color color); // Draw text (using default font)
1258
+ void DrawTextEx(Font font, const char *text, Vector2 position, float fontSize, float spacing, Color tint); // Draw text using font and additional parameters
1259
+ void DrawTextPro(Font font, const char *text, Vector2 position, Vector2 origin, float rotation, float fontSize, float spacing, Color tint); // Draw text using Font and pro parameters (rotation)
1260
+ void DrawTextCodepoint(Font font, int codepoint, Vector2 position, float fontSize, Color tint); // Draw one character (codepoint)
1261
+ void DrawTextCodepoints(Font font, const int *codepoints, int codepointCount, Vector2 position, float fontSize, float spacing, Color tint); // Draw multiple character (codepoint)
1262
+ // Text font info functions
1263
+ void SetTextLineSpacing(int spacing); // Set vertical line spacing when drawing with line-breaks
1264
+ int MeasureText(const char *text, int fontSize); // Measure string width for default font
1265
+ Vector2 MeasureTextEx(Font font, const char *text, float fontSize, float spacing); // Measure string size for Font
1266
+ int GetGlyphIndex(Font font, int codepoint); // Get glyph index position in font for a codepoint (unicode character), fallback to '?' if not found
1267
+ GlyphInfo GetGlyphInfo(Font font, int codepoint); // Get glyph font info data for a codepoint (unicode character), fallback to '?' if not found
1268
+ Rectangle GetGlyphAtlasRec(Font font, int codepoint); // Get glyph rectangle in font atlas for a codepoint (unicode character), fallback to '?' if not found
1269
+ // Text codepoints management functions (unicode characters)
1270
+ char *LoadUTF8(const int *codepoints, int length); // Load UTF-8 text encoded from codepoints array
1271
+ void UnloadUTF8(char *text); // Unload UTF-8 text encoded from codepoints array
1272
+ int *LoadCodepoints(const char *text, int *count); // Load all codepoints from a UTF-8 text string, codepoints count returned by parameter
1273
+ void UnloadCodepoints(int *codepoints); // Unload codepoints data from memory
1274
+ int GetCodepointCount(const char *text); // Get total number of codepoints in a UTF-8 encoded string
1275
+ int GetCodepoint(const char *text, int *codepointSize); // Get next codepoint in a UTF-8 encoded string, 0x3f('?') is returned on failure
1276
+ int GetCodepointNext(const char *text, int *codepointSize); // Get next codepoint in a UTF-8 encoded string, 0x3f('?') is returned on failure
1277
+ int GetCodepointPrevious(const char *text, int *codepointSize); // Get previous codepoint in a UTF-8 encoded string, 0x3f('?') is returned on failure
1278
+ const char *CodepointToUTF8(int codepoint, int *utf8Size); // Encode one codepoint into UTF-8 byte array (array length returned as parameter)
1279
+ // Text strings management functions (no UTF-8 strings, only byte chars)
1280
+ // WARNING 1: Most of these functions use internal static buffers[], it's recommended to store returned data on user-side for re-use
1281
+ // WARNING 2: Some strings allocate memory internally for the returned strings, those strings must be free by user using MemFree()
1282
+ char **LoadTextLines(const char *text, int *count); // Load text as separate lines ('\n')
1283
+ void UnloadTextLines(char **text, int lineCount); // Unload text lines
1284
+ int TextCopy(char *dst, const char *src); // Copy one string to another, returns bytes copied
1285
+ bool TextIsEqual(const char *text1, const char *text2); // Check if two text string are equal
1286
+ unsigned int TextLength(const char *text); // Get text length, checks for '\0' ending
1287
+ const char *TextFormat(const char *text, ...); // Text formatting with variables (sprintf() style)
1288
+ const char *TextSubtext(const char *text, int position, int length); // Get a piece of a text string
1289
+ const char *TextRemoveSpaces(const char *text); // Remove text spaces, concat words
1290
+ char *GetTextBetween(const char *text, const char *begin, const char *end); // Get text between two strings
1291
+ char *TextReplace(const char *text, const char *search, const char *replacement); // Replace text string (WARNING: memory must be freed!)
1292
+ char *TextReplaceBetween(const char *text, const char *begin, const char *end, const char *replacement); // Replace text between two specific strings (WARNING: memory must be freed!)
1293
+ char *TextInsert(const char *text, const char *insert, int position); // Insert text in a position (WARNING: memory must be freed!)
1294
+ char *TextJoin(char **textList, int count, const char *delimiter); // Join text strings with delimiter
1295
+ char **TextSplit(const char *text, char delimiter, int *count); // Split text into multiple strings, using MAX_TEXTSPLIT_COUNT static strings
1296
+ void TextAppend(char *text, const char *append, int *position); // Append text at specific position and move cursor
1297
+ int TextFindIndex(const char *text, const char *search); // Find first text occurrence within a string, -1 if not found
1298
+ char *TextToUpper(const char *text); // Get upper case version of provided string
1299
+ char *TextToLower(const char *text); // Get lower case version of provided string
1300
+ char *TextToPascal(const char *text); // Get Pascal case notation version of provided string
1301
+ char *TextToSnake(const char *text); // Get Snake case notation version of provided string
1302
+ char *TextToCamel(const char *text); // Get Camel case notation version of provided string
1303
+ int TextToInteger(const char *text); // Get integer value from text
1304
+ float TextToFloat(const char *text); // Get float value from text
1305
+ //------------------------------------------------------------------------------------
1306
+ // Basic 3d Shapes Drawing Functions (Module: models)
1307
+ //------------------------------------------------------------------------------------
1308
+ // Basic geometric 3D shapes drawing functions
1309
+ void DrawLine3D(Vector3 startPos, Vector3 endPos, Color color); // Draw a line in 3D world space
1310
+ void DrawPoint3D(Vector3 position, Color color); // Draw a point in 3D space, actually a small line
1311
+ void DrawCircle3D(Vector3 center, float radius, Vector3 rotationAxis, float rotationAngle, Color color); // Draw a circle in 3D world space
1312
+ void DrawTriangle3D(Vector3 v1, Vector3 v2, Vector3 v3, Color color); // Draw a color-filled triangle (vertex in counter-clockwise order!)
1313
+ void DrawTriangleStrip3D(const Vector3 *points, int pointCount, Color color); // Draw a triangle strip defined by points
1314
+ void DrawCube(Vector3 position, float width, float height, float length, Color color); // Draw cube
1315
+ void DrawCubeV(Vector3 position, Vector3 size, Color color); // Draw cube (Vector version)
1316
+ void DrawCubeWires(Vector3 position, float width, float height, float length, Color color); // Draw cube wires
1317
+ void DrawCubeWiresV(Vector3 position, Vector3 size, Color color); // Draw cube wires (Vector version)
1318
+ void DrawSphere(Vector3 centerPos, float radius, Color color); // Draw sphere
1319
+ void DrawSphereEx(Vector3 centerPos, float radius, int rings, int slices, Color color); // Draw sphere with extended parameters
1320
+ void DrawSphereWires(Vector3 centerPos, float radius, int rings, int slices, Color color); // Draw sphere wires
1321
+ void DrawCylinder(Vector3 position, float radiusTop, float radiusBottom, float height, int slices, Color color); // Draw a cylinder/cone
1322
+ void DrawCylinderEx(Vector3 startPos, Vector3 endPos, float startRadius, float endRadius, int sides, Color color); // Draw a cylinder with base at startPos and top at endPos
1323
+ void DrawCylinderWires(Vector3 position, float radiusTop, float radiusBottom, float height, int slices, Color color); // Draw a cylinder/cone wires
1324
+ void DrawCylinderWiresEx(Vector3 startPos, Vector3 endPos, float startRadius, float endRadius, int sides, Color color); // Draw a cylinder wires with base at startPos and top at endPos
1325
+ void DrawCapsule(Vector3 startPos, Vector3 endPos, float radius, int slices, int rings, Color color); // Draw a capsule with the center of its sphere caps at startPos and endPos
1326
+ void DrawCapsuleWires(Vector3 startPos, Vector3 endPos, float radius, int slices, int rings, Color color); // Draw capsule wireframe with the center of its sphere caps at startPos and endPos
1327
+ void DrawPlane(Vector3 centerPos, Vector2 size, Color color); // Draw a plane XZ
1328
+ void DrawRay(Ray ray, Color color); // Draw a ray line
1329
+ void DrawGrid(int slices, float spacing); // Draw a grid (centered at (0, 0, 0))
1330
+ //------------------------------------------------------------------------------------
1331
+ // Model 3d Loading and Drawing Functions (Module: models)
1332
+ //------------------------------------------------------------------------------------
1333
+ // Model management functions
1334
+ Model LoadModel(const char *fileName); // Load model from files (meshes and materials)
1335
+ Model LoadModelFromMesh(Mesh mesh); // Load model from generated mesh (default material)
1336
+ bool IsModelValid(Model model); // Check if a model is valid (loaded in GPU, VAO/VBOs)
1337
+ void UnloadModel(Model model); // Unload model (including meshes) from memory (RAM and/or VRAM)
1338
+ BoundingBox GetModelBoundingBox(Model model); // Compute model bounding box limits (considers all meshes)
1339
+ // Model drawing functions
1340
+ void DrawModel(Model model, Vector3 position, float scale, Color tint); // Draw a model (with texture if set)
1341
+ void DrawModelEx(Model model, Vector3 position, Vector3 rotationAxis, float rotationAngle, Vector3 scale, Color tint); // Draw a model with extended parameters
1342
+ void DrawModelWires(Model model, Vector3 position, float scale, Color tint); // Draw a model wires (with texture if set)
1343
+ void DrawModelWiresEx(Model model, Vector3 position, Vector3 rotationAxis, float rotationAngle, Vector3 scale, Color tint); // Draw a model wires (with texture if set) with extended parameters
1344
+ void DrawModelPoints(Model model, Vector3 position, float scale, Color tint); // Draw a model as points
1345
+ void DrawModelPointsEx(Model model, Vector3 position, Vector3 rotationAxis, float rotationAngle, Vector3 scale, Color tint); // Draw a model as points with extended parameters
1346
+ void DrawBoundingBox(BoundingBox box, Color color); // Draw bounding box (wires)
1347
+ void DrawBillboard(Camera camera, Texture2D texture, Vector3 position, float scale, Color tint); // Draw a billboard texture
1348
+ void DrawBillboardRec(Camera camera, Texture2D texture, Rectangle source, Vector3 position, Vector2 size, Color tint); // Draw a billboard texture defined by source
1349
+ void DrawBillboardPro(Camera camera, Texture2D texture, Rectangle source, Vector3 position, Vector3 up, Vector2 size, Vector2 origin, float rotation, Color tint); // Draw a billboard texture defined by source and rotation
1350
+ // Mesh management functions
1351
+ void UploadMesh(Mesh *mesh, bool dynamic); // Upload mesh vertex data in GPU and provide VAO/VBO ids
1352
+ void UpdateMeshBuffer(Mesh mesh, int index, const void *data, int dataSize, int offset); // Update mesh vertex data in GPU for a specific buffer index
1353
+ void UnloadMesh(Mesh mesh); // Unload mesh data from CPU and GPU
1354
+ void DrawMesh(Mesh mesh, Material material, Matrix transform); // Draw a 3d mesh with material and transform
1355
+ void DrawMeshInstanced(Mesh mesh, Material material, const Matrix *transforms, int instances); // Draw multiple mesh instances with material and different transforms
1356
+ BoundingBox GetMeshBoundingBox(Mesh mesh); // Compute mesh bounding box limits
1357
+ void GenMeshTangents(Mesh *mesh); // Compute mesh tangents
1358
+ bool ExportMesh(Mesh mesh, const char *fileName); // Export mesh data to file, returns true on success
1359
+ bool ExportMeshAsCode(Mesh mesh, const char *fileName); // Export mesh as code file (.h) defining multiple arrays of vertex attributes
1360
+ // Mesh generation functions
1361
+ Mesh GenMeshPoly(int sides, float radius); // Generate polygonal mesh
1362
+ Mesh GenMeshPlane(float width, float length, int resX, int resZ); // Generate plane mesh (with subdivisions)
1363
+ Mesh GenMeshCube(float width, float height, float length); // Generate cuboid mesh
1364
+ Mesh GenMeshSphere(float radius, int rings, int slices); // Generate sphere mesh (standard sphere)
1365
+ Mesh GenMeshHemiSphere(float radius, int rings, int slices); // Generate half-sphere mesh (no bottom cap)
1366
+ Mesh GenMeshCylinder(float radius, float height, int slices); // Generate cylinder mesh
1367
+ Mesh GenMeshCone(float radius, float height, int slices); // Generate cone/pyramid mesh
1368
+ Mesh GenMeshTorus(float radius, float size, int radSeg, int sides); // Generate torus mesh
1369
+ Mesh GenMeshKnot(float radius, float size, int radSeg, int sides); // Generate trefoil knot mesh
1370
+ Mesh GenMeshHeightmap(Image heightmap, Vector3 size); // Generate heightmap mesh from image data
1371
+ Mesh GenMeshCubicmap(Image cubicmap, Vector3 cubeSize); // Generate cubes-based map mesh from image data
1372
+ // Material loading/unloading functions
1373
+ Material *LoadMaterials(const char *fileName, int *materialCount); // Load materials from model file
1374
+ Material LoadMaterialDefault(void); // Load default material (Supports: DIFFUSE, SPECULAR, NORMAL maps)
1375
+ bool IsMaterialValid(Material material); // Check if a material is valid (shader assigned, map textures loaded in GPU)
1376
+ void UnloadMaterial(Material material); // Unload material from GPU memory (VRAM)
1377
+ void SetMaterialTexture(Material *material, int mapType, Texture2D texture); // Set texture for a material map type (MATERIAL_MAP_DIFFUSE, MATERIAL_MAP_SPECULAR...)
1378
+ void SetModelMeshMaterial(Model *model, int meshId, int materialId); // Set material for a mesh
1379
+ // Model animations loading/unloading functions
1380
+ ModelAnimation *LoadModelAnimations(const char *fileName, int *animCount); // Load model animations from file
1381
+ void UpdateModelAnimation(Model model, ModelAnimation anim, int frame); // Update model animation pose (CPU)
1382
+ void UpdateModelAnimationBones(Model model, ModelAnimation anim, int frame); // Update model animation mesh bone matrices (GPU skinning)
1383
+ void UnloadModelAnimation(ModelAnimation anim); // Unload animation data
1384
+ void UnloadModelAnimations(ModelAnimation *animations, int animCount); // Unload animation array data
1385
+ bool IsModelAnimationValid(Model model, ModelAnimation anim); // Check model animation skeleton match
1386
+ // Collision detection functions
1387
+ bool CheckCollisionSpheres(Vector3 center1, float radius1, Vector3 center2, float radius2); // Check collision between two spheres
1388
+ bool CheckCollisionBoxes(BoundingBox box1, BoundingBox box2); // Check collision between two bounding boxes
1389
+ bool CheckCollisionBoxSphere(BoundingBox box, Vector3 center, float radius); // Check collision between box and sphere
1390
+ RayCollision GetRayCollisionSphere(Ray ray, Vector3 center, float radius); // Get collision info between ray and sphere
1391
+ RayCollision GetRayCollisionBox(Ray ray, BoundingBox box); // Get collision info between ray and box
1392
+ RayCollision GetRayCollisionMesh(Ray ray, Mesh mesh, Matrix transform); // Get collision info between ray and mesh
1393
+ RayCollision GetRayCollisionTriangle(Ray ray, Vector3 p1, Vector3 p2, Vector3 p3); // Get collision info between ray and triangle
1394
+ RayCollision GetRayCollisionQuad(Ray ray, Vector3 p1, Vector3 p2, Vector3 p3, Vector3 p4); // Get collision info between ray and quad
1395
+ //------------------------------------------------------------------------------------
1396
+ // Audio Loading and Playing Functions (Module: audio)
1397
+ //------------------------------------------------------------------------------------
1398
+ typedef void (*AudioCallback)(void *bufferData, unsigned int frames);
1399
+ // Audio device management functions
1400
+ void InitAudioDevice(void); // Initialize audio device and context
1401
+ void CloseAudioDevice(void); // Close the audio device and context
1402
+ bool IsAudioDeviceReady(void); // Check if audio device has been initialized successfully
1403
+ void SetMasterVolume(float volume); // Set master volume (listener)
1404
+ float GetMasterVolume(void); // Get master volume (listener)
1405
+ // Wave/Sound loading/unloading functions
1406
+ Wave LoadWave(const char *fileName); // Load wave data from file
1407
+ Wave LoadWaveFromMemory(const char *fileType, const unsigned char *fileData, int dataSize); // Load wave from memory buffer, fileType refers to extension: i.e. '.wav'
1408
+ bool IsWaveValid(Wave wave); // Checks if wave data is valid (data loaded and parameters)
1409
+ Sound LoadSound(const char *fileName); // Load sound from file
1410
+ Sound LoadSoundFromWave(Wave wave); // Load sound from wave data
1411
+ Sound LoadSoundAlias(Sound source); // Create a new sound that shares the same sample data as the source sound, does not own the sound data
1412
+ bool IsSoundValid(Sound sound); // Checks if a sound is valid (data loaded and buffers initialized)
1413
+ void UpdateSound(Sound sound, const void *data, int sampleCount); // Update sound buffer with new data (default data format: 32 bit float, stereo)
1414
+ void UnloadWave(Wave wave); // Unload wave data
1415
+ void UnloadSound(Sound sound); // Unload sound
1416
+ void UnloadSoundAlias(Sound alias); // Unload a sound alias (does not deallocate sample data)
1417
+ bool ExportWave(Wave wave, const char *fileName); // Export wave data to file, returns true on success
1418
+ bool ExportWaveAsCode(Wave wave, const char *fileName); // Export wave sample data to code (.h), returns true on success
1419
+ // Wave/Sound management functions
1420
+ void PlaySound(Sound sound); // Play a sound
1421
+ void StopSound(Sound sound); // Stop playing a sound
1422
+ void PauseSound(Sound sound); // Pause a sound
1423
+ void ResumeSound(Sound sound); // Resume a paused sound
1424
+ bool IsSoundPlaying(Sound sound); // Check if a sound is currently playing
1425
+ void SetSoundVolume(Sound sound, float volume); // Set volume for a sound (1.0 is max level)
1426
+ void SetSoundPitch(Sound sound, float pitch); // Set pitch for a sound (1.0 is base level)
1427
+ void SetSoundPan(Sound sound, float pan); // Set pan for a sound (-1.0 left, 0.0 center, 1.0 right)
1428
+ Wave WaveCopy(Wave wave); // Copy a wave to a new wave
1429
+ void WaveCrop(Wave *wave, int initFrame, int finalFrame); // Crop a wave to defined frames range
1430
+ void WaveFormat(Wave *wave, int sampleRate, int sampleSize, int channels); // Convert wave data to desired format
1431
+ float *LoadWaveSamples(Wave wave); // Load samples data from wave as a 32bit float data array
1432
+ void UnloadWaveSamples(float *samples); // Unload samples data loaded with LoadWaveSamples()
1433
+ // Music management functions
1434
+ Music LoadMusicStream(const char *fileName); // Load music stream from file
1435
+ Music LoadMusicStreamFromMemory(const char *fileType, const unsigned char *data, int dataSize); // Load music stream from data
1436
+ bool IsMusicValid(Music music); // Checks if a music stream is valid (context and buffers initialized)
1437
+ void UnloadMusicStream(Music music); // Unload music stream
1438
+ void PlayMusicStream(Music music); // Start music playing
1439
+ bool IsMusicStreamPlaying(Music music); // Check if music is playing
1440
+ void UpdateMusicStream(Music music); // Updates buffers for music streaming
1441
+ void StopMusicStream(Music music); // Stop music playing
1442
+ void PauseMusicStream(Music music); // Pause music playing
1443
+ void ResumeMusicStream(Music music); // Resume playing paused music
1444
+ void SeekMusicStream(Music music, float position); // Seek music to a position (in seconds)
1445
+ void SetMusicVolume(Music music, float volume); // Set volume for music (1.0 is max level)
1446
+ void SetMusicPitch(Music music, float pitch); // Set pitch for a music (1.0 is base level)
1447
+ void SetMusicPan(Music music, float pan); // Set pan for a music (-1.0 left, 0.0 center, 1.0 right)
1448
+ float GetMusicTimeLength(Music music); // Get music time length (in seconds)
1449
+ float GetMusicTimePlayed(Music music); // Get current music time played (in seconds)
1450
+ // AudioStream management functions
1451
+ AudioStream LoadAudioStream(unsigned int sampleRate, unsigned int sampleSize, unsigned int channels); // Load audio stream (to stream raw audio pcm data)
1452
+ bool IsAudioStreamValid(AudioStream stream); // Checks if an audio stream is valid (buffers initialized)
1453
+ void UnloadAudioStream(AudioStream stream); // Unload audio stream and free memory
1454
+ void UpdateAudioStream(AudioStream stream, const void *data, int frameCount); // Update audio stream buffers with data
1455
+ bool IsAudioStreamProcessed(AudioStream stream); // Check if any audio stream buffers requires refill
1456
+ void PlayAudioStream(AudioStream stream); // Play audio stream
1457
+ void PauseAudioStream(AudioStream stream); // Pause audio stream
1458
+ void ResumeAudioStream(AudioStream stream); // Resume audio stream
1459
+ bool IsAudioStreamPlaying(AudioStream stream); // Check if audio stream is playing
1460
+ void StopAudioStream(AudioStream stream); // Stop audio stream
1461
+ void SetAudioStreamVolume(AudioStream stream, float volume); // Set volume for audio stream (1.0 is max level)
1462
+ void SetAudioStreamPitch(AudioStream stream, float pitch); // Set pitch for audio stream (1.0 is base level)
1463
+ void SetAudioStreamPan(AudioStream stream, float pan); // Set pan for audio stream (0.5 is centered)
1464
+ void SetAudioStreamBufferSizeDefault(int size); // Default size for new audio streams
1465
+ void SetAudioStreamCallback(AudioStream stream, AudioCallback callback); // Audio thread callback to request new data
1466
+ void AttachAudioStreamProcessor(AudioStream stream, AudioCallback processor); // Attach audio stream processor to stream, receives frames x 2 samples as 'float' (stereo)
1467
+ void DetachAudioStreamProcessor(AudioStream stream, AudioCallback processor); // Detach audio stream processor from stream
1468
+ void AttachAudioMixedProcessor(AudioCallback processor); // Attach audio stream processor to the entire audio pipeline, receives frames x 2 samples as 'float' (stereo)
1469
+ void DetachAudioMixedProcessor(AudioCallback processor); // Detach audio stream processor from the entire audio pipeline