Need help with magnum?
Click the “chat” button below for chat support from the developer who created it, or find similar developers for support.

About the developer

mosra
3.5K Stars 352 Forks Other 8.8K Commits 67 Opened issues

Description

Lightweight and modular C++11 graphics middleware for games and data visualization

Services available

!
?

Need anything else?

Contributors list

# 4,540
magnum
c-plus-...
vulkan
graphic...
8621 commits
# 48,263
magnum
graphic...
vulkan
webasse...
81 commits
# 218,125
magnum
c-plus-...
graphic...
vulkan
12 commits
# 192,844
TeX
deep-q-...
c-plus-...
vulkan
10 commits
# 50,038
vulkan
Lua
D
directx...
10 commits
# 225,224
magnum
c-plus-...
graphic...
vulkan
10 commits
# 254,975
c-plus-...
graphic...
vulkan
magnum
5 commits
# 304,628
c-plus-...
graphic...
vulkan
C++
4 commits
# 8,413
The Jul...
julia-l...
vulkan
magnum
4 commits
# 36,026
pytorch
c-plus-...
vulkan
advanta...
4 commits
# 293,602
c-plus-...
graphic...
vulkan
C++
3 commits
# 32,878
TypeScr...
sqlserv...
Electro...
React N...
3 commits
# 179,731
C++
Lua
magnum
vulkan
3 commits
# 338,574
C++
magnum
c-plus-...
graphic...
3 commits
# 123,594
angular...
aes-enc...
Bootstr...
c-plus-...
3 commits
# 121,876
C++
c-plus-...
travis-...
OpenCV
3 commits
# 378,833
c-plus-...
graphic...
vulkan
C++
2 commits
# 259,186
c-plus-...
graphic...
vulkan
C++
2 commits
# 375,506
C++
magnum
c-plus-...
graphic...
2 commits
# 334,099
C++
magnum
c-plus-...
voxels
2 commits

Magnum — Lightweight and modular C++11/C++14 graphics middleware for games and data visualization

Looking for an open-source library that gives you graphics abstraction and platform independence on major desktop, mobile and web platforms? Do you want it to have all the convenience utilities around yet stay small, powerful and not give up on flexibility? Here it is. And it's free to use, even for commercial purposes.

Join the chat at https://gitter.im/mosra/magnum Build Status Build Status Build Status Coverage Status Hunter Package MIT License

  • Project homepage — https://magnum.graphics/
  • Documentation — https://doc.magnum.graphics/
  • GitHub project page — https://github.com/mosra/magnum

Beauty of simplicity

Among Magnum essentials is a UTF-8-aware OS, filesystem and console abstraction, a feature-packed vector math library and a slim C++11 wrapper of OpenGL / WebGL family of APIs. Build on top of that or opt-in for more.

See all core features

With batteries included

Shaders and primitives for fast prototyping, algorithms, debugging and automatic testing, asset management, integration with popular windowing toolkits and a UI library. Everything fits together but you still have a choice.

List the extra features

Screws are not glued in

There's always more than one way to do things. Enjoy the freedom of choice and integrate your own asset loader, texture compressor, font format or math library, if you feel the need. Or use any of the various plugins.

View extension points


Wondering if Magnum is a good fit for your project? We prepared a few case studies to help you decide.

SUPPORTED PLATFORMS

  • Linux and embedded Linux
  • Windows with MSVC, clang-cl and MinGW, Windows RT (Store/Phone)
  • macOS, iOS
  • Android
  • Web (asm.js or WebAssembly), through Emscripten

Graphics APIs:

  • OpenGL 2.1 through 4.6, core profile functionality and modern extensions
  • OpenGL ES 2.0, 3.0–3.2 and extensions to match desktop OpenGL functionality
  • WebGL 1.0, 2.0 and extensions to match desktop OpenGL functionality

See the Build Status page for detailed per-platform build status.

WHAT'S NEW?

Curious about what was added or improved recently? Check out the Changelog page in the documentation.

GETTING STARTED

The best way to get started is to read the thorough download, build, install and start using Magnum in your project. There is also a complete building documentation — we provide packages for many platforms, including Windows, Linux and macOS. After that, there are various tutorials and examples and a complete feature guide explaining all aspects of the library.

Apart from that, various Magnum functionality is available through single-header libraries. Just download a file,

#include
it in your project and you're ready to go! No buildsystem wrangling needed.

RELATED PROJECTS

The engine itself is kept as small as possible with only a few dependencies. Additional functionality, often depending on external libraries, is provided in separate repositories.

  • Corrade — main Magnum dependency, a multiplatform utility library: https://github.com/mosra/corrade
  • Magnum Bootstrap — bootstrap projects for many use cases, helping you get up and running in no time: https://github.com/mosra/magnum-bootstrap
  • Magnum Plugins — various importer plugins for image, font, audio and 3D model formats are at https://github.com/mosra/magnum-plugins
  • Magnum Integration — integration with various external math and physics, get it at https://github.com/mosra/magnum-integration
  • Magnum Examples — examples of engine usage, varying from simple Hello World-like example to more advanced applications, such as viewer for complex 3D models. See it at https://github.com/mosra/magnum-examples
  • Magnum Extras — playground for testing new APIs, specialized stuff that doesn't necessarily need to be a part of main Magnum repository or mutually exclusive functionality: https://github.com/mosra/magnum-extras
  • Magnum Bindings — bindings to other languages such as Python are at https://github.com/mosra/magnum-bindings
  • Magnum Singles — various functionality from Magnum available as easy-to-integrate fast-to-compile single-header libraries: https://github.com/mosra/magnum-singles

Outside of the project itself, there's also a lot of community contributions — check them out on the website.

CONTACT & SUPPORT

If you want to contribute to Magnum, if you spotted a bug, need a feature or have an awesome idea, you can get a copy of the sources from GitHub and start right away! There is the already mentioned guide about how to download and build Magnum and also a guide about coding style and best practices which you should follow to keep the library as consistent and maintainable as possible.

  • Project homepage — https://magnum.graphics/
  • Documentation — https://doc.magnum.graphics/
  • GitHub — https://github.com/mosra/magnum and the #magnum topic
  • GitLab — https://gitlab.com/mosra/magnum
  • Gitter community chat — https://gitter.im/mosra/magnum
  • E-mail — [email protected]
  • Google Groups mailing list — [email protected] (archive)
  • Twitter — https://twitter.com/czmosra and the #MagnumEngine hashtag

See also the Magnum Project Contact & Support page for further information.

CREDITS

See the CREDITS.md file for details. Big thanks to everyone involved!

LICENSE

Magnum is licensed under the MIT/Expat license, see the COPYING file for details.

We use cookies. If you continue to browse the site, you agree to the use of cookies. For more information on our use of cookies please see our Privacy Policy.