keybrd library is an open source library for creating custom-keyboard firmware.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
This repo is archived. You can view files and clone it, but cannot push or open issues/pull-requests.

keybrd_3e_sublayerNestedScSc.ino 2.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. /* keybrd_3e_sublayerNestedScSc.ino
  2. This sketch:
  3. is firmware for layout two layers plus one sublayer.
  4. runs on the first three columns of a breadboard keyboard
  5. | Layout | **0** | **1** | **2** |
  6. |:------:|:-----:|:-----:|:-----:|
  7. | **0** | a - 1 | b = | c Num |
  8. | **1** | Alpha | Sym | Enter |
  9. */
  10. // ################## GLOBAL ###################
  11. // ================= INCLUDES ==================
  12. //Keys
  13. #include <Code_Sc.h>
  14. #include <LayerState.h>
  15. #include <Code_LayerLock.h>
  16. #include <Code_LayerHold.h>
  17. #include <Key_LayeredKeys.h>
  18. #include <Key_LayeredScSc.h>
  19. //Matrix
  20. #include <Row.h>
  21. #include <Scanner_uC.h>
  22. #include <ScanDelay.h>
  23. // ============ SPEED CONFIGURATION ============
  24. ScanDelay scanDelay(9000);
  25. // ================== SCANNER ==================
  26. uint8_t readPins[] = {14, 15, 16};
  27. uint8_t readPinCount = sizeof(readPins)/sizeof(*readPins);
  28. Scanner_uC scanner(LOW, readPins, readPinCount);
  29. // =================== CODES ===================
  30. // ---------------- LAYER GROUP ----------------
  31. enum layerIds { ALPHA, SYM };
  32. LayerState groupState;
  33. Code_LayerLock l_normal(ALPHA, groupState);
  34. Code_LayerLock l_sym(SYM, groupState);
  35. /*
  36. groupState manages a layer group delineated by all layers that are in Key_LayeredKeys objects.
  37. */
  38. LayerStateInterface& Key_LayeredKeys::refLayerState = groupState;
  39. // --------------- LAYER SUBGROUP --------------
  40. enum subLayers { SUBSYM, SUBNUM };
  41. LayerState subgroupState;
  42. Code_LayerHold l_num(SUBNUM, subgroupState);
  43. /*
  44. subgroupState manages a layer group delineated by all layers that are in Key_LayeredScSc objects.
  45. */
  46. LayerStateInterface& Key_LayeredScSc::refLayerState = subgroupState;
  47. // ----------------- SCANCODES -----------------
  48. Code_Sc s_a(KEY_A);
  49. Code_Sc s_b(KEY_B);
  50. Code_Sc s_c(KEY_C);
  51. Code_Sc s_minus(KEY_MINUS);
  52. Code_Sc s_equal(KEY_EQUAL);
  53. Code_Sc s_enter(KEY_ENTER);
  54. Code_Sc s_1(KEY_1);
  55. /* =================== KEYS ====================
  56. k_sub00 contains codes for sub layers SUBSYM and SUBNUM.
  57. k_sub00 gets it's active layer from subgroupState.
  58. */
  59. Key_LayeredScSc sub_00(KEY_MINUS, KEY_1);
  60. /*
  61. k_00 contains code and key for layers ALPHA and SYM.
  62. k_00 gets it's active layer from groupState.
  63. k_sub00 is nested in layer SYM.
  64. */
  65. Key* const ptrsKeys_00[] = { &s_a, &sub_00 };
  66. Key_LayeredKeys k_00(ptrsKeys_00);
  67. Key* const ptrsKeys_01[] = { &s_b, &s_equal };
  68. Key_LayeredKeys k_01(ptrsKeys_01);
  69. Key* const ptrsKeys_02[] = { &s_c, &l_num };
  70. Key_LayeredKeys k_02(ptrsKeys_02);
  71. // =================== ROWS ====================
  72. Key* const ptrsKeys_0[] = { &k_00, &k_01, &k_02 };
  73. uint8_t keyCount_0 = sizeof(ptrsKeys_0)/sizeof(*ptrsKeys_0);
  74. Row row_0(scanner, 0, ptrsKeys_0, keyCount_0);
  75. Key* const ptrsKeys_1[] = { &l_normal, &l_sym, &s_enter };
  76. uint8_t keyCount_1 = sizeof(ptrsKeys_1)/sizeof(*ptrsKeys_1);
  77. Row row_1(scanner, 1, ptrsKeys_1, keyCount_1);
  78. // ################### MAIN ####################
  79. void setup()
  80. {
  81. }
  82. void loop()
  83. {
  84. row_0.process();
  85. row_1.process();
  86. scanDelay.delay();
  87. }