aboutsummaryrefslogtreecommitdiffstats
path: root/layouts/community/ortho_4x4/jotix/keymap.c
diff options
context:
space:
mode:
Diffstat (limited to 'layouts/community/ortho_4x4/jotix/keymap.c')
-rw-r--r--layouts/community/ortho_4x4/jotix/keymap.c91
1 files changed, 62 insertions, 29 deletions
diff --git a/layouts/community/ortho_4x4/jotix/keymap.c b/layouts/community/ortho_4x4/jotix/keymap.c
index 91d0ed74d..9035860da 100644
--- a/layouts/community/ortho_4x4/jotix/keymap.c
+++ b/layouts/community/ortho_4x4/jotix/keymap.c
@@ -1,41 +1,74 @@
#include QMK_KEYBOARD_H
-extern keymap_config_t keymap_config;
+enum layers {
+ _NUMPAD,
+ _GAMEPAD,
+ _FN
+};
-// Each layer gets a name for readability, which is then used in the keymap matrix below.
-// The underscores don't mean anything - you can have a layer called STUFF or any other name.
-// Layer names don't all need to be of the same length, obviously, and you can also skip them
-// entirely and just use numbers.
+static bool is_p0_pressed;
+static bool is_p7_pressed;
+static bool is_pmns_pressed;
-#define _NUMPAD 0
-#define _LOWER 1
-#define LOWER LT(_LOWER, KC_PENT)
+#define TGGAME TG(_GAMEPAD)
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
-/* Numpad
- * +-------+-------+-------+-------+
- * | 7 | 8 | 9 | - |
- * +-------+-------+-------+-------+
- * | 4 | 5 | 6 | + |
- * +-------+-------+-------+-------+
- * | 1 | 2 | 3 | / |
- * +-------+-------+-------+-------+
- * | | 0 | . | * |
- * +-------+-------+-------+-------+
- */
[_NUMPAD] = LAYOUT_ortho_4x4 (
- KC_P7, KC_P8, KC_P9, KC_PMNS,
- KC_P4, KC_P5, KC_P6, KC_PPLS,
- KC_P1, KC_P2, KC_P3, KC_PSLS,
- LOWER, KC_P0, KC_PDOT,KC_PAST
+ KC_P7, KC_P8, KC_P9, KC_PMNS,
+ KC_P4, KC_P5, KC_P6, KC_PPLS,
+ KC_P1, KC_P2, KC_P3, MO(_FN),
+ KC_P0, KC_PDOT,KC_PSLS,KC_PAST
),
-/* Lower */
-[_LOWER] = LAYOUT_ortho_4x4 (
- KC_NLCK,_______,_______,RESET ,
- _______,_______,_______,_______,
- _______,_______,_______,_______,
- _______,_______,_______,_______
+[_GAMEPAD] = LAYOUT_ortho_4x4 (
+ KC_5, KC_6, KC_7, KC_8,
+ KC_1, KC_2, KC_3, KC_4,
+ KC_Q, KC_W, KC_E, _______,
+ KC_A, KC_S, KC_D, KC_SPC
),
+
+[_FN] = LAYOUT_ortho_4x4 (
+ KC_PERC,KC_CIRC,KC_AMPR,KC_ASTR,
+ KC_EXLM,KC_AT, KC_HASH,KC_DLR,
+ KC_Z, KC_X, KC_C, _______,
+ KC_NLCK,_______,_______,TGGAME
+)
};
+
+layer_state_t layer_state_set_user(layer_state_t state) {
+#ifdef JOTPAD16_LEDS
+ writePin(JOTPAD16_LED1, (get_highest_layer(state) == _FN));
+ writePin(JOTPAD16_LED2, (get_highest_layer(state) == _GAMEPAD));
+#endif
+ return state;
+}
+
+bool led_update_user(led_t led_state) {
+ // NumLock allways on
+ if (!led_state.num_lock) {
+ tap_code(KC_NUMLOCK);
+ }
+ return true;
+}
+
+bool process_record_user(uint16_t keycode, keyrecord_t *record) {
+ switch (keycode) {
+ case KC_P0:
+ is_p0_pressed = record->event.pressed;
+ break;
+ case KC_P7:
+ is_p7_pressed = record->event.pressed;
+ break;
+ case KC_PMNS:
+ is_pmns_pressed = record->event.pressed;
+ break;
+ };
+ return true;
+}
+
+void matrix_scan_user(void) {
+ if (is_p0_pressed && is_p7_pressed && is_pmns_pressed) {
+ reset_keyboard();
+ }
+}