TheFabulousCube.ConsoleColors
1.8.1
dotnet add package TheFabulousCube.ConsoleColors --version 1.8.1
NuGet\Install-Package TheFabulousCube.ConsoleColors -Version 1.8.1
<PackageReference Include="TheFabulousCube.ConsoleColors" Version="1.8.1" />
paket add TheFabulousCube.ConsoleColors --version 1.8.1
#r "nuget: TheFabulousCube.ConsoleColors, 1.8.1"
// Install TheFabulousCube.ConsoleColors as a Cake Addin #addin nuget:?package=TheFabulousCube.ConsoleColors&version=1.8.1 // Install TheFabulousCube.ConsoleColors as a Cake Tool #tool nuget:?package=TheFabulousCube.ConsoleColors&version=1.8.1
Cube's Console Colors makes adding color to your console output easier!
Tired of long boring walls of scrolling text? Need to call attention to something important?
Adding a splash of color to your console output makes important events stand out!
There are a couple of ways to add colors to the console output, but neither one is very user friendly.
The most common way is setting Console.ForegroundColor
and Console.BackgroundColor
. Just don't forget to Console.ResetColor()
afterwards or all the rest of the output is colored.
Here's an example:
Console.ForegroundColor = ConsoleColor.Red;
Console.BackgroundColor = ConsoleColor.DarkRed;
Console.WriteLine("Error: Something failed to happen");
Console.ResetColor();
Want to just color the word "Error:"? Totally possible!
Break the output up, set the color, Write (don't WriteLine yet) the word "Error:", reset the colors, then WriteLine the rest of the error.
Pretty quickly the Console output becomes complicated and getting that right takes focus away from the actual code!
You can also use ANSI Escape codes!
Console.WriteLine($"\u001B[91;41mError: Something failed to happen\u001B[0m");
Changing this to the single word version is much easier:
Console.WriteLine($"\u001B[91;41m Error: \u001B[0m Something failed to happen");
Is it maintainable? Not really. What color is '91'? Why is there a '41'? Do you remember the syntax? You can look it up, but how much time do you want to spend looking up syntax for logging???
Cube's Console Colors to the rescue!
I'm still using the ANSI escape color codes, that's the way to go. But they're self describing now! It's much easier to read and far quicker to write!
(Unless you spend an unusual amount of time using colored output in Minecraft. It uses the same escape codes.)
The above lines would look like this:
Console.WriteLine(Color.Red($"Error: Something failed to happen").WithDarkRed());
Console.WriteLine($"{Color.Red("Error:").WithDarkRed()} Something failed to happen");
and display:
Now if you decide later you don't want the background color, could you figure out how to remove that? Sure you could!
If you wanted to add a 'Success' message, could you figure out the syntax? I bet you could!
Here are some examples:
Note: The background effect doesn't overwrite the global setting of Console.BackgroundColor
How to use
This library adds some methods to help make adding color to the console output easier. These methods return the string wrapped in the ANSI escape codes for you. Since the escape codes work directly on the string, the color changes are 'local' to each line. If you want to set the whole background or default text color, you can still do that.
Foreground colors (text)
The foreground colors are methods that take in a string and return the same string wrapped in the ANSI escape codes.
Simply pass your text into a color method:
Console.WriteLine(Color.Blue("This prints the text in Blue"));
The background is whatever Console.Background is set to.
You don't have to use the entire string. To color a single word, interpolate the command in the string:
Console.WriteLine($"This prints the word {Color.Yellow("'Yellow'")} in Yellow");
The rest of the line is whatever the console is set to.
The Color method also takes in a background color so you can do both at the same time:
Console.WriteLine($"There are {Color.Blue("blue skys", ConsoleColor.White)} ahead");
This is limited to the standard ConsoleColors
Not enough colors?
There's a Color.RGB() method that takes in the string to color, followed by red, green, and blue values. If you know the hexadecimal, prefix it with "0x"
Console.WriteLine(Color.RGB("Let's try something new!", 255, 45, 45));
Console.WriteLine(Color.RGB("Let's try something new!", 0x2d, 0xff, 0x2d));
Console.WriteLine(Color.RGB("Let's try something new!", 45, 45, 255));
This is still experimental and doesn't play well with nesting.
Background colors
The backgound colors are string extension methods and are prefixed by ".with###()" so just add the background color you want to the end of the string:
Console.WriteLine("The other way around string method".WithBlack());
You can also use this to highlight specific words:
Console.WriteLine($"This is {"highlighted".WithDarkGreen()} in dark green");
Mixing foreground/background and nesting
When nested, the most immediate commands win out, like most nesting.
You can freely mix and match as much as you want:
Console.WriteLine(Color.DarkRed($" This is pretty {Color.Red("complicated", ConsoleColor.DarkRed)} nesting, but {Color.DarkGreen("perfectly")} fine").WithWhite());
Styling and convenience methods
There are also some styling methods included
Support for ANSI escape codes around styling is a little spotty. They may or may not work well for your application. The 'bold' feature really only works well on dark colors, and all it does is translate them to the lighter version of the same color.
Bold:
Console.WriteLine(Color.DarkCyan($" The {Color.Bold(" bold feature ")} really only works on dark colors, it just changes them to the {"light".WithBold()} version"));
Console.WriteLine(Color.Magenta($" The {Color.Bold("bold feature")} doesn't show any difference for already light colors"));
Underline:
Console.WriteLine($" The {Color.Underline("underline")} can be used for emphasis. There are {"both formats".WithUnderline()} of the styling methods");
Inverse: (swaps the background and foreground colors, kinda neat!)
Console.WriteLine($" You can {Color.Invert(" invert a section of text ")} in a line");
Convenience methods:
Success, writes green on dark green background:
Console.WriteLine($" The operation was a {Color.Success("success")}, please proceed");
Warning, writes yellow on dark yellow background:
Console.WriteLine($" Trouble {Color.Warning("parsing file")}, you may want to check results");
Failure, writes red on dark red background:
Console.WriteLine($" Parsing the arguments {Color.Failure("failed")}, check the logs");
Pro tip!
Adding a static using lets you simplify coding even more:
using static ConsoleColors.Color;
.........
Console.WriteLine(DarkRed($"This is a simplified version with {Underline("underline")}. It makes typing a little easier."));
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. 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 was computed. 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. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.8.1 | 189 | 9/3/2023 |
Initial release
Color.RGB() is still experimental