2
0
mirror of https://github.com/raylib-cs/raylib-cs synced 2025-10-23 05:29:50 -04:00
ChrisDill 701434ef99 Remove file management functions in favour of System.IO alternatives
- These functions have a similar api to System.IO functions in C#.
For example 'DirectoryExists' can be replaced with 'Directory.Exists'.
- I considered wrapping them to use `System.IO` internally however that is less flexible than using it
directly.
2020-12-29 16:26:35 +00:00
2018-09-13 12:00:51 +01:00
2020-04-01 14:35:26 +01:00
2020-09-15 08:57:14 +01:00
2020-04-01 14:35:26 +01:00
2020-12-28 10:56:29 +00:00

Raylib-cs Logo

Raylib-cs

C# bindings for raylib 3.5.0, a simple and easy-to-use library to learn videogames programming (www.raylib.com)

GitHub contributors License .NET Core GitHub stars

Chat on Discord

Raylib-cs targets netstandard2.1 and supports netcoreapp3.0+ and net5.0.

Installation - NuGet

This is the prefered method to get started - The package is still new so please report any issues.

NOTE: The nuget package uses raylib 3.0. It will soon be updated to raylib 3.5.0.

dotnet add package Raylib-cs --version 3.1.5

NuGet

If you need to edit Raylib-cs source then you will need to add the bindings as a project (see below).

Installation - Manual

  1. Download/Clone this repo

  2. Add Raylib-cs/Raylib-cs.csproj to your project as an existing project.

  3. Download the native libraries for the platforms you want to build for using the official 3.5.0 release. NOTE: the MSVC version is required for Windows platforms

  4. (Recommended) Put the native library for each platform under Raylib-cs/runtimes/{platform}/native/ (Optional) If you want to handle the native libraries yourself, make sure they are either in the same directory as the executable and/or can be found in the search path. See https://www.mono-project.com/docs/advanced/pinvoke/ for details.

  5. Start coding!

using Raylib_cs;

namespace HelloWorld
{
    static class Program
    {
        public static void Main()
        {
            Raylib.InitWindow(800, 480, "Hello World");

            while (!Raylib.WindowShouldClose())
            {
                Raylib.BeginDrawing();
                Raylib.ClearBackground(Color.WHITE);

                Raylib.DrawText("Hello, world!", 12, 12, 20, Color.BLACK);

                Raylib.EndDrawing();
            }

            Raylib.CloseWindow();
        }
    }
}

Physac-cs and Raygui-cs

These are unfinished EXPERIMENTAL bindings to physac and raygui. Added as a test to Raylib-cs but caused confusion in project setup so they were moved into their own libraries.

Documentation

Examples for Raylib-cs can be found at Raylib-cs-Examples.

Details about Raylib-cs can be found on the Raylib-cs wiki.

Contributing

If you have any ideas, feel free to open an issue and tell me what you think. If you'd like to contribute, please fork the repository and make changes as you'd like. Pull requests are warmly welcome.

If you want to request features or report bugs related to the library (in contrast to this binding), please refer to the author's project repo.

License

See LICENSE for details.

Description
C# bindings for raylib, a simple and easy-to-use library to learn videogames programming
https://www.raylib.com
Readme Zlib 75 MiB
Languages
C# 100%