Archived
1
0
This repo is archived. You can view files and clone it, but cannot push or open issues or pull requests.
keybrd/tutorials/keybrd_3a_multi-layerHold/keybrd_3a_multi-layerHold.ino

124 lines
3.7 KiB
Arduino
Raw Normal View History

2016-09-20 01:46:03 +00:00
/* keybrd_3a_multi-layerHold.ino
2016-05-09 14:05:08 +00:00
This sketch:
2016-07-18 02:03:03 +00:00
is firmware for a simple 2-layer keyboard
2016-05-09 14:05:08 +00:00
runs on the first two rows and columns of a breadboard keyboard
| Layout | **0** | **1** |
|:------:|-------|-------|
| **0** | a - | b = |
| **1** | fn | shift |
2016-05-09 14:05:08 +00:00
Each cell in the table's body represents a key.
Each element in a cell represents a scancode or layer code.
The keys in row 0 have two characters each, one character for each layer.
Letters 'a' and 'b' are on the normal layer. Symbols '-' and '=' are on the fn layer.
2016-09-28 20:37:40 +00:00
"fn" is a layer key. Holding the fn key down makes it the active layer.
Releasing the fn key restores the normal layer.
2016-05-09 14:05:08 +00:00
*/
// ################## GLOBAL ###################
// ================= INCLUDES ==================
2016-07-18 02:03:03 +00:00
//Keys
2016-05-09 14:05:08 +00:00
#include <Code_Sc.h>
2016-05-28 21:16:32 +00:00
#include <LayerState.h>
2016-05-09 14:05:08 +00:00
#include <Code_LayerHold.h>
#include <Key_LayeredKeys.h>
2016-05-09 14:05:08 +00:00
//Matrix
#include <Row.h>
#include <Scanner_uC.h>
2016-07-18 02:03:03 +00:00
#include <ScanDelay.h>
2016-05-09 14:05:08 +00:00
2016-07-18 02:03:03 +00:00
// ============ SPEED CONFIGURATION ============
ScanDelay scanDelay(9000);
2016-05-09 14:05:08 +00:00
// ================== SCANNER ==================
2016-07-18 02:03:03 +00:00
uint8_t readPins[] = {14, 15};
uint8_t readPinCount = sizeof(readPins)/sizeof(*readPins);
Scanner_uC scanner(LOW, readPins, readPinCount);
2016-05-09 14:05:08 +00:00
// =================== CODES ===================
2016-07-18 02:03:03 +00:00
/* ---------------- LAYER CODE -----------------
2016-09-20 01:46:03 +00:00
enum assigns layerId numbers to the layers.
NORMAL=0 and FN=1.
2016-05-09 14:05:08 +00:00
*/
2016-09-22 13:46:50 +00:00
enum layerIds { NORMAL, FN };
2016-07-18 02:03:03 +00:00
/*
layerState keeps track of the active layer.
2016-05-09 14:05:08 +00:00
*/
2016-05-28 21:16:32 +00:00
LayerState layerState;
2016-07-18 02:03:03 +00:00
2016-05-09 14:05:08 +00:00
/*
Code_LayerHold constructor parameters are: layerId, LayerState.
layerState is assigned to layer FN.
layerState also has a default layer 0, which implicitly is layer NORMAL.
FN is the active layer while the key is held down.
In this example, when l_fn is pressed, it tells layerState to change the active layer to FN.
When l_fn is released, it tells layerState that layer FN is released,
and layerState restores the active layer to default layerId 0 (NORMAL).
2016-05-09 14:05:08 +00:00
*/
2016-05-28 21:16:32 +00:00
Code_LayerHold l_fn(FN, layerState);
2016-05-09 14:05:08 +00:00
// ---------------- SCAN CODES -----------------
Code_Sc s_a(KEY_A);
Code_Sc s_b(KEY_B);
Code_Sc s_minus(KEY_MINUS);
Code_Sc s_equal(KEY_EQUAL);
2016-05-09 14:05:08 +00:00
Code_Sc s_shift(MODIFIERKEY_LEFT_SHIFT);
2016-07-18 02:03:03 +00:00
/* =================== KEYS ====================
Here we pack Codes into keys.
ptrsKeys_00[] contains all the Code objects of the key, one Code object per layer.
2016-05-09 14:05:08 +00:00
2016-07-18 02:26:00 +00:00
The Key object names in this sketch start with a "k_" followed by row-column coordinates.
2016-05-09 14:05:08 +00:00
*/
Key* const ptrsKeys_00[] = { &s_a, &s_minus };
Key_LayeredKeys k_00(ptrsKeys_00);
2016-05-09 14:05:08 +00:00
Key* const ptrsKeys_01[] = { &s_b, &s_equal };
Key_LayeredKeys k_01(ptrsKeys_01);
2016-07-18 02:03:03 +00:00
/*
Key_LayeredKeys has a reference to layerState.
2016-05-09 14:05:08 +00:00
*/
LayerStateInterface& Key_LayeredKeys::refLayerState = layerState;
2016-05-09 14:05:08 +00:00
2016-07-18 02:03:03 +00:00
/* HOW LAYERED OBJECTS WORK
When a Key_LayeredKeys object is pressed, it gets the active layer id from layerState.
It then uses the layer id as an array index to call the Code of the active layer.
The Code object then sends its scancode over USB.
2016-05-09 14:05:08 +00:00
*/
2016-07-18 02:03:03 +00:00
/* =================== ROWS ====================
Here we pack Key pointers into Row objects.
2016-05-09 14:05:08 +00:00
Rows are composed of a Key-pointer array.
2016-05-09 14:05:08 +00:00
Codes are a kind of Key that only have one layer.
Thus rows can contain a mix of codes and multi-layered keys (subtype polymorphism).
In this example, Key-pointer arrays contain both Code pointers (&l_fn and &s_shift)
and Key pointers (&k_00 and &k_01).
2016-05-09 14:05:08 +00:00
*/
Key* const ptrsKeys_0[] = { &k_00, &k_01 };
uint8_t keyCount_0 = sizeof(ptrsKeys_0)/sizeof(*ptrsKeys_0);
Row row_0(scanner, 0, ptrsKeys_0, keyCount_0);
2016-05-09 14:05:08 +00:00
Key* const ptrsKeys_1[] = { &l_fn, &s_shift };
uint8_t keyCount_1 = sizeof(ptrsKeys_1)/sizeof(*ptrsKeys_1);
Row row_1(scanner, 1, ptrsKeys_1, keyCount_1);
2016-05-09 14:05:08 +00:00
// ################### MAIN ####################
void setup()
{
Keyboard.begin();
}
void loop()
{
2016-07-18 02:03:03 +00:00
row_0.process();
row_1.process();
scanDelay.delay();
2016-05-09 14:05:08 +00:00
}