nanoFramework.Iot.Device.KeyMatrix
                               
                            
                                1.2.907
                            
                        
                            
                                
                                
                                    Prefix Reserved
                                
                            
                    dotnet add package nanoFramework.Iot.Device.KeyMatrix --version 1.2.907
NuGet\Install-Package nanoFramework.Iot.Device.KeyMatrix -Version 1.2.907
<PackageReference Include="nanoFramework.Iot.Device.KeyMatrix" Version="1.2.907" />
<PackageVersion Include="nanoFramework.Iot.Device.KeyMatrix" Version="1.2.907" />
<PackageReference Include="nanoFramework.Iot.Device.KeyMatrix" />
paket add nanoFramework.Iot.Device.KeyMatrix --version 1.2.907
#r "nuget: nanoFramework.Iot.Device.KeyMatrix, 1.2.907"
#:package nanoFramework.Iot.Device.KeyMatrix@1.2.907
#addin nuget:?package=nanoFramework.Iot.Device.KeyMatrix&version=1.2.907
#tool nuget:?package=nanoFramework.Iot.Device.KeyMatrix&version=1.2.907
Key Matrix
An M×N key matrix driver.
(M is number of output pins and N is number of input pins.)
Documentation
These key matrices look like this:
This is a 4×4 matrix. And here is the schematic
You can connect any M×N key matrix, theoretically, by using M+N GPIO pins.
You can also use any compatible GPIO controller like Mcp23xxx instead of native controller.
Usage
You need to create 2 lists of int, one for the input and one for the output.
int[] outputs = new int[] { 26, 19, 13, 6 };
int[] inputs = new int[] { 21, 20, 16, 12 };
KeyMatrix mk = new KeyMatrix(outputs, inputs, TimeSpan.FromMilliseconds(20));
You can use as well any GpioController like the MCP23017 in the following example
var settings = new System.Device.I2c.I2cConnectionSettings(1, 0x20);
var i2cDevice = System.Device.I2c.I2cDevice.Create(settings);
var mcp23017 = new Iot.Device.Mcp23xxx.Mcp23017(i2cDevice);
GpioController gpio = new GpioController(PinNumberingScheme.Logical, mcp23017);
int[] outputs = new int[] { 26, 19, 13, 6 };
int[] inputs = new int[] { 21, 20, 16, 12 };
KeyMatrix mk = new KeyMatrix(outputs, inputs, TimeSpan.FromMilliseconds(20), gpio, true);
Read on Key
To read a key, just the ReadKey function:
KeyMatrixEvent? key = mk.ReadKey();
KeyMatrixEvent contains the event that happened. Please note that ReadKey is blocked up to the moment an event is detected.
Event based approach
KeyMatrix supports events. Just subscribe to the event and have a function to handle the events:
Debug.WriteLine("This will now start listening to events and display them for 60 seconds.");
mk.KeyEvent += KeyMatrixEventReceived;
mk.StartListeningKeyEvent();
Thread.Sleep(60000);
mk.StopListeningKeyEvent();
void KeyMatrixEventReceived(object sender, KeyMatrixEvent keyMatrixEvent)
{
    // Do something here, you have an event!
}
Tips and tricks
- Using diodes(eg. 1N4148) for each button prevents "ghosting" or "masking" problem.
- Input pins need pull-down resistors connect to ground if your MCU doesn't have it. So you need to have a pull-down on a the MCU for example.
- If your key matrix doesn't work well, try to swap output and input pins. Some includes diodes and if they are used the reverse way won't work properly.
Key Matrix Samples
This shows how to connect the matrix.
Important: Please make you don't forget to place a pull down on the input matrix.
Connection using on-board GPIO
Connection using MCP23017
| Product | Versions Compatible and additional computed target framework versions. | 
|---|---|
| .NET Framework | net is compatible. | 
- 
                                                - nanoFramework.CoreLibrary (>= 1.17.11)
- nanoFramework.Runtime.Events (>= 1.11.32)
- nanoFramework.System.Device.Gpio (>= 1.1.57)
 
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.2.907 | 168 | 10/2/2025 | 
| 1.2.864 | 254 | 4/2/2025 | 
| 1.2.852 | 274 | 3/11/2025 | 
| 1.2.822 | 201 | 2/26/2025 | 
| 1.2.772 | 201 | 2/4/2025 | 
| 1.2.755 | 206 | 1/31/2025 | 
| 1.2.737 | 179 | 1/13/2025 | 
| 1.2.696 | 195 | 12/16/2024 | 
| 1.2.673 | 195 | 10/23/2024 | 
| 1.2.631 | 184 | 8/28/2024 | 
| 1.2.570 | 214 | 6/14/2024 | 
| 1.2.560 | 204 | 5/29/2024 | 
| 1.2.548 | 179 | 5/15/2024 | 
| 1.2.436 | 292 | 11/10/2023 | 
| 1.2.329 | 271 | 5/26/2023 | 
| 1.2.313 | 234 | 5/12/2023 | 
| 1.2.297 | 257 | 5/3/2023 | 
| 1.2.203 | 427 | 12/28/2022 | 
| 1.2.141 | 498 | 10/25/2022 | 
| 1.2.122 | 552 | 10/12/2022 | 
| 1.2.114 | 477 | 10/8/2022 | 
| 1.2.95 | 495 | 9/22/2022 | 
| 1.2.87 | 569 | 9/15/2022 | 
| 1.2.73 | 518 | 9/8/2022 | 
| 1.1.113.2032 | 515 | 6/23/2022 | 
| 1.1.58.10097 | 555 | 5/23/2022 | 
| 1.1.1 | 574 | 4/14/2022 | 
| 1.0.300 | 519 | 3/31/2022 | 
| 1.0.277-preview.125 | 217 | 3/25/2022 | 
| 1.0.277-preview.110 | 218 | 3/18/2022 | 
| 1.0.277-preview.105 | 220 | 3/15/2022 | 
| 1.0.277-preview.98 | 224 | 3/8/2022 | 
| 1.0.277-preview.77 | 218 | 2/18/2022 | 
| 1.0.277-preview.41 | 232 | 1/28/2022 | 
| 1.0.277-preview.32 | 236 | 1/27/2022 | 
| 1.0.277-preview.17 | 240 | 1/24/2022 | 
| 1.0.277-preview.15 | 222 | 1/21/2022 | 
| 1.0.277-preview.13 | 230 | 1/21/2022 | 
| 1.0.277-preview.1 | 229 | 1/11/2022 | 
| 1.0.259 | 417 | 12/9/2021 | 
| 1.0.218 | 304 | 10/18/2021 | 
| 1.0.155 | 427 | 8/31/2021 | 
| 1.0.135 | 408 | 7/16/2021 | 
| 1.0.134 | 280 | 7/15/2021 | 
| 1.0.133 | 296 | 7/14/2021 | 
| 1.0.129 | 266 | 7/6/2021 | 
| 1.0.125 | 298 | 7/5/2021 | 
| 1.0.121 | 308 | 6/29/2021 | 
| 1.0.119 | 331 | 6/28/2021 | 
| 1.0.33 | 275 | 5/24/2021 |