Kiibohd Controller
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.

matrix_template.h 5.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. /* Copyright (C) 2011,2014-2015 by Jacob Alexander
  2. *
  3. * Permission is hereby granted, free of charge, to any person obtaining a copy
  4. * of this software and associated documentation files (the "Software"), to deal
  5. * in the Software without restriction, including without limitation the rights
  6. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  7. * copies of the Software, and to permit persons to whom the Software is
  8. * furnished to do so, subject to the following conditions:
  9. *
  10. * The above copyright notice and this permission notice shall be included in
  11. * all copies or substantial portions of the Software.
  12. *
  13. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  14. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  15. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  16. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  17. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  18. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  19. * THE SOFTWARE.
  20. */
  21. #pragma once
  22. // ----- Includes -----
  23. // Compiler Includes
  24. #include <stdint.h>
  25. // ----- Scan Mode Setting (See matrix_scan.h for more details) -----
  26. #define scanMode scanDual
  27. // ----- Key Settings -----
  28. // -- Example for scanCol --
  29. /*
  30. #define KEYBOARD_KEYS 16 // # of keys
  31. #define MAX_ROW_SIZE 16 // # of keys in the largest row
  32. #define MAX_COL_SIZE 1 // # of keys in the largest column
  33. */
  34. // -- Example for scanRow --
  35. /*
  36. #define KEYBOARD_KEYS 16 // # of keys
  37. #define MAX_ROW_SIZE 1 // # of keys in the largest row
  38. #define MAX_COL_SIZE 16 // # of keys in the largest column
  39. */
  40. // -- Example for scanRow_powrCol, scanCol_powrRow, and scanDual --
  41. /*
  42. #define KEYBOARD_KEYS 69 // # of keys
  43. #define MAX_ROW_SIZE 8 // # of keys in the largest row
  44. #define MAX_COL_SIZE 9 // # of keys in the largest column
  45. */
  46. // ----- Matrix Configuration -----
  47. static const uint8_t matrix_pinout[][MAX_ROW_SIZE + 1] = {
  48. // Just layout the matrix by rows and columns
  49. // Usually you'll want to set the scanMode above to scanDual or scanCol_powrRow/scanRow_powrCol
  50. // The mode allows for optimization in the kind of scanning algorithms that are done
  51. //
  52. // The key numbers are used to translate into the keymap table (array) (and always start from 1, not 0).
  53. // Thus if a row doesn't use all the key positions, you can denote it as 0, which will be ignored/skipped on each scan
  54. // See the keymap.h file for the various preconfigured arrays.
  55. // Scan Mode | Col 1 | Col 2 | Col 3 | Col 4 | Col 5 | ...
  56. // -------------------------------------------------------
  57. // Row 1 | Key 1 Key 7 Key32 ...
  58. // Row 2 | Key 3 Key92 ...
  59. // Row 3 | Key23 ...
  60. // Row 4 | ...
  61. // Row 5 |
  62. // ... |
  63. // -- scanCol Example --
  64. /*
  65. { scanMode, pinF0, pinF4, pinB7, pinD3, pinF5, pinF1, pinD1, pinD2, pinF6, pinF7, pinB2, pinD0, pinB0, pinB6, pinB1, pinB3 },
  66. { pinNULL, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16 },
  67. */
  68. // -- scanRow Example --
  69. /*
  70. { scanMode, pinNULL },
  71. { pinF0, 1 },
  72. { pinF4, 2 },
  73. { pinB7, 3 },
  74. { pinD3, 4 },
  75. { pinF5, 5 },
  76. { pinF1, 6 },
  77. { pinD1, 7 },
  78. { pinD2, 8 },
  79. { pinF6, 9 },
  80. { pinF7, 10 },
  81. { pinB2, 11 },
  82. { pinD0, 12 },
  83. { pinB0, 13 },
  84. { pinB6, 14 },
  85. { pinB1, 15 },
  86. { pinB3, 16 },
  87. */
  88. // -- scanRow_powrCol Example and scanCol_powrRow Example --
  89. // The example is the same, as the difference is whether the row or col is powered, and the other is used to detect the signal
  90. /*
  91. { scanMode, pinF0, pinF4, pinB7, pinD3, pinF5, pinF1, pinD1, pinD2 },
  92. { pinF6, 1, 2, 3, 4, 5, 6, 7, 8 },
  93. { pinF7, 9, 10, 11, 12, 13, 14, 15, 16 },
  94. { pinB2, 17, 20, 30, 40, 50, 60, 59, 38 },
  95. { pinD0, 18, 21, 31, 41, 51, 61, 67, 39 },
  96. { pinB0, 19, 22, 32, 42, 52, 62, 68, 47 },
  97. { pinB6, 27, 23, 33, 43, 53, 63, 69, 48 },
  98. { pinB1, 28, 24, 34, 44, 54, 64, 0, 49 }, // 0 signifies no key at that location
  99. { pinB3, 29, 25, 35, 45, 55, 65, 0, 57 },
  100. { pinA0, 37, 26, 36, 46, 56, 66, 0, 58 },
  101. */
  102. // -- scanDual Example --
  103. // The example is the same as the previous one, but uses both columns and rows to power and detect, needed for non-NKRO matrices.
  104. /*
  105. { scanMode, pinF0, pinF4, pinB7, pinD3, pinF5, pinF1, pinD1, pinD2 },
  106. { pinF6, 1, 2, 3, 4, 5, 6, 7, 8 },
  107. { pinF7, 9, 10, 11, 12, 13, 14, 15, 16 },
  108. { pinB2, 17, 20, 30, 40, 50, 60, 59, 38 },
  109. { pinD0, 18, 21, 31, 41, 51, 61, 67, 39 },
  110. { pinB0, 19, 22, 32, 42, 52, 62, 68, 47 },
  111. { pinB6, 27, 23, 33, 43, 53, 63, 69, 48 },
  112. { pinB1, 28, 24, 34, 44, 54, 64, 0, 49 }, // 0 signifies no key at that location
  113. { pinB3, 29, 25, 35, 45, 55, 65, 0, 57 },
  114. { pinA0, 37, 26, 36, 46, 56, 66, 0, 58 },
  115. */
  116. };