SadConsole 10.5.0
dotnet add package SadConsole --version 10.5.0
NuGet\Install-Package SadConsole -Version 10.5.0
<PackageReference Include="SadConsole" Version="10.5.0" />
paket add SadConsole --version 10.5.0
#r "nuget: SadConsole, 10.5.0"
// Install SadConsole as a Cake Addin #addin nuget:?package=SadConsole&version=10.5.0 // Install SadConsole as a Cake Tool #tool nuget:?package=SadConsole&version=10.5.0
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
GUI library
Scrolling
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.4.2 (10/23/2024)
- [Core] Fixed small bug when cursor's effect was removed.
- [Core]
StringParser
's base command object has a virtualRemoved
method. - [Core]
StringParser
's Recolor command can use 'w' in place of length to specify that it recolors 'word' length: until a space or \0 character is reached. - [Core]
StringParser
's Blink command now has the blink effectRestoreCellOnRemoved
set to true. - [Core]
NamedColor
supporting type which is just a collection of named color values for serialization. - [Core] Fix some spelling errors.
Product | Versions 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 is compatible. 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. |
-
net6.0
- Coroutine (>= 2.1.5)
- Newtonsoft.Json (>= 13.0.3)
- TheSadRogue.Primitives (>= 1.6.0-rc3)
-
net7.0
- Coroutine (>= 2.1.5)
- Newtonsoft.Json (>= 13.0.3)
- TheSadRogue.Primitives (>= 1.6.0-rc3)
-
net8.0
- Coroutine (>= 2.1.5)
- Newtonsoft.Json (>= 13.0.3)
- TheSadRogue.Primitives (>= 1.6.0-rc3)
-
net9.0
- Coroutine (>= 2.1.5)
- Newtonsoft.Json (>= 13.0.3)
- TheSadRogue.Primitives (>= 1.6.0-rc3)
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-debug | 1,605 | 9/7/2019 | |
8.8.1 | 3,045 | 7/28/2019 | |
8.8.1-debug | 1,583 | 7/28/2019 | |
8.8.0 | 2,362 | 7/27/2019 | |
8.8.0-debug | 1,521 | 7/27/2019 | |
8.7.1 | 1,921 | 6/22/2019 | |
8.7.1-debug | 1,585 | 6/22/2019 | |
8.7.0 | 1,768 | 6/22/2019 | |
8.7.0-debug | 1,604 | 6/22/2019 | |
8.6.0 | 2,048 | 4/14/2019 | |
8.6.0-debug | 1,608 | 4/14/2019 | |
8.5.0 | 1,941 | 4/2/2019 | |
8.5.0-debug | 1,634 | 4/2/2019 | |
8.4.1 | 1,899 | 3/19/2019 | |
8.4.1-debug | 1,671 | 3/19/2019 | |
8.4.0 | 1,762 | 3/17/2019 | |
8.4.0-debug | 1,602 | 3/17/2019 | |
8.3.0 | 1,868 | 3/10/2019 | |
8.3.0-debug | 1,595 | 3/10/2019 | |
8.2.0 | 1,904 | 3/2/2019 | |
8.2.0-debug | 1,675 | 3/2/2019 | |
8.1.0 | 1,862 | 2/28/2019 | |
8.1.0-debug | 1,593 | 2/28/2019 | |
8.0.0 | 1,962 | 2/24/2019 | |
8.0.0-pre5 | 1,645 | 2/19/2019 | |
8.0.0-pre4 | 1,676 | 1/31/2019 | |
8.0.0-pre2 | 1,726 | 12/30/2018 | |
8.0.0-pre1 | 1,693 | 12/30/2018 | |
7.3.0 | 2,024 | 12/29/2018 | |
7.2.0 | 2,116 | 11/20/2018 | |
7.1.0 | 2,153 | 10/19/2018 | |
7.0.4 | 2,100 | 9/8/2018 | |
7.0.3 | 1,960 | 9/8/2018 | |
7.0.2 | 2,316 | 8/31/2018 | |
7.0.0 | 2,080 | 8/29/2018 | |
7.0.0-pre1 | 1,784 | 8/22/2018 | |
6.5.0 | 2,271 | 6/12/2018 | |
6.4.11 | 2,317 | 4/13/2018 | |
6.4.11-pre1 | 2,105 | 4/6/2018 | |
6.4.10 | 2,273 | 3/18/2018 | |
6.4.9 | 2,230 | 3/18/2018 | |
6.4.8 | 2,197 | 3/18/2018 | |
6.4.7 | 2,279 | 3/16/2018 | |
6.4.6 | 2,478 | 2/14/2018 | |
6.4.5 | 2,296 | 2/3/2018 | |
6.4.3 | 2,276 | 11/14/2017 | |
6.4.2 | 2,359 | 8/11/2017 | |
6.4.1 | 2,182 | 8/10/2017 | |
6.4.0 | 2,260 | 7/25/2017 | |
6.3.0 | 2,279 | 6/9/2017 | |
6.2.2 | 2,287 | 5/20/2017 | |
6.2.1 | 2,398 | 4/23/2017 | |
6.2.0 | 2,204 | 4/22/2017 | |
6.1.4 | 2,201 | 4/17/2017 | |
6.1.3 | 2,897 | 4/3/2017 | |
6.1.2 | 2,169 | 4/1/2017 | |
6.1.1 | 2,132 | 4/1/2017 | |
6.1.0 | 2,153 | 3/31/2017 | |
6.0.1 | 2,273 | 3/19/2017 | |
6.0.0 | 2,076 | 3/18/2017 |
- Some components that used their own renderers weren't disposing the ones they replaced.
- Fix bug with mouse moving over composite controls such as the list box.