Go to file
Ray b4d67499a7 BREAKING CHANGE: Read description
Changes:

 - Font structure has been redesigned, CharInfo structure contained character rectangle within font texture, it has not much sense, considering that it was an information relative to the font atlas generated and not the character itself, so character rectangles have been moved out from CharInfo to Font.
 - CharInfo included a data parameters to contain character pixel data (usually grayscale), generated on TTF font generation. It was inconsistent with other fonts types, so, now CharInfo includes directly an Image of the glyph.
 - REDESIGNED: GenImageFontAtlas(), additional recs parameter added, loaded and filled inside the function to export atlas characters rectangles, instead of silently modify the input CharInfo data.
 - REVIEWED: ImageTextEx(), funtion retrieved the font atlas image from the GPU, that was slow and problematic in several platforms. Now it uses directly the CharInfo image. Support for unicode codepoints has also been added.
 - REDESIGNED: ImageDraw(), now it includes an additional parameter, the color tint, not only it could be useful for several situations but also function signature is more consistent with similar functions.
 - ADDED: ImageFromImage() to generate a new image from a piece of another image.
 - REVIEWED: GetNextCodepoint(), renamed parameters to be more clear.

Also all examples and games that were affected by those changes have been reviewed.
2019-07-24 15:05:14 +02:00
.github Update FUNDING.yml 2019-07-16 23:32:49 +02:00
cmake CMake: fix dependency build with -Draylib_USE_STATIC_LIBS=ON 2019-07-24 00:12:38 +02:00
examples BREAKING CHANGE: Read description 2019-07-24 15:05:14 +02:00
games BREAKING CHANGE: Read description 2019-07-24 15:05:14 +02:00
logo New icon generation 2018-09-25 10:41:15 +02:00
projects Review VSCode project 2019-07-02 18:36:09 +02:00
src BREAKING CHANGE: Read description 2019-07-24 15:05:14 +02:00
templates Move emscripten web shell to src 2019-05-22 10:40:51 +02:00
.gitignore Ignore web bitcode lib 2019-05-21 18:02:20 +02:00
.travis.yml .travis.yml: update wayland dependency ECM version 2019-05-15 08:13:25 +02:00
appveyor.yml CI: Build with all optional formats enabled 2018-07-29 12:13:01 +02:00
BINDINGS.md Update BINDINGS.md 2019-06-09 23:15:42 +02:00
CHANGELOG Update to raylib 2.5 2019-05-31 09:57:22 +02:00
CMakeLists.txt Revert "CMake: make unsequenced modifications an error" 2019-05-04 23:56:38 +02:00
CONTRIBUTING.md Update CONTRIBUTING.md 2019-06-12 11:30:18 +02:00
HISTORY.md Update HISTORY.md 2019-05-29 13:55:50 +02:00
LICENSE.md Update LICENSE.md 2019-06-05 13:35:34 +02:00
raylib.pc.in CMake: pkg-config: fix usage for RedHat-like systems (#728) 2019-01-19 13:52:55 +01:00
README.md Update README.md 2019-05-27 15:31:57 +02:00
ROADMAP.md Update ROADMAP.md 2019-05-28 00:33:52 +02:00
SPONSORS.md Create SPONSORS.md 2019-07-18 23:19:22 +02:00

raylib is a simple and easy-to-use library to enjoy videogames programming.

raylib is highly inspired by Borland BGI graphics lib and by XNA framework and it's specially well suited for prototyping, tooling, graphical applications, embedded systems and education.

NOTE for ADVENTURERS: raylib is a programming library to enjoy videogames programming; no fancy interface, no visual helpers, no auto-debugging... just coding in the most pure spartan-programmers way.

Ready to learn? Jump to code examples!

Build Status https://ci.appveyor.com/api/projects/status/github/raysan5/raylib?svg=true Chat on Discord License Twitter URL

features

  • NO external dependencies, all required libraries are bundled into raylib
  • Multiple platforms supported: Windows, Linux, MacOS, Android... and many more!
  • Written in plain C code (C99) in PascalCase/camelCase notation
  • Hardware accelerated with OpenGL (1.1, 2.1, 3.3 or ES 2.0)
  • Unique OpenGL abstraction layer (usable as standalone module): rlgl
  • Multiple Fonts formats supported (XNA fonts, AngelCode fonts, TTF)
  • Outstanding texture formats support, including compressed formats (DXT, ETC, ASTC)
  • Full 3D support, including 3D Shapes, Models, Billboards, Heightmaps and more!
  • Flexible Materials system, supporting classic maps and PBR maps
  • Animated 3D models supported (skeletal bones animation)
  • Shaders support, including model and postprocessing shaders.
  • Powerful math module for Vector, Matrix and Quaternion operations: raymath
  • Audio loading and playing with streaming support (WAV, OGG, MP3, FLAC, XM, MOD)
  • VR stereo rendering support with configurable HMD device parameters
  • Huge examples collection with +95 code examples!
  • Bindings to +25 programming languages!

raylib uses on its core module the outstanding GLFW3 library, embedded in the form of rglfw module, to avoid external dependencies.

raylib uses on its raudio module, the amazing miniaudio library to support multiple platforms and multiple audio backends.

raylib uses internally multiple single-file header-only libraries to support different fileformats loading and saving, all those libraries are embedded with raylib and available in src/external directory. Check raylib Wiki for a detailed list.

On Android platform, native_app_glue module module (provided by Android NDK) and native Android libraries are used to manage window/context, inputs and activity life cycle.

On Raspberry Pi platform (native mode), Videocore API and EGL libraries are used for window/context management. Inputs are processed using evdev Linux libraries

build and installation

Binary releases for Windows, Linux and macOS are available at the Github Releases page. raylib is also available via multiple package managers on multiple OS distributions. Check raylib Wiki for more info.

If you wish to build raylib yourself, the raylib Wiki also contains detailed instructions on how to approach that.

raylib has been developed using two tools:

Those are the tools recommended to enjoy raylib development.

contact

If you are using raylib and you enjoy it, please, join our Discord server.

license

raylib is licensed under an unmodified zlib/libpng license, which is an OSI-certified, BSD-like license that allows static linking with closed source software. Check LICENSE for further details.