SadConsole 10.0.0-beta3

This is a prerelease version of SadConsole.
There is a newer version of this package available.
See the version list below for details.
dotnet add package SadConsole --version 10.0.0-beta3
                    
NuGet\Install-Package SadConsole -Version 10.0.0-beta3
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="SadConsole" Version="10.0.0-beta3" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="SadConsole" Version="10.0.0-beta3" />
                    
Directory.Packages.props
<PackageReference Include="SadConsole" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add SadConsole --version 10.0.0-beta3
                    
#r "nuget: SadConsole, 10.0.0-beta3"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package SadConsole@10.0.0-beta3
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=SadConsole&version=10.0.0-beta3&prerelease
                    
Install as a Cake Addin
#tool nuget:?package=SadConsole&version=10.0.0-beta3&prerelease
                    
Install as a Cake Tool

SadConsole Logo

Chat on discord NuGet kandi X-Ray

SadConsole is a generic library that emulates old-school console game systems. It provides command prompt-style graphics where one or more tile textures are used to represent an ASCII character set. Console's are made up of a grid of cells, each of which can have its own foreground, background, glyph, and special effect applied to it.

While SadConsole is a generic library that doesn't provide any rendering capabilities, "host" libraries are provided that add renderers to SadConsole. The two hosts provided by this library are for MonoGame and SFML.

SadConsole currently targets .NET 6 and .NET 7

For the latest changes in this release, see the notes below

Features

Here are some of the features SadConsole supports:

  • Show any number of consoles.
  • Uses graphical tile-based images to build out an ASCII-character font with support for more than 256 characters.
  • Use more than one font file. However, each console is restricted to a single font.
  • Independently controlled entities for game objects.
  • Keyboard and Mouse support.
  • Text UI control framework with windowing support.
  • Importers for DOS ANSI files, TheDraw text fonts, RexPaint, and Playscii.
  • Animated consoles.
  • Translating images to text-blocks.
  • Highly customizable framework.
String display and parsing

string pic

GUI library

GUI library pic

Scrolling

scrolling console

Dependencies

SadConsole uses NuGet for its .NET dependencies:

Example startup code

using Console = SadConsole.Console;
using SadConsole;
using SadConsole.Configuration;
using SadRogue.Primitives;

Settings.WindowTitle = "SadConsole Examples";

// Configure how SadConsole starts up
Builder startup = new Builder()
    .SetScreenSize(90, 30)
    .UseDefaultConsole()
    .OnStart(Game_Started)
    .IsStartingScreenFocused(true)
    .ConfigureFonts((config, game) => config.UseBuiltinFontExtended())
    ;

// Setup the engine and start the game
Game.Create(startup);
Game.Instance.Run();
Game.Instance.Dispose();

void Game_Started(object? sender, GameHost host)
{
    ColoredGlyph boxBorder = new(Color.White, Color.Black, 178);
    ColoredGlyph boxFill = new(Color.White, Color.Black);

    Game.Instance.StartingConsole.FillWithRandomGarbage(255);
    Game.Instance.StartingConsole.DrawBox(new Rectangle(2, 2, 26, 5), ShapeParameters.CreateFilled(boxBorder, boxFill));
    Game.Instance.StartingConsole.Print(4, 4, "Welcome to SadConsole!");
}
Imports SadConsole
Imports Console = SadConsole.Console
Imports SadConsole.Configuration
Imports SadRogue.Primitives

Module Module1

    Sub Main()

        Dim startup As New Builder()

        ' Configure how SadConsole starts up
        startup.SetScreenSize(90, 30)
        startup.UseDefaultConsole()
        startup.OnStart(AddressOf Game_Started)
        startup.IsStartingScreenFocused(True)
        startup.ConfigureFonts(Sub(config As FontConfig, gameObject As Game)
                                   config.UseBuiltinFontExtended()
                               End Sub)

        ' Setup the engine and start the game
        SadConsole.Game.Create(startup)
        SadConsole.Game.Instance.Run()
        SadConsole.Game.Instance.Dispose()

    End Sub

    Sub Game_Started(sender As Object, host As GameHost)

        Dim boxBorder = New ColoredGlyph(Color.White, Color.Black, 178)
        Dim boxFill = New ColoredGlyph(Color.White, Color.Black)

        Game.Instance.StartingConsole.FillWithRandomGarbage(255)
        Game.Instance.StartingConsole.DrawBox(New Rectangle(2, 2, 26, 5), ShapeParameters.CreateFilled(boxBorder, boxFill))
        Game.Instance.StartingConsole.Print(4, 4, "Welcome to SadConsole!")

    End Sub

End Module

Latest changes v10.0.0 Beta 1 and 2 (10/11/2023)

  • OnStart startup config is no longer an Action but is now an event.
  • Startup config changed again from the last alpha. Types were renamed and rewritten to be extensible. It works the same way as before except that everything is in the SadConsole.Configuration namespace. You must import that namespace to enable the extension methods that build the config. The type to build the config is Builder.
  • Tabs orientated left/right didn't display the text properly.
  • ColoredGlyph was renamed to ColoredGlyphBase and a new ColoredGlyph that inherits from the base class was added.
  • Scrollbars didn't behave properly when in a CompositeControl.
  • ListBox mouse logic was improved to use an "ItemsArea" property that designates when the mouse is over the items list specifically.
  • StringParser supports variables. There's a dictionary that invokes a delegate which returns a value for the variable. So the value can be determined as the variable is used. See DemoStringParsing.cs in the sample template.
  • AnimatedScreenObject's weren't rendering correctly.
  • Decorators are no longer array's but rented from a list pool. Use the CellDecoratorHelpers class to manage them. SadConsole does its best to rent and return from the pool as you add or remove decorators.
  • Default font used the wrong name. It's been corrected from "IBM_16x8" to "IBM_8x16".
  • The ToggleSwitch control wasn't drawing properly.
  • NumberBox supports cultured number parsing.
  • CellDecorator, as a readonly struct, now declares the properties with "get; init;" which allows mutation with the the "with" keyword.
  • EntityManager.AlternativeFont added to support different fonts for entities.
Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 is compatible.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (8)

Showing the top 5 NuGet packages that depend on SadConsole:

Package Downloads
SadConsole.Extended

A library of common classes that extend SadConsole with new controls, windows, and more.

SadConsole.Host.MonoGame

A graphics hosting library for SadConsole that targets MonoGame.

SadConsole.Host.SFML

A graphics hosting library for SadConsole that targets SFML.

SadConsole.GoRogueHelpers

A helper library for SadConsole games built with GoRogue.

TheSadRogue.Integration

An official integration library for using GoRogue and SadConsole together to create a roguelike.

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on SadConsole:

Repository Stars
Thraka/SadConsole
A .NET ascii/ansi console engine written in C# for MonoGame and SFML. Create your own text roguelike (or other) games!
Version Downloads Last Updated
10.6.0 651 8/9/2025
10.6.0-debug 206 8/9/2025
10.5.0 2,389 12/7/2024
10.5.0-debug 233 12/7/2024
10.4.2 361 10/24/2024
10.4.2-debug 162 10/24/2024
10.4.1 1,533 6/13/2024
10.4.1-debug 260 6/13/2024
10.4.0 1,575 3/31/2024
10.4.0-debug 298 3/31/2024
10.0.3 737 3/14/2024
10.0.3-debug 360 3/14/2024
10.0.2 1,739 11/10/2023
10.0.2-debug 959 11/10/2023
10.0.1 824 11/10/2023
10.0.1-debug 784 11/10/2023
10.0.0 1,940 10/29/2023
10.0.0-debug 1,081 10/29/2023
10.0.0-beta3-debug 1,210 10/14/2023
10.0.0-beta3 1,156 10/14/2023
10.0.0-beta2-debug 1,161 10/11/2023
10.0.0-beta2 1,192 10/11/2023
10.0.0-beta1-debug 1,196 10/11/2023
10.0.0-beta1 1,221 10/11/2023
10.0.0-alpha4-debug 1,481 8/26/2023
10.0.0-alpha4 1,431 8/26/2023
10.0.0-alpha3-debug 1,345 8/26/2023
10.0.0-alpha3 1,348 8/26/2023
10.0.0-alpha2-debug 1,740 6/18/2023
10.0.0-alpha2 1,534 6/18/2023
10.0.0-alpha1-debug 1,691 6/4/2023
9.2.2 5,510 1/22/2022
9.2.2-debug 1,350 1/22/2022
9.2.1 2,646 1/4/2022
9.2.0 3,576 12/31/2021
9.2.0-debug 1,215 12/31/2021
9.1.1 6,184 8/7/2021
9.1.1-debug 1,409 8/7/2021
9.1.0 2,332 7/6/2021
9.1.0-debug 1,392 7/6/2021
9.0.0 5,011 6/6/2021
9.0.0-debug 1,401 6/6/2021
9.0.0-beta4 2,167 1/15/2021
9.0.0-beta3 2,348 12/19/2020
9.0.0-beta2 1,749 10/9/2020
9.0.0-beta1 1,871 8/1/2020
9.0.0-alpha9 1,904 7/25/2020
9.0.0-alpha8 1,556 7/13/2020
9.0.0-alpha7 1,996 7/11/2020
9.0.0-alpha6 1,976 5/28/2020
9.0.0-alpha5 1,754 5/26/2020
9.0.0-alpha4 1,568 5/1/2020
9.0.0-alpha3 1,776 5/1/2020
9.0.0-alpha2 1,686 3/14/2020
9.0.0-alpha1 2,171 1/26/2020
8.99.3 3,920 8/15/2020
8.99.3-debug 1,606 8/15/2020
8.99.2 1,941 7/14/2020
8.99.2-debug 1,561 7/14/2020
8.99.1 2,637 4/11/2020
8.99.1-debug 1,584 4/11/2020
8.99.0 2,683 11/27/2019
8.99.0-debug 1,574 11/27/2019
8.9.1 4,131 11/5/2019
8.9.1-debug 1,578 11/5/2019
8.9.0 2,454 9/7/2019 8.9.0 is deprecated because it is no longer maintained.
8.9.0-debug 1,877 9/7/2019 8.9.0-debug is deprecated because it is no longer maintained.
8.8.1 3,380 7/28/2019 8.8.1 is deprecated because it is no longer maintained.
8.8.1-debug 1,818 7/28/2019 8.8.1-debug is deprecated because it is no longer maintained.
8.8.0 2,641 7/27/2019 8.8.0 is deprecated because it is no longer maintained.
8.8.0-debug 1,752 7/27/2019 8.8.0-debug is deprecated because it is no longer maintained.
8.7.1 2,190 6/22/2019 8.7.1 is deprecated because it is no longer maintained.
8.7.1-debug 1,816 6/22/2019 8.7.1-debug is deprecated because it is no longer maintained.
8.7.0 2,028 6/22/2019 8.7.0 is deprecated because it is no longer maintained.
8.7.0-debug 1,857 6/22/2019 8.7.0-debug is deprecated because it is no longer maintained.
8.6.0 2,286 4/14/2019 8.6.0 is deprecated because it is no longer maintained.
8.6.0-debug 1,871 4/14/2019 8.6.0-debug is deprecated because it is no longer maintained.
8.5.0 2,180 4/2/2019 8.5.0 is deprecated because it is no longer maintained.
8.5.0-debug 1,895 4/2/2019 8.5.0-debug is deprecated because it is no longer maintained.
8.4.1 2,144 3/19/2019 8.4.1 is deprecated because it is no longer maintained.
8.4.1-debug 1,905 3/19/2019 8.4.1-debug is deprecated because it is no longer maintained.
8.4.0 2,024 3/17/2019 8.4.0 is deprecated because it is no longer maintained.
8.4.0-debug 1,890 3/17/2019 8.4.0-debug is deprecated because it is no longer maintained.
8.3.0 2,116 3/10/2019 8.3.0 is deprecated because it is no longer maintained.
8.3.0-debug 1,842 3/10/2019 8.3.0-debug is deprecated because it is no longer maintained.
8.2.0 2,154 3/2/2019 8.2.0 is deprecated because it is no longer maintained.
8.2.0-debug 1,945 3/2/2019 8.2.0-debug is deprecated because it is no longer maintained.
8.1.0 2,114 2/28/2019 8.1.0 is deprecated because it is no longer maintained.
8.1.0-debug 1,832 2/28/2019 8.1.0-debug is deprecated because it is no longer maintained.
8.0.0 2,235 2/24/2019 8.0.0 is deprecated because it is no longer maintained.
8.0.0-pre5 1,913 2/19/2019 8.0.0-pre5 is deprecated because it is no longer maintained.
8.0.0-pre4 1,934 1/31/2019 8.0.0-pre4 is deprecated because it is no longer maintained.
8.0.0-pre2 1,972 12/30/2018 8.0.0-pre2 is deprecated because it is no longer maintained.
8.0.0-pre1 1,926 12/30/2018 8.0.0-pre1 is deprecated because it is no longer maintained.
7.3.0 2,185 12/29/2018
7.2.0 2,379 11/20/2018 7.2.0 is deprecated because it is no longer maintained.
7.1.0 2,425 10/19/2018 7.1.0 is deprecated because it is no longer maintained.
7.0.4 2,375 9/8/2018 7.0.4 is deprecated because it is no longer maintained.
7.0.3 2,215 9/8/2018 7.0.3 is deprecated because it is no longer maintained.
7.0.2 2,604 8/31/2018 7.0.2 is deprecated because it is no longer maintained.
7.0.0 2,268 8/29/2018
7.0.0-pre1 2,056 8/22/2018 7.0.0-pre1 is deprecated because it is no longer maintained.
6.5.0 2,694 6/12/2018
6.4.11 2,815 4/13/2018 6.4.11 is deprecated because it is no longer maintained.
6.4.11-pre1 2,590 4/6/2018 6.4.11-pre1 is deprecated because it is no longer maintained.
6.4.10 2,771 3/18/2018 6.4.10 is deprecated because it is no longer maintained.
6.4.9 2,743 3/18/2018 6.4.9 is deprecated because it is no longer maintained.
6.4.8 2,712 3/18/2018 6.4.8 is deprecated because it is no longer maintained.
6.4.7 2,780 3/16/2018 6.4.7 is deprecated because it is no longer maintained.
6.4.6 3,011 2/14/2018 6.4.6 is deprecated because it is no longer maintained.
6.4.5 2,821 2/3/2018 6.4.5 is deprecated because it is no longer maintained.
6.4.3 2,670 11/14/2017 6.4.3 is deprecated because it is no longer maintained.
6.4.2 2,761 8/11/2017 6.4.2 is deprecated because it is no longer maintained.
6.4.1 2,581 8/10/2017 6.4.1 is deprecated because it is no longer maintained.
6.4.0 2,657 7/25/2017 6.4.0 is deprecated because it is no longer maintained.
6.3.0 2,676 6/9/2017 6.3.0 is deprecated because it is no longer maintained.
6.2.2 2,685 5/20/2017 6.2.2 is deprecated because it is no longer maintained.
6.2.1 2,777 4/23/2017 6.2.1 is deprecated because it is no longer maintained.
6.2.0 2,610 4/22/2017 6.2.0 is deprecated because it is no longer maintained.
6.1.4 2,599 4/17/2017 6.1.4 is deprecated because it is no longer maintained.
6.1.3 3,273 4/3/2017 6.1.3 is deprecated because it is no longer maintained.
6.1.2 2,583 4/1/2017 6.1.2 is deprecated because it is no longer maintained.
6.1.1 2,531 4/1/2017 6.1.1 is deprecated because it is no longer maintained.
6.1.0 2,537 3/31/2017 6.1.0 is deprecated because it is no longer maintained.
6.0.1 2,674 3/19/2017 6.0.1 is deprecated because it is no longer maintained.
6.0.0 2,391 3/18/2017

- OnStart startup config is no longer an Action but is now an event.
- Startup config changed again from the last alpha. Types were renamed and rewritten to be extensible. It works the same way as before except that everything is in the SadConsole.Configuration namespace. You must import that namespace to enable the extension methods that build the config. The type to build the config is Builder.
- Tabs orientated left/right didn't display the text properly.
- ColoredGlyph was renamed to ColoredGlyphBase and a new ColoredGlyph that inherits from the base class was added.
- Scrollbars didn't behave properly when in a CompositeControl.
- ListBox mouse logic was improved to use an "ItemsArea" property that designates when the mouse is over the items list specifically.
- StringParser supports variables. There's a dictionary that invokes a delegate which returns a value for the variable. So the value can be determined as the variable is used. See DemoStringParsing.cs in the sample template.
- AnimatedScreenObject's weren't rendering correctly.
- Decorators are no longer array's but rented from a list pool. Use the CellDecoratorHelpers class to manage them. SadConsole does its best to rent and return from the pool as you add or remove decorators.
- Default font used the wrong name. It's been corrected from "IBM_16x8" to "IBM_8x16".
- The ToggleSwitch control wasn't drawing properly.
- NumberBox supports cultured number parsing.
- CellDecorator, as a readonly struct, now declares the properties with "get; init;" which allows mutation with the the "with" keyword.
- EntityManager.AlternativeFont added to support different fonts for entities.