keymap.c 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. #include QMK_KEYBOARD_H
  2. extern keymap_config_t keymap_config;
  3. // Each layer gets a name for readability, which is then used in the keymap matrix below.
  4. // The underscores don't mean anything - you can have a layer called STUFF or any other name.
  5. // Layer names don't all need to be of the same length, obviously, and you can also skip them
  6. // entirely and just use numbers.
  7. #define _NP 0
  8. // Macro name shortcuts
  9. #define NUMPAD M(_NP)
  10. // Fillers to make layering more clear
  11. #define _______ KC_TRNS
  12. #define XXXXXXX KC_NO
  13. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  14. [_NP] = LAYOUT_numpad_4x4( /* Numpad */
  15. KC_P7, KC_P8, KC_P9, KC_PPLS, \
  16. KC_P4, KC_P5, KC_P6, \
  17. KC_P1, KC_P2, KC_P3, KC_PENT, \
  18. KC_P0, KC_PDOT \
  19. ),
  20. };
  21. const uint16_t PROGMEM fn_actions[] = {
  22. };
  23. void persistent_default_layer_set(uint16_t default_layer) {
  24. eeconfig_update_default_layer(default_layer);
  25. default_layer_set(default_layer);
  26. }
  27. const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
  28. {
  29. switch(id) {
  30. case _NP:
  31. if (record->event.pressed) {
  32. persistent_default_layer_set(1UL<<_NP);
  33. }
  34. break;
  35. }
  36. return MACRO_NONE;
  37. };