SadConsole 10.0.3-debug

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.3-debug                
NuGet\Install-Package SadConsole -Version 10.0.3-debug                
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.3-debug" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add SadConsole --version 10.0.3-debug                
#r "nuget: SadConsole, 10.0.3-debug"                
#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.
// Install SadConsole as a Cake Addin
#addin nuget:?package=SadConsole&version=10.0.3-debug&prerelease

// Install SadConsole as a Cake Tool
#tool nuget:?package=SadConsole&version=10.0.3-debug&prerelease                

SadConsole Logo

Chat on discord NuGet kandi X-Ray

SadConsole is a C#-based .NET cross-platform terminal, ascii, console, game engine. It simulates these types of programs and with it you can make ascii-styled games for modern platforms. At its heart, SadConsole is really a giant tile-based game engine. However, its object model is conceptually similar to a traditional console app.

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 SadConsole.Host.MonoGame and SadConsole.Host.SFML. When adding a host library to your project, you don't need to reference the base SadConsole package. If you use MonoGame, you'll also need to add a rendering NuGet package, such as MonoGame.Framework.DesktopGL.

SadConsole currently targets .NET 6, .NET 7, and .NET 8

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 of any size.
  • Uses graphical tile-based images to build out an ASCII-character font with support for more than 256 characters.
  • Fonts are simply sprite sheet tilesets tied to ascii codes, you can use full graphical tiles if you want.
  • Use more than one font file. However, each console is restricted to a single font.
  • Full GUI system for interactive controls such as list boxes, buttons, and text fields.
  • Importers for DOS ANSI files, TheDraw text fonts, RexPaint, and Playscii.
  • Animated consoles and instruction system to chain commands together.
  • String encoding system for colors and effects while printing.
  • Entity support for drawing thousands of movable objects on the screen
  • Translating images to text-blocks.
  • Keyboard and mouse support.
  • 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(true)
    ;

// 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(True)

        ' 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.3 (03/13/2024)

  • [UI] ScrollBar has been completely rewritten. Minor breaking changes.
    • .Maximum has been changed to .MaximumValue.
    • Properties related to the style, such as BarGlyph, were moved to a Style property which controls how the control looks. Some property names have changed
  • [UI] NumberBox improvements.
    • Rendering code split from Textbox.
    • Added ShowUpDownButtons to show up\down buttons.
    • Fixed bug with UseMinMax messing up the value and setting it back to 0 when the control loses focus.
  • [UI] ControlBase.FindThemeFont helper method added.
  • [UI] Minor bug fixed where captured controls (such as a scroll bar) wouldn't process the mouse if the control was parented to a composite control and the mouse left the parent area.
  • [Core] Fixed EffectSet bug where the last effect wasn't applied.
  • [Core] GlyphDefinition has an init accessor now.
  • [Core] Added ShapeParameter docs and CreateFilled supports ignoring the border.
  • [Core] Added RootComponent class that can be added to SadConsole.Game.Instance.RootComponents. These components run logic before the keyboard and screen updates.
  • [Core] Splash screen collection is nulled after it runs, freeing memory.
  • [Extended] Classic keyboard handler has IsReady flag now to control when it's active.
  • [Extended] ColorPickerPopup would crash on invalid textbox values.
  • [Extended] GlyphSelectPopup added. You can use this to display a list of glyphs in your font while debugging your app.
  • [Extended] Fixed a bug in the table control that prevented the scroll bars from being displayed.
  • [Extended] Cleaned up code and enabled nullable.
  • [Host - SFML] Fix bug where it was always running at unlimited FPS.
  • [Host - MonoGame] Renderers can set backing texture usage.
  • [Host - FNA] Fix bug where the screen clear wasn't working and would default to violet.
  • [Host - All] Add OptimizedScreenSurfaceRenderer which renders.
  • [Host - All] Surface render step can accept an alternative surface with the SetData method.
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 is compatible.  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. 
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 XNA. Create your own text roguelike (or other) games!
Version Downloads Last updated
10.5.0 502 12/7/2024
10.5.0-debug 105 12/7/2024
10.4.2 254 10/24/2024
10.4.2-debug 76 10/24/2024
10.4.1 1,273 6/13/2024
10.4.1-debug 155 6/13/2024
10.4.0 1,298 3/31/2024
10.4.0-debug 216 3/31/2024
10.0.3 497 3/14/2024
10.0.3-debug 263 3/14/2024
10.0.2 1,584 11/10/2023
10.0.2-debug 880 11/10/2023
10.0.1 757 11/10/2023
10.0.1-debug 725 11/10/2023
10.0.0 1,808 10/29/2023
10.0.0-debug 992 10/29/2023
10.0.0-beta3-debug 1,105 10/14/2023
10.0.0-beta3 1,071 10/14/2023
10.0.0-beta2-debug 1,054 10/11/2023
10.0.0-beta2 1,075 10/11/2023
10.0.0-beta1-debug 1,082 10/11/2023
10.0.0-beta1 1,121 10/11/2023
10.0.0-alpha4-debug 1,372 8/26/2023
10.0.0-alpha4 1,305 8/26/2023
10.0.0-alpha3-debug 1,216 8/26/2023
10.0.0-alpha3 1,233 8/26/2023
10.0.0-alpha2-debug 1,600 6/18/2023
10.0.0-alpha2 1,394 6/18/2023
10.0.0-alpha1-debug 1,498 6/4/2023
9.2.2 5,093 1/22/2022
9.2.2-debug 1,193 1/22/2022
9.2.1 2,453 1/4/2022
9.2.0 3,321 12/31/2021
9.2.0-debug 1,083 12/31/2021
9.1.1 5,403 8/7/2021
9.1.1-debug 1,274 8/7/2021
9.1.0 2,140 7/6/2021
9.1.0-debug 1,262 7/6/2021
9.0.0 4,636 6/6/2021
9.0.0-debug 1,263 6/6/2021
9.0.0-beta4 1,950 1/15/2021
9.0.0-beta3 2,058 12/19/2020
9.0.0-beta2 1,579 10/9/2020
9.0.0-beta1 1,699 8/1/2020
9.0.0-alpha9 1,711 7/25/2020
9.0.0-alpha8 1,401 7/13/2020
9.0.0-alpha7 1,738 7/11/2020
9.0.0-alpha6 1,771 5/28/2020
9.0.0-alpha5 1,566 5/26/2020
9.0.0-alpha4 1,412 5/1/2020
9.0.0-alpha3 1,608 5/1/2020
9.0.0-alpha2 1,501 3/14/2020
9.0.0-alpha1 1,926 1/26/2020
8.99.3 3,717 8/15/2020
8.99.3-debug 1,454 8/15/2020
8.99.2 1,783 7/14/2020
8.99.2-debug 1,414 7/14/2020
8.99.1 2,440 4/11/2020
8.99.1-debug 1,417 4/11/2020
8.99.0 2,485 11/27/2019
8.99.0-debug 1,411 11/27/2019
8.9.1 3,850 11/5/2019
8.9.1-debug 1,418 11/5/2019
8.9.0 2,187 9/7/2019 8.9.0 is deprecated because it is no longer maintained.
8.9.0-debug 1,605 9/7/2019 8.9.0-debug is deprecated because it is no longer maintained.
8.8.1 3,045 7/28/2019 8.8.1 is deprecated because it is no longer maintained.
8.8.1-debug 1,583 7/28/2019 8.8.1-debug is deprecated because it is no longer maintained.
8.8.0 2,362 7/27/2019 8.8.0 is deprecated because it is no longer maintained.
8.8.0-debug 1,521 7/27/2019 8.8.0-debug is deprecated because it is no longer maintained.
8.7.1 1,921 6/22/2019 8.7.1 is deprecated because it is no longer maintained.
8.7.1-debug 1,585 6/22/2019 8.7.1-debug is deprecated because it is no longer maintained.
8.7.0 1,768 6/22/2019 8.7.0 is deprecated because it is no longer maintained.
8.7.0-debug 1,604 6/22/2019 8.7.0-debug is deprecated because it is no longer maintained.
8.6.0 2,048 4/14/2019 8.6.0 is deprecated because it is no longer maintained.
8.6.0-debug 1,608 4/14/2019 8.6.0-debug is deprecated because it is no longer maintained.
8.5.0 1,941 4/2/2019 8.5.0 is deprecated because it is no longer maintained.
8.5.0-debug 1,634 4/2/2019 8.5.0-debug is deprecated because it is no longer maintained.
8.4.1 1,899 3/19/2019 8.4.1 is deprecated because it is no longer maintained.
8.4.1-debug 1,671 3/19/2019 8.4.1-debug is deprecated because it is no longer maintained.
8.4.0 1,762 3/17/2019 8.4.0 is deprecated because it is no longer maintained.
8.4.0-debug 1,602 3/17/2019 8.4.0-debug is deprecated because it is no longer maintained.
8.3.0 1,868 3/10/2019 8.3.0 is deprecated because it is no longer maintained.
8.3.0-debug 1,595 3/10/2019 8.3.0-debug is deprecated because it is no longer maintained.
8.2.0 1,904 3/2/2019 8.2.0 is deprecated because it is no longer maintained.
8.2.0-debug 1,675 3/2/2019 8.2.0-debug is deprecated because it is no longer maintained.
8.1.0 1,862 2/28/2019 8.1.0 is deprecated because it is no longer maintained.
8.1.0-debug 1,593 2/28/2019 8.1.0-debug is deprecated because it is no longer maintained.
8.0.0 1,962 2/24/2019 8.0.0 is deprecated because it is no longer maintained.
8.0.0-pre5 1,645 2/19/2019 8.0.0-pre5 is deprecated because it is no longer maintained.
8.0.0-pre4 1,676 1/31/2019 8.0.0-pre4 is deprecated because it is no longer maintained.
8.0.0-pre2 1,726 12/30/2018 8.0.0-pre2 is deprecated because it is no longer maintained.
8.0.0-pre1 1,693 12/30/2018 8.0.0-pre1 is deprecated because it is no longer maintained.
7.3.0 2,024 12/29/2018
7.2.0 2,116 11/20/2018 7.2.0 is deprecated because it is no longer maintained.
7.1.0 2,153 10/19/2018 7.1.0 is deprecated because it is no longer maintained.
7.0.4 2,100 9/8/2018 7.0.4 is deprecated because it is no longer maintained.
7.0.3 1,960 9/8/2018 7.0.3 is deprecated because it is no longer maintained.
7.0.2 2,316 8/31/2018 7.0.2 is deprecated because it is no longer maintained.
7.0.0 2,080 8/29/2018
7.0.0-pre1 1,784 8/22/2018 7.0.0-pre1 is deprecated because it is no longer maintained.
6.5.0 2,271 6/12/2018
6.4.11 2,317 4/13/2018 6.4.11 is deprecated because it is no longer maintained.
6.4.11-pre1 2,105 4/6/2018 6.4.11-pre1 is deprecated because it is no longer maintained.
6.4.10 2,273 3/18/2018 6.4.10 is deprecated because it is no longer maintained.
6.4.9 2,230 3/18/2018 6.4.9 is deprecated because it is no longer maintained.
6.4.8 2,197 3/18/2018 6.4.8 is deprecated because it is no longer maintained.
6.4.7 2,279 3/16/2018 6.4.7 is deprecated because it is no longer maintained.
6.4.6 2,478 2/14/2018 6.4.6 is deprecated because it is no longer maintained.
6.4.5 2,296 2/3/2018 6.4.5 is deprecated because it is no longer maintained.
6.4.3 2,276 11/14/2017 6.4.3 is deprecated because it is no longer maintained.
6.4.2 2,359 8/11/2017 6.4.2 is deprecated because it is no longer maintained.
6.4.1 2,182 8/10/2017 6.4.1 is deprecated because it is no longer maintained.
6.4.0 2,260 7/25/2017 6.4.0 is deprecated because it is no longer maintained.
6.3.0 2,279 6/9/2017 6.3.0 is deprecated because it is no longer maintained.
6.2.2 2,287 5/20/2017 6.2.2 is deprecated because it is no longer maintained.
6.2.1 2,398 4/23/2017 6.2.1 is deprecated because it is no longer maintained.
6.2.0 2,204 4/22/2017 6.2.0 is deprecated because it is no longer maintained.
6.1.4 2,201 4/17/2017 6.1.4 is deprecated because it is no longer maintained.
6.1.3 2,897 4/3/2017 6.1.3 is deprecated because it is no longer maintained.
6.1.2 2,169 4/1/2017 6.1.2 is deprecated because it is no longer maintained.
6.1.1 2,132 4/1/2017 6.1.1 is deprecated because it is no longer maintained.
6.1.0 2,153 3/31/2017 6.1.0 is deprecated because it is no longer maintained.
6.0.1 2,273 3/19/2017 6.0.1 is deprecated because it is no longer maintained.
6.0.0 2,076 3/18/2017

- ScrollBar has been completely rewritten. Minor breaking changes.
     - NumberBox has been improved.
     - Minor bug fixed where captured controls (such as a scroll bar) wouldn't process the mouse if the control was parented to a composite control and the mouse left the parent area.
     - ControlBase.FindThemeFont helper method added.
     - Fixed EffectSet bug where the last effect wasn't applied.
     - GlyphDefinition has an init accessor now.
     - Added ShapeParameter docs and CreateFilled supports ignoring the border.
     - Added RootComponent class that can be added to SadConsole.Game.Instance.RootComponents. These components run logic before the keyboard and screen updates.
     - Splash screen collection is nulled after it runs, freeing memory.