3D engine for the Nintendo DS
Go to file
2024-03-03 19:59:49 +00:00
docs docs: Document all Dual 3D modes 2023-10-18 22:29:17 +01:00
documentation doc: library: Increase version to 0.11.0 2024-03-02 14:21:47 +00:00
examples examples: Move old text example to text folder 2024-03-02 13:13:28 +00:00
include library: Add note about texture sizes for rich text 2024-03-03 19:59:49 +00:00
licenses examples: Change license to CC0-1.0 2022-10-16 22:55:06 +01:00
screenshots docs: Add screenshot of text rendering to readme 2024-03-02 18:43:19 +00:00
source libdsf: Update to version 0.1.1 2024-03-03 19:59:15 +00:00
tests tests: Fix build of LCD depth test example 2024-01-28 02:35:35 +00:00
tools img2ds: Add another deprecation notice 2024-01-28 01:44:50 +00:00
.gitignore library: docs: example: Refactor debug mode builds 2022-10-21 00:50:13 +01:00
changelog.rst doc: library: Increase version to 0.11.0 2024-03-02 14:21:47 +00:00
Makefile library: Add rich text support 2024-03-02 13:07:44 +00:00
Makefile.blocksds library: Add rich text support 2024-03-02 13:07:44 +00:00
readme.rst docs: Add screenshot of text rendering to readme 2024-03-02 18:43:19 +00:00

####################
Nitro Engine v0.11.0
####################

Introduction
============

This is a 3D game engine, a lot of functions designed to simplify the process of
making a 3D game. It isn't standalone, it needs libnds to work.

You may use Nitro Engine with both devkitPro installations, and with `BlocksDS
<https://github.com/blocksds/sdk>`_.

Features:

- Support for static models, converted from OBJ files.
- Support for animated models, thanks to the `DSMA library
  <https://github.com/AntonioND/dsma-library>`_, which converts MD5 models (with
  skeletal animation) into a format that can be rendered with hardware
  acceleration. It can also blend two animations together (for transitions).
- Support for all format of textures (even compressed textures, thanks to 
  `ptexconv <https://github.com/Garhoogin/ptexconv>`_).
- Dual 3D (render 3D to both screens, but at 30 FPS instead of 60 FPS).
- Functions to render 2D images accelerated by 3D hardware.
- Text system based on `libDSF <https://github.com/AntonioND/libdsf>`_, which is
  based on `BMFont <https://www.angelcode.com/products/bmfont/>`_.
- Basic GUI elements like buttons and scrollbars.
- Basic physic system: Axis-aligned bounding boxes (AABB) only.

Nitro Engine doesn't support any of the 2D hardware of the DS. In order to use
the 2D hardware you can use libnds directly, or you can use a library like
`NFlib <https://github.com/knightfox75/nds_nflib>`_. There is an example of how
to integrate Nitro Engine and NFlib in the same project `here
<./examples/templates/using_nflib>`_.

Setup
=====

devkitpro
---------

1. Clone this repository. Create a symbolic link to it inside the devkitPro
   folder in your system. For example, in Linux, create a symlink so that
   ``/opt/devkitpro/nitro-engine`` points to the folder with Nitro Engine:

   .. code:: bash

       ln -sT /path/to/nitro-engine /opt/devkitpro/nitro-engine

2. Go to the ``nitro-engine`` folder and type this on the terminal:

   .. code:: bash

       make
       make NE_DEBUG=1

   This should build the library in both debug and release modes.

3. If you want to check that everything is working as expected, open one of the
   folders of the examples and type ``make``. That should build an ``.nds`` file
   that you can run on an emulator or real hardware.

BlocksDS
--------

1. Clone this repository and run:

   .. code:: bash

       make -f Makefile.blocksds
       make -f Makefile.blocksds NE_DEBUG=1
       make -f Makefile.blocksds install

   This should build the library in both debug and release modes and install it.

2. If you want to check that everything is working as expected, open one of the
   folders of the examples and run:

   .. code:: bash

       make -f Makefile.blocksds

   That should build an ``.nds`` file that you can run on an emulator or real
   hardware.

Common
------

Note that some features of the 3D hardware aren't emulated by most emulators, so
you may need to use an actual NDS to test some things. **melonDS** seems to
emulate all features correctly. **DeSmuME** doesn't emulate the polygon/vertices
count registers, so the touch test feature of Nitro Engine doesn't work.

Normally you should link your programs with ``-lNE``, which is the release
version of Nitro Engine. If you want to use the debug features of Nitro Engine,
you should link with ``-lNE_debug``, and add ``-DNE_DEBUG`` to the ``CFLAGS``
and ``CPPFLAGS`` in your Makefile. Make sure to clean and rebuild your project
after doing the changes mentioned in this step. Check the **error_handling**
example to see how to use the debug mode of Nitro Engine.

Screenshots
===========

Screenshots of some of the examples included with Nitro Engine:

.. |animated_model| image:: screenshots/animated_model.png
.. |box_tower| image:: screenshots/box_tower.png
.. |fog| image:: screenshots/fog.png
.. |specular_material| image:: screenshots/specular_material.png
.. |screen_effects| image:: screenshots/screen_effects.png
.. |sprites| image:: screenshots/sprites.png
.. |text| image:: screenshots/text.png

+------------------+-------------------+
| Animated model   | Box tower physics |
+------------------+-------------------+
| |animated_model| | |box_tower|       |
+------------------+-------------------+

+------------------+---------------------+
| Hardware fog     | Specular material   |
+------------------+---------------------+
| |fog|            | |specular_material| |
+------------------+---------------------+

+------------------+-------------------+
| Screen effects   | 2D sprites        |
+------------------+-------------------+
| |screen_effects| | |sprites|         |
+------------------+-------------------+

+------------------+
| Text             |
+------------------+
| |text|           |
+------------------+

Contact
=======

This project is currently hosted on GitHub at:

    https://github.com/AntonioND/nitro-engine

If you want to contact me (Antonio Niño Díaz) directly you can email me at:

   antonio underscore nd at outlook dot com

License
=======

The code of this repository is under the MIT license. The examples are under the
CC0-1.0 license.

The full text of the licenses can be found under the ``licenses`` folder.

Future work
===========

- Asynchronous loading of assets.
- Support for compressed textures.

Thanks to
=========

- **devkitPro**: https://devkitpro.org/
- **libnds**: https://github.com/devkitPro/libnds
- **DLDI**: https://www.chishm.com/DLDI/
- **DeSmuME**: http://desmume.org/
- **melonDS**: https://melonds.kuribo64.net/
- **no$gba**: https://problemkaputt.de/gba.htm
- **gbatek**: https://problemkaputt.de/gbatek.htm
- **gbadev forums**: https://forum.gbadev.org/