From cd837717e328f4647bb4e27be25140f0188ddbb2 Mon Sep 17 00:00:00 2001 From: Alexey Osheychik Date: Sun, 28 Dec 2025 18:50:58 +0100 Subject: [PATCH] Default config for lotus kb --- .../lotus58/keymaps/lotus/config.h | 2 + .../lotus58/keymaps/lotus/keymap.c | 97 +++++++++++++++++++ .../lotus58/keymaps/lotus/rules.mk | 17 ++++ qmk.json | 6 +- 4 files changed, 120 insertions(+), 2 deletions(-) create mode 100644 keyboards/tweetydabird/lotus58/keymaps/lotus/config.h create mode 100644 keyboards/tweetydabird/lotus58/keymaps/lotus/keymap.c create mode 100644 keyboards/tweetydabird/lotus58/keymaps/lotus/rules.mk diff --git a/keyboards/tweetydabird/lotus58/keymaps/lotus/config.h b/keyboards/tweetydabird/lotus58/keymaps/lotus/config.h new file mode 100644 index 00000000..eac5baf7 --- /dev/null +++ b/keyboards/tweetydabird/lotus58/keymaps/lotus/config.h @@ -0,0 +1,2 @@ +#undef ENCODER_RESOLUTION +#define ENCODER_RESOLUTION 4 \ No newline at end of file diff --git a/keyboards/tweetydabird/lotus58/keymaps/lotus/keymap.c b/keyboards/tweetydabird/lotus58/keymaps/lotus/keymap.c new file mode 100644 index 00000000..5fcc5cf1 --- /dev/null +++ b/keyboards/tweetydabird/lotus58/keymaps/lotus/keymap.c @@ -0,0 +1,97 @@ +// Copyright 2022 Markus Knutsson (@TweetyDaBird) +// SPDX-License-Identifier: GPL-2.0-or-later +#include QMK_KEYBOARD_H + +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { + [0] = LAYOUT( + QK_GESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_MPLY, KC_MPLY, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, + 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_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, + LCTL_T(KC_LEFT), KC_Z, KC_X, KC_C, KC_V, KC_B, KC_DOWN, KC_UP, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, RCTL_T(KC_RGHT), + KC_LGUI, TG(2), KC_LALT, LSFT_T(KC_SPC), RSFT_T(KC_ENT), KC_RALT, TG(1), RGUI_T(KC_BSPC) + ), + + [1] = LAYOUT( + _______, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, _______, _______, KC_CIRC, KC_KP_7, KC_KP_8, KC_KP_9, XXXXXXX, XXXXXXX, + _______, XXXXXXX, KC_UP, XXXXXXX, XXXXXXX, XXXXXXX, KC_HASH, KC_KP_4, KC_KP_5, KC_KP_6, XXXXXXX, XXXXXXX, + XXXXXXX, KC_LEFT, KC_DOWN, KC_RIGHT,KC_LBRC, KC_RBRC, KC_AMPR, KC_KP_1, KC_KP_2, KC_KP_3, XXXXXXX, XXXXXXX, + _______, XXXXXXX, KC_PAST, KC_PPLS, KC_PSLS, KC_EQL, _______, _______, KC_DLR, KC_KP_0, KC_PDOT, KC_COLN, KC_PMNS, _______, + _______, _______, _______, _______, _______, _______, _______, _______ + ), + + [2] = LAYOUT( + _______, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, _______, _______, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, _______, + _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, + _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, + _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, + _______, _______, _______, _______, _______, _______, _______, _______ + ), + + [3] = LAYOUT( + QK_BOOT, XXXXXXX, XXXXXXX, XXXXXXX, NK_TOGG, AC_TOGG, _______, _______, XXXXXXX, XXXXXXX, XXXXXXX, UG_NEXT, UG_SATU, UG_TOGG, + QK_RBT, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, UG_PREV, UG_SATD, RGB_M_P, + XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_CAPS, XXXXXXX, XXXXXXX, XXXXXXX, UG_HUEU, UG_VALU, RGB_M_B, + XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, UG_HUED, UG_VALD, RGB_M_R, + _______, _______, _______, _______, _______, _______, _______, _______ + ) +}; + +#if defined(ENCODER_MAP_ENABLE) +const uint16_t PROGMEM encoder_map[][NUM_ENCODERS][NUM_DIRECTIONS] = { + [0] = { ENCODER_CCW_CW(KC_VOLD, KC_VOLU), ENCODER_CCW_CW(KC_VOLD, KC_VOLU) }, + [1] = { ENCODER_CCW_CW(KC_TRNS, KC_TRNS), ENCODER_CCW_CW(KC_TRNS, KC_TRNS) }, + [2] = { ENCODER_CCW_CW(KC_TRNS, KC_TRNS), ENCODER_CCW_CW(KC_TRNS, KC_TRNS) }, + [3] = { ENCODER_CCW_CW(KC_TRNS, KC_TRNS), ENCODER_CCW_CW(KC_TRNS, KC_TRNS) } +}; +#endif + +#ifdef OLED_ENABLE +static void print_status_narrow(void) { + // Create OLED content + oled_write_P(PSTR("\n"), false); + oled_write_P(PSTR(""), false); + oled_write_P(PSTR("Lotus -58-"), false); + oled_write_P(PSTR("\n"), false); + + // Print current layer + oled_write_P(PSTR("Layer"), false); + switch (get_highest_layer(layer_state)) { + case 0: + oled_write_P(PSTR("-Base\n"), false); + break; + case 1: + oled_write_P(PSTR("-Num \n"), false); + break; + case 2: + oled_write_P(PSTR("-Func\n"), false); + break; + case 3: + oled_write_P(PSTR("-Sys \n"), false); + break; + default: + oled_write_P(PSTR("Undef"), false); + } + + oled_write_P(PSTR("\n"), false); + led_t led_usb_state = host_keyboard_led_state(); + oled_write_ln_P(PSTR("Caps- lock"), led_usb_state.caps_lock); + +#ifdef AUTO_SHIFT_ENABLE + + bool autoshift = get_autoshift_state(); + oled_advance_page(true); + oled_write_P(PSTR("Auto-Shift"), autoshift); + oled_advance_page(true); + +#endif + + +} + +bool oled_task_user(void) { + // Render the OLED + print_status_narrow(); + return false; +} + +#endif \ No newline at end of file diff --git a/keyboards/tweetydabird/lotus58/keymaps/lotus/rules.mk b/keyboards/tweetydabird/lotus58/keymaps/lotus/rules.mk new file mode 100644 index 00000000..8262d4eb --- /dev/null +++ b/keyboards/tweetydabird/lotus58/keymaps/lotus/rules.mk @@ -0,0 +1,17 @@ +CONVERT_TO=rp2040_ce + +ENCODER_MAP_ENABLE = yes +AUTO_SHIFT_ENABLE = yes + +# CAPS_WORD_ENABLE = yes +# COMMAND_ENABLE = no +# REPEAT_KEY_ENABLE = no +# AUDIO_ENABLE = no +# LAYER_LOCK_ENABLE = yes +# COMBO_ENABLE = yes +# EXTRAKEY_ENABLE = yes + +OLED_ENABLE = no +RGBLIGHT_ENABLE = no + +CONSOLE_ENABLE = yes diff --git a/qmk.json b/qmk.json index 3afc389f..6a3623e9 100644 --- a/qmk.json +++ b/qmk.json @@ -1,4 +1,6 @@ { - "userspace_version": "1.0", - "build_targets": [] + "userspace_version": "1.1", + "build_targets": [ + ["tweetydabird/lotus58", "lotus"] + ] } \ No newline at end of file