Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/pardcode/cpp-3d-game-tutorial-series

C++ 3D Game Tutorial Series (DirectX) - Learn to code a DirectX 3D Game in C++ from scratch
https://github.com/pardcode/cpp-3d-game-tutorial-series

3d 3d-game 3d-graphics 3d-graphics-engine cpp cpp11 d3d11 direct3d direct3d11 directx directx-11 directx-3d directx11 game game-development game-engine gamedev graphics graphics-engine graphics-programming

Last synced: 2 days ago
JSON representation

C++ 3D Game Tutorial Series (DirectX) - Learn to code a DirectX 3D Game in C++ from scratch

Awesome Lists containing this project

README

        

![CX3D Framework](Media/cx3d_logo.png)

[![CPP17](https://img.shields.io/badge/c++-17-blue)]()
[![Build Status](https://github.com/skypjack/entt/workflows/build/badge.svg)]()
[![Docs](https://img.shields.io/badge/docs-wiki-blue)]()
[![Discord channel](https://img.shields.io/discord/622797245368238082?logo=discord)](https://discord.gg/RymBzwKPyZ)
[![Patreon](https://img.shields.io/badge/donate-patreon-orange)](https://www.patreon.com/pardcode)
[![YouTube](https://img.shields.io/badge/tutorial-youtube-red)](https://www.youtube.com/PardCode)

## An easy to use C++ 3D Game Framework
![CX3D Framework](Media/cx3d_screen.jpg)
The `CX3D Framework` is an easy to use Game Framework for the development of 3D Games in C++.

The framework is written in C++ 17 and it provides a set of features that allow the users to make games quickly at low-level.

At the same time, the users can improve `CX3D` by adding new functionalities or extending the existing ones.

Games made upon this framework, and the framework itself, can be easily debugged and compiled in Release and/or Debug Mode.

The project aims to give the developers a complete and total control over the development of their games, starting from the internal `low-level` systems like Graphics Engine, Input Manager, Game System etc. arriving to the `high-level` classes (e.g. Entities).

This repository contains:
* Source Code of `CX3D Framework`,
* Source Code of a series of `Samples` that show how to use the framework (e.g. SpaceShooterGame).
* Documentation

The repository contains also branches like `AllTutorials` and `AssetsAndLibs`, related to the YouTube Tutorial Series called `C++ 3D Game Tutorial Series`:

These branches must be considered completely unrelated to the framework.

`CX3D Framework` derives from the Tutorial Series above mentioned.

The license is available [here](#license).

## Features
![CX3D Framework](Media/cx3d_screen2.jpg)
`CX3D Framework` is currently composed by the following (yet incomplete) list of features:

**Game System**
* Entity System
* Object-Oriented
* Dynamic Creation and Release of custom Entities through templating features: `createEntity()`
* Event-based Logic support: `onCreate()`, `onUpdate(f32 deltaTime)`, ...
* Default Entity classes available out-of-the-box: `LightEntity`,`MeshEntity`,`CameraEntity`,...

**Graphics Engine**
* Graphics APIs: `DirectX 11`
* Forward Rendering
* Phong-Based Lighting
* Static Meshes Support: `.obj` (all formats supported by `tinyobjloader`)
* Textures Support: `.jpg`,`.png`,`.bmp`,`.tga` etc. (all formats supported by `DirectXTex`)
* Materials Support: `HLSL` Shading Language, Textures, Custom Data Passage

**Input Manager**
* Mouse Input Events Support
* Keyboard Input Events Support

**Windowing System**
* Native windowing and event support under Windows.

## Quick Guide to build CX3D Framework and Game Sample

### Prerequisites:
* Visual Studio 2019 or later.
* Windows 10 or later.

Open `SpaceShooterGame.sln` Project, available under the `Samples/SpaceShooterGame` folder.

In Visual Studio, press the `Local Windows Debugger` button available in the main Toolbar.

## Public discussion forum
[The Discord Server](https://discord.gg/RymBzwKPyZ) is the place for project news, discussions of latest developments and any questions you have on how to use the `CX3D Framework` to develop your own 3D Games.

## Support
This project is available under a free and permissive license, but needs a financial support to sustain its development.

If `CX3D Framework` is helpful to you, consider to support it through [`Patreon`](https://www.patreon.com/pardcode).

Every single contribution makes the difference, regardless the amount.

Many thanks to all **the patrons** who have supported me so far!


[![Patreon](https://img.shields.io/badge/Donate-Patreon-orange)](https://www.patreon.com/pardcode)

## License

The license of this project is based on the modified MIT-License.

That means you can do whatever you want with the code available in this repository.

The only conditions to meet are:

- include the license text in your product (e.g. in the About Window of a GUI Application, About/Credits Section of a 2D/3D VideoGame)
- include the license text in all the source code files (copy-paste the license text to the top of all the source code files you get from this repository, even if you have partially modified them.)

If you want to modify and redistribute the source code files available in this repository, you can optionally add your own copyright notice together with the license text in this way:

```
...
CX3D Game Framework (https://github.com/PardCode/CX3D)
,

Copyright (c) 2019-2024, PardCode
Copyright (c) ,
...
```

The license text is available in the [`LICENSE`](LICENSE) file.