From 76b07511ef8a902141695c88fe5faaf361bcdeec Mon Sep 17 00:00:00 2001 From: Fabrice Mouhartem Date: Sun, 13 Jul 2025 12:23:39 +0200 Subject: [PATCH] Add xbows/nature keyboard --- .../xbows/nature/keymaps/custom/config.h | 22 +++++++++++++++ .../xbows/nature/keymaps/custom/keymap.c | 27 +++++++++++++++++++ .../xbows/nature/keymaps/custom/keymap.h | 13 +++++++++ 3 files changed, 62 insertions(+) create mode 100644 keyboards/xbows/nature/keymaps/custom/config.h create mode 100644 keyboards/xbows/nature/keymaps/custom/keymap.c create mode 100644 keyboards/xbows/nature/keymaps/custom/keymap.h diff --git a/keyboards/xbows/nature/keymaps/custom/config.h b/keyboards/xbows/nature/keymaps/custom/config.h new file mode 100644 index 0000000..66437d9 --- /dev/null +++ b/keyboards/xbows/nature/keymaps/custom/config.h @@ -0,0 +1,22 @@ +#pragma once +// Set the mouse settings to a comfortable speed/accuracy trade-off, +// assuming a screen refresh rate of 60 Htz or higher +// The default is 50. This makes the mouse ~3 times faster and more accurate +#define MOUSEKEY_INTERVAL 16 +// The default is 20. Since we made the mouse about 3 times faster with the previous setting, +// give it more time to accelerate to max speed to retain precise control over short distances. +#define MOUSEKEY_TIME_TO_MAX 40 +// The default is 300. Let's try and make this as low as possible while keeping the cursor responsive +#define MOUSEKEY_DELAY 100 +// It makes sense to use the same delay for the mouseweel +#define MOUSEKEY_WHEEL_DELAY 100 +// The default is 100 +#define MOUSEKEY_WHEEL_INTERVAL 50 +// The default is 40 +#define MOUSEKEY_WHEEL_TIME_TO_MAX 100 + +// Pick good defaults for enabling homerow modifiers +#define TAPPING_TERM 150 +// #define PERMISSIVE_HOLD +// #define QUICK_TAP_TERM 0 +#define PERMISSIVE_HOLD_PER_KEY diff --git a/keyboards/xbows/nature/keymaps/custom/keymap.c b/keyboards/xbows/nature/keymaps/custom/keymap.c new file mode 100644 index 0000000..393e811 --- /dev/null +++ b/keyboards/xbows/nature/keymaps/custom/keymap.c @@ -0,0 +1,27 @@ +#include QMK_KEYBOARD_H +#if __has_include("keymap.h") +# include "keymap.h" +#endif + + +/* THIS FILE WAS GENERATED! + * + * This file was generated by qmk json2c. You may or may not want to + * edit it directly. + */ + +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { + [0] = LAYOUT(KC_ESC, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_DEL, KC_PSCR, KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, KC_RBRC, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_HOME, KC_END, KC_PGUP, LT(1,KC_CAPS), LGUI_T(KC_A), LALT_T(KC_S), LSFT_T(KC_D), LCTL_T(KC_F), KC_G, KC_BSPC, KC_H, LCTL_T(KC_J), LSFT_T(KC_K), LALT_T(KC_L), LGUI_T(KC_SCLN), KC_QUOT, TO(1), KC_PGDN, KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_ENT, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_BSLS, KC_RCTL, KC_LCTL, KC_LGUI, KC_LALT, LT(2,KC_SPC), LT(3,KC_ENT), RALT_T(KC_ESC), LT(2,KC_TAB), RCTL(KC_RSFT), MO(1), KC_LEFT, KC_DOWN, KC_UP, KC_RGHT), + [1] = LAYOUT(QK_BOOT, KC_MUTE, KC_VOLD, KC_VOLU, RGB_M_P, UG_VALD, UG_VALU, UG_PREV, UG_NEXT, UG_TOGG, UG_SPDD, UG_SPDU, UG_HUEU, NK_TOGG, EE_CLR, KC_TRNS, KC_TRNS, KC_NUM, KC_PSLS, KC_PAST, KC_PMNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_NUM, KC_CALC, KC_TRNS, KC_P7, KC_P8, KC_P9, KC_PPLS, KC_GRV, MS_BTN3, KC_TRNS, KC_TRNS, MS_WHLU, KC_PGUP, KC_TRNS, KC_INS, KC_HOME, KC_TRNS, TO(0), KC_P4, KC_P5, KC_P6, KC_PCMM, KC_TRNS, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT, MS_WHLD, KC_PGDN, TO(0), KC_END, KC_TRNS, KC_PDOT, KC_P1, KC_P2, KC_P3, KC_PEQL, KC_TRNS, MS_LEFT, MS_DOWN, MS_UP, MS_RGHT, MS_BTN1, KC_MUTE, KC_VOLU, KC_TRNS, KC_TRNS, KC_P0, KC_PENT, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_MPLY, KC_MPRV, KC_VOLD, KC_MNXT), + [2] = LAYOUT(KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_PSLS, KC_7, KC_8, KC_9, KC_GRV, KC_HOME, KC_PGDN, KC_PGUP, KC_END, KC_PSCR, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, LSFT(KC_N), KC_4, KC_5, KC_6, KC_0, KC_NO, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT, KC_BSPC, KC_NO, KC_NO, KC_NO, KC_NO, KC_DOT, KC_1, KC_2, KC_3, KC_N, KC_NO, KC_MPLY, KC_VOLD, KC_VOLU, KC_MUTE, KC_DEL, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, OSL(3), KC_NUBS, KC_NUBS, OSL(3), KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO), + [3] = LAYOUT(KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_F5, KC_F6, KC_F7, KC_F8, RSFT(KC_LSFT), KC_PWR, KC_SLEP, KC_WAKE, KC_NUBS, MS_WHLU, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_F1, KC_F2, KC_F3, KC_F4, TO(4), KC_NO, MS_LEFT, MS_DOWN, MS_UP, MS_RGHT, MS_WHLD, KC_NO, KC_NO, KC_NO, KC_NO, KC_F9, KC_F10, KC_F11, KC_F12, OS_LGUI, KC_NO, MS_BTN4, MS_BTN1, MS_BTN3, MS_BTN2, MS_BTN5, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_TRNS, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO), + [4] = LAYOUT(KC_ESC, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_DEL, KC_PSCR, KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_HOME, KC_END, KC_PGUP, KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_BSPC, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, TO(0), KC_PGDN, KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_ENT, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_BSLS, KC_RCTL, KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, LSFT_T(KC_ENT), KC_RALT, KC_TAB, RCTL(KC_RSFT), MO(1), KC_LEFT, KC_DOWN, KC_UP, KC_RGHT) +}; + + + +#ifdef OTHER_KEYMAP_C +# include OTHER_KEYMAP_C +#endif // OTHER_KEYMAP_C + + diff --git a/keyboards/xbows/nature/keymaps/custom/keymap.h b/keyboards/xbows/nature/keymaps/custom/keymap.h new file mode 100644 index 0000000..1990e8d --- /dev/null +++ b/keyboards/xbows/nature/keymaps/custom/keymap.h @@ -0,0 +1,13 @@ +bool get_permissive_hold(uint16_t keycode, keyrecord_t *record) { + switch (keycode) { + case LT(2,KC_SPC): + case LT(3,KC_ENT): + case RALT_T(KC_ESC): + case LT(2,KC_TAB): + // Immediately select the hold action when another key is tapped. + return true; + default: + // Do not select the hold action when another key is tapped. + return false; + } +}