nanoFramework.Graphics 1.1.5

Prefix Reserved
There is a newer version of this package available.
See the version list below for details.
dotnet add package nanoFramework.Graphics --version 1.1.5
                    
NuGet\Install-Package nanoFramework.Graphics -Version 1.1.5
                    
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="nanoFramework.Graphics" Version="1.1.5" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="nanoFramework.Graphics" Version="1.1.5" />
                    
Directory.Packages.props
<PackageReference Include="nanoFramework.Graphics" />
                    
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 nanoFramework.Graphics --version 1.1.5
                    
#r "nuget: nanoFramework.Graphics, 1.1.5"
                    
#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 nanoFramework.Graphics@1.1.5
                    
#: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=nanoFramework.Graphics&version=1.1.5
                    
Install as a Cake Addin
#tool nuget:?package=nanoFramework.Graphics&version=1.1.5
                    
Install as a Cake Tool

Quality Gate Status Reliability Rating License NuGet #yourfirstpr Discord

nanoFramework logo


Welcome to the .NET nanoFramework Graphics repository

Build status

Component Build Status NuGet Package
nanoFramework.Graphics Build Status NuGet

Usage

Important:

  • This library is still work in progress. There may be breaking changes happening while work on this library progresses.
  • So far only SPI interface has been implemented.

Check the samples for more detailed usage.

Initializing the screen

It is important to understand that the driver will be loaded when the screen routing will be initialized from the managed code. Also keep in mind that most screens are actually smaller than the size the driver is capable of handling, also that the real screen can start at a position that is not the typical origin (0,0).

You must initialize the screen before being able to create a bitmap or display anything.

This code snippet works with the ESP32 WROVER KIT pinout, in this case, the screen size matches the driver size:


const int backLightPin = 5;
const int chipSelect = 22;
const int dataCommand = 21;
const int reset = 18;
const int screenWidth = 320;
const int screenHeight = 240;
DisplayControl.Initialize(new SpiConfiguration(1, chipSelect, dataCommand, reset, backLightPin), new ScreenConfiguration(0, 0, screenWidth, screenHeight), screenBufferSize);

This code snippet is for a M5 Stick where the screen size is smaller than the driver size and starts an offset position of X=26 and Y=1 coordinate:

int backLightPin = -1; // Not managed thru ESP32 but thru AXP192
int chipSelect = 5;
int dataCommand = 23;
int reset = 18;
Configuration.SetPinFunction(4, DeviceFunction.SPI1_MISO); // 4 is unused but necessary
Configuration.SetPinFunction(15, DeviceFunction.SPI1_MOSI);
Configuration.SetPinFunction(13, DeviceFunction.SPI1_CLOCK);
DisplayControl.Initialize(new SpiConfiguration(1, chipSelect, dataCommand, reset, backLightPin), new ScreenConfiguration(26, 1, 80, 160), 10 * 1024);

Note that depending on your target, especially for ESP32, you may have to setup the pins. Even if physically not used, the MISO pin must be setup to a valid pin.

As you can see it is possible as well not to define the backlight pin. It is the same for the rest pins. Both can be set to -1. Note that in most of the cases, both are connected and needed. In the case of the M5 Stick, the backlight pin is managed thru an AXP192. If you don't switch on the backlight pin, your screen will always be black. It is important to check how this pin can be switched on.

Feedback and documentation

For documentation, providing feedback, issues and finding out how to contribute please refer to the Home repo.

Join our Discord community here.

Credits

The list of contributors to this project can be found at CONTRIBUTORS.

License

The nanoFramework Class Libraries are licensed under the MIT license.

Code of Conduct

This project has adopted the code of conduct defined by the Contributor Covenant to clarify expected behaviour in our community. For more information see the .NET Foundation Code of Conduct.

.NET Foundation

This project is supported by the .NET Foundation.

Product Compatible and additional computed target framework versions.
.NET Framework net is compatible. 
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 nanoFramework.Graphics:

Package Downloads
nanoFramework.M5Core2

This package includes the nanoFramework.M5Core2 assembly for .NET nanoFramework C# projects.

nanoFramework.M5StickC

This package includes the nanoFramework.M5StickC assembly for .NET nanoFramework C# projects.

nanoFramework.M5Core

This package includes the nanoFramework.M5Core assembly for .NET nanoFramework C# projects.

nanoFramework.M5StickCPlus

This package includes the nanoFramework.M5StickCPlus assembly for .NET nanoFramework C# projects.

nanoFramework.Fire

This package includes the nanoFramework.Fire assembly for .NET nanoFramework C# projects.

GitHub repositories (3)

Showing the top 3 popular GitHub repositories that depend on nanoFramework.Graphics:

Repository Stars
nanoframework/Samples
🍬 Code samples from the nanoFramework team used in testing, proof of concepts and other explorational endeavours
nanoframework/nanoFramework.IoT.Device
📦 This repo includes .NET nanoFramework implementations for various sensors, chips, displays, hats and drivers
nanoframework/nanoFramework.M5Stack
:package: Board support package for M5Stack, M5StickC and M5StickCPlus for .NET nanoFramework
Version Downloads Last Updated
1.2.45 2,550 4/2/2025
1.2.44 211 4/2/2025
1.2.42 603 3/10/2025
1.2.41 210 3/10/2025
1.2.39 2,507 2/25/2025
1.2.35 1,678 2/4/2025
1.2.34 423 2/4/2025
1.2.33 956 1/30/2025
1.2.22 3,512 10/14/2024
1.2.21 1,675 9/26/2024
1.2.15 3,656 6/26/2024
1.2.10 1,455 5/13/2024
1.2.4 6,956 11/9/2023
1.2.2 246 11/9/2023
1.1.37 7,973 5/10/2023
1.1.34 385 5/5/2023
1.1.32 293 5/5/2023
1.1.30 294 5/5/2023
1.1.28 880 5/4/2023
1.1.25 454 4/18/2023
1.1.23 4,014 3/15/2023
1.1.21 1,168 3/10/2023
1.1.17 12,755 12/22/2022
1.1.13 15,412 10/11/2022
1.1.10 531 10/11/2022
1.1.8 2,292 10/7/2022
1.1.5 2,251 10/6/2022
1.0.3.6 30,266 7/29/2022
1.0.3.4 13,109 7/6/2022
1.0.3.2 27,388 6/2/2022
1.0.2 52,482 3/28/2022
1.0.2-preview.20 238 3/28/2022
1.0.2-preview.18 288 3/18/2022
1.0.2-preview.16 277 3/14/2022
1.0.2-preview.15 283 3/8/2022
1.0.2-preview.12 411 2/17/2022
1.0.2-preview.11 306 2/4/2022
1.0.2-preview.10 362 1/28/2022
1.0.2-preview.8 261 1/28/2022
1.0.2-preview.7 312 1/25/2022
1.0.2-preview.6 274 1/21/2022
1.0.2-preview.5 252 1/20/2022
1.0.2-preview.3 392 12/28/2021
1.0.1 1,426 12/4/2021
1.0.1-preview.24 258 12/4/2021
1.0.1-preview.22 256 12/3/2021
1.0.1-preview.20 261 12/3/2021
1.0.1-preview.18 258 12/2/2021
1.0.1-preview.16 263 12/2/2021
1.0.1-preview.14 262 12/2/2021
1.0.1-preview.12 261 12/1/2021
1.0.1-preview.11 267 12/1/2021
1.0.1-preview.8 601 10/22/2021
1.0.1-preview.7 330 10/19/2021
1.0.1-preview.5 294 10/17/2021
1.0.0 845 7/16/2021
1.0.0-preview.71 272 7/16/2021
1.0.0-preview.70 282 7/15/2021
1.0.0-preview.69 288 7/14/2021
1.0.0-preview.68 388 6/19/2021
1.0.0-preview.67 281 6/7/2021
1.0.0-preview.66 303 6/7/2021
1.0.0-preview.65 322 6/6/2021
1.0.0-preview.64 301 5/31/2021
1.0.0-preview.63 305 5/31/2021
1.0.0-preview.62 293 5/30/2021
1.0.0-preview.61 273 5/26/2021
1.0.0-preview.60 330 5/21/2021
1.0.0-preview.59 258 5/19/2021
1.0.0-preview.58 295 5/19/2021
1.0.0-preview.57 264 5/15/2021
1.0.0-preview.56 280 5/13/2021
1.0.0-preview.55 287 5/11/2021
1.0.0-preview.54 336 5/6/2021
1.0.0-preview.53 254 5/5/2021
1.0.0-preview.52 257 5/5/2021
1.0.0-preview.47 304 4/10/2021
1.0.0-preview.43 377 3/21/2021
1.0.0-preview.41 432 3/2/2021
1.0.0-preview.38 406 1/6/2021
1.0.0-preview.36 887 12/29/2020
1.0.0-preview.34 306 12/28/2020
1.0.0-preview.32 381 12/22/2020
1.0.0-preview.27 368 12/11/2020
1.0.0-preview.25 387 10/21/2020
1.0.0-preview.23 384 10/21/2020
1.0.0-preview.21 360 10/20/2020
1.0.0-preview.19 432 10/1/2020
1.0.0-preview.17 405 7/2/2020
1.0.0-preview.15 381 7/1/2020
1.0.0-preview.13 415 6/30/2020
1.0.0-preview.11 389 6/16/2020
1.0.0-preview.7 392 6/12/2020
1.0.0-preview.6 366 9/19/2020
1.0.0-preview.5 398 6/12/2020
1.0.0-preview.4 367 9/19/2020
1.0.0-preview.2 381 9/19/2020
1.0.0-preview.1 417 5/23/2020