From a6a84314442a9c2ee2f148f5aace765bf6d906c3 Mon Sep 17 00:00:00 2001 From: takashicompany Date: Mon, 18 Nov 2024 01:50:08 +0900 Subject: [PATCH] fix setting --- .../left_slinger/custom_joystick.c | 13 +- .../left_slinger/keymaps/default/keymap.c | 88 +++++++++--- .../left_slinger/left_slinger.c | 129 ++++++++++++------ .../left_slinger/left_slinger.h | 22 +-- 4 files changed, 180 insertions(+), 72 deletions(-) diff --git a/keyboards/takashicompany/left_slinger/custom_joystick.c b/keyboards/takashicompany/left_slinger/custom_joystick.c index 9f6acd6826a..91de7245137 100644 --- a/keyboards/takashicompany/left_slinger/custom_joystick.c +++ b/keyboards/takashicompany/left_slinger/custom_joystick.c @@ -38,8 +38,17 @@ report_mouse_t pointing_device_driver_get_report(report_mouse_t mouse_report) { if (timer_elapsed(lastCursor) > ANALOG_JOYSTICK_READ_INTERVAL) { // 多分、指定のミリ秒経過したかを見て処理を走らせている lastCursor = timer_read(); - mouse_report.x = axisCoordinate_custom(ANALOG_JOYSTICK_X_AXIS_PIN, xOrigin) / joystick_ratio; - mouse_report.y = axisCoordinate_custom(ANALOG_JOYSTICK_Y_AXIS_PIN, yOrigin) / joystick_ratio; + + int16_t jsr = joystick_ratio; + if (0 <= jsr && jsr < 10) { + jsr = 10; + } + else if (-10 < jsr && jsr < 0) { + jsr = -10; + } + + mouse_report.x = axisCoordinate_custom(ANALOG_JOYSTICK_X_AXIS_PIN, xOrigin) / jsr; + mouse_report.y = axisCoordinate_custom(ANALOG_JOYSTICK_Y_AXIS_PIN, yOrigin) / jsr; } return mouse_report; diff --git a/keyboards/takashicompany/left_slinger/keymaps/default/keymap.c b/keyboards/takashicompany/left_slinger/keymaps/default/keymap.c index 70c2479f53b..43f716d8adb 100644 --- a/keyboards/takashicompany/left_slinger/keymaps/default/keymap.c +++ b/keyboards/takashicompany/left_slinger/keymaps/default/keymap.c @@ -4,28 +4,80 @@ #include QMK_KEYBOARD_H const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { - /* - * ┌───┬───┬───┬───┐ - * │ 7 │ 8 │ 9 │ / │ - * ├───┼───┼───┼───┤ - * │ 4 │ 5 │ 6 │ * │ - * ├───┼───┼───┼───┤ - * │ 1 │ 2 │ 3 │ - │ - * ├───┼───┼───┼───┤ - * │ 0 │ . │Ent│ + │ - * └───┴───┴───┴───┘ - */ [0] = LAYOUT( - KC_1, KC_2, KC_3, - KC_4, KC_5, KC_6, KC_MY_BTN1, - KC_8, KC_9, KC_0, KC_A, KC_B, - KC_C, KC_D, KC_E, - KC_F, KC_G, KC_H - ) + KC_Q , KC_W , KC_E , + KC_TAB , KC_A , KC_S , KC_D , + KC_LSFT, KC_Z , KC_X , KC_C , KC_V , + KC_LCTL, KC_UP , KC_LALT, + KC_LEFT, KC_DOWN, KC_RGHT + ), + + [1] = 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 + ), + + [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 + ), + + [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 + ), + + [4] = 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 + ), + + [5] = 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 + ), + + [6] = LAYOUT( + KC_NO , KC_NO , KC_NO , + KC_NO , MY_BTN2, MY_SCRL, MY_BTN1, + KC_NO , KC_NO , KC_NO , KC_NO , KC_NO , + KC_NO , KC_NO , KC_NO , + KC_NO , KC_NO , KC_NO + ), + + [7] = LAYOUT( + KC_NO , KC_NO , KC_NO , + KC_NO , KC_NO , MY_CLKD, MY_CLKI, + QK_BOOT, KC_NO , MY_SCDV, MY_SCDH, KC_NO , + KC_NO , MY_JSDD, MY_JSDI, + KC_NO , MY_STGE, KC_NO + ), }; #if defined(ENCODER_MAP_ENABLE) const uint16_t PROGMEM encoder_map[][NUM_ENCODERS][NUM_DIRECTIONS] = { - [0] = { ENCODER_CCW_CW(KC_1, KC_2) } + [0] = { ENCODER_CCW_CW(MS_WHLD, MS_WHLU) }, + [1] = { ENCODER_CCW_CW(MS_WHLL, MS_WHLR) }, + [2] = { ENCODER_CCW_CW(KC_TRNS, KC_TRNS) }, + [3] = { ENCODER_CCW_CW(KC_TRNS, KC_TRNS) }, + [4] = { ENCODER_CCW_CW(KC_TRNS, KC_TRNS) }, + [5] = { ENCODER_CCW_CW(KC_TRNS, KC_TRNS) }, + [6] = { ENCODER_CCW_CW(KC_TRNS, KC_TRNS) }, + [7] = { ENCODER_CCW_CW(KC_TRNS, KC_TRNS) } }; #endif diff --git a/keyboards/takashicompany/left_slinger/left_slinger.c b/keyboards/takashicompany/left_slinger/left_slinger.c index 10e3243566b..c13a9efbd52 100644 --- a/keyboards/takashicompany/left_slinger/left_slinger.c +++ b/keyboards/takashicompany/left_slinger/left_slinger.c @@ -9,7 +9,6 @@ #define MOUSE_SCROLL_V_REVERSE_BIT (1 << 0) // 0000 0001 #define MOUSE_SCROLL_H_REVERSE_BIT (1 << 1) // 0000 0010 -#define IS_OLED_LOGO_BIT (1 << 2) // 0000 0100 enum click_state { NONE = 0, @@ -38,7 +37,8 @@ uint16_t click_timer; // タイマー。状態に応じて時間で判定 // uint16_t to_clickable_time = 50; // この秒数(千分の一秒)、WAITING状態ならクリックレイヤーが有効になる。 For this number of seconds (milliseconds), if in WAITING state, the click layer is activated. uint16_t to_reset_time = 1000; // この秒数(千分の一秒)、CLICKABLE状態ならクリックレイヤーが無効になる。 For this number of seconds (milliseconds), the click layer is disabled if in CLICKABLE state. -const uint16_t click_layer = 8; // マウス入力が可能になった際に有効になるレイヤー。Layers enabled when mouse input is enabled +const uint16_t click_layer = 6; // マウス入力が可能になった際に有効になるレイヤー。Layers enabled when mouse input is enabled +const uint16_t setting_layer = 7; int16_t scroll_v_mouse_interval_counter; // 垂直スクロールの入力をカウントする。 Counting Vertical Scroll Inputs int16_t scroll_h_mouse_interval_counter; // 水平スクロールの入力をカウントする。 Counts horizontal scrolling inputs. @@ -54,7 +54,6 @@ int16_t mouse_move_count_ratio = 5; // ポインターの動きを再生す const uint16_t ignore_disable_mouse_layer_keys[] = {KC_LGUI, KC_LCTL}; // この配列で指定されたキーはマウスレイヤー中に押下してもマウスレイヤーを解除しない int16_t mouse_movement; -uint32_t press_count; void eeconfig_init_kb(void) { user_config.raw = 0; @@ -65,7 +64,6 @@ void eeconfig_init_kb(void) { user_config.settings = 0; // 初期化 user_config.settings |= MOUSE_SCROLL_V_REVERSE_BIT * false; // ここでfalseなので実際にはセットしない user_config.settings |= MOUSE_SCROLL_H_REVERSE_BIT * false; // 同上 - user_config.settings |= IS_OLED_LOGO_BIT * false; // 同上 eeconfig_update_kb(user_config.raw); } @@ -78,10 +76,6 @@ bool get_mouse_scroll_h_reverse(void) { return user_config.settings & MOUSE_SCROLL_H_REVERSE_BIT; } -bool get_is_oled_logo(void) { - return user_config.settings & IS_OLED_LOGO_BIT; -} - void set_mouse_scroll_v_reverse(bool value) { if (value) { user_config.settings |= MOUSE_SCROLL_V_REVERSE_BIT; @@ -98,17 +92,9 @@ void set_mouse_scroll_h_reverse(bool value) { } } -void set_is_oled_logo(bool value) { - if (value) { - user_config.settings |= IS_OLED_LOGO_BIT; - } else { - user_config.settings &= ~IS_OLED_LOGO_BIT; - } -} - void keyboard_post_init_kb(void) { user_config.raw = eeconfig_read_kb(); - // joystick_ratio = user_config.joystick_ratio; + joystick_ratio = user_config.joystick_ratio; } // クリック用のレイヤーを有効にする。 Enable layers for clicks @@ -126,6 +112,29 @@ void disable_click_layer(void) { scroll_h_mouse_interval_counter = 0; } +bool setting_flags[4] = { false, false, false, false }; + +void enable_setting_layer(void) { + for (int i = 0; i < 4; i++) + { + setting_flags[i] = false; + } + layer_on(setting_layer); + + SEND_STRING("Setting Layer Start."); +} + +void disable_setting_layer(void) { + + for (int i = 0; i < 4; i++) + { + setting_flags[i] = false; + } + + layer_off(setting_layer); + SEND_STRING("Setting Layer End."); +} + // 自前の絶対数を返す関数。 Functions that return absolute numbers. int8_t my_abs(int8_t num) { if (num < 0) { @@ -141,20 +150,51 @@ bool is_clickable_mode(void) { } bool process_record_kb(uint16_t keycode, keyrecord_t *record) { - - if (record->event.pressed) { - press_count++; - } + if (record->event.key.row == 0 && record->event.key.col == 0) + { + setting_flags[0] = record->event.pressed; + } + + if (record->event.key.row == 0 && record->event.key.col == 2) + { + setting_flags[1] = record->event.pressed; + } + + if (record->event.key.row == 5 && record->event.key.col == 0) + { + setting_flags[2] = record->event.pressed; + } + + if (record->event.key.row == 5 && record->event.key.col == 2) + { + setting_flags[3] = record->event.pressed; + } + + for (int i = 0; i < 4; i++) + { + if (!setting_flags[i]) + { + break; + } + + if (i == 3) + { + enable_setting_layer(); + return true; + } + } + + switch (keycode) { - case KC_MY_BTN1: - case KC_MY_BTN2: - case KC_MY_BTN3: + case MY_BTN1: + case MY_BTN2: + case MY_BTN3: { report_mouse_t currentReport = pointing_device_get_report(); // どこのビットを対象にするか。 Which bits are to be targeted? - uint8_t btn = 1 << (keycode - KC_MY_BTN1); + uint8_t btn = 1 << (keycode - MY_BTN1); if (record->event.pressed) { // ビットORは演算子の左辺と右辺の同じ位置にあるビットを比較して、両方のビットのどちらかが「1」の場合に「1」にします。 @@ -175,7 +215,7 @@ bool process_record_kb(uint16_t keycode, keyrecord_t *record) { return false; } - case KC_MY_SCR: + case MY_SCRL: if (record->event.pressed) { state = SCROLLING; } else { @@ -183,14 +223,14 @@ bool process_record_kb(uint16_t keycode, keyrecord_t *record) { } return false; - case KC_TO_CLICKABLE_INC: + case MY_CLKI: if (record->event.pressed) { user_config.to_clickable_movement += 5; // user_config.to_clickable_time += 10; eeconfig_update_kb(user_config.raw); } return false; - case KC_TO_CLICKABLE_DEC: + case MY_CLKD: if (record->event.pressed) { user_config.to_clickable_movement -= 5; // user_config.to_clickable_time -= 10; @@ -208,45 +248,52 @@ bool process_record_kb(uint16_t keycode, keyrecord_t *record) { } return false; - case KC_SCROLL_DIR_V: + case MY_SCDV: if (record->event.pressed) { set_mouse_scroll_v_reverse(!get_mouse_scroll_v_reverse()); // user_config.mouse_scroll_v_reverse = !user_config.mouse_scroll_v_reverse; eeconfig_update_kb(user_config.raw); } return false; - case KC_SCROLL_DIR_H: + case MY_SCDH: if (record->event.pressed) { set_mouse_scroll_h_reverse(!get_mouse_scroll_h_reverse()); // user_config.mouse_scroll_h_reverse = !user_config.mouse_scroll_h_reverse; eeconfig_update_kb(user_config.raw); } return false; - - case KC_OLED: - if (record->event.pressed) { - set_is_oled_logo(!get_is_oled_logo()); - eeconfig_update_kb(user_config.raw); - } - break; - case KC_JS_INC: + case MY_JSDI: if (record->event.pressed) { - joystick_ratio = joystick_ratio + 10; + joystick_ratio = joystick_ratio + 5; user_config.joystick_ratio = joystick_ratio; eeconfig_update_kb(user_config.raw); + + // char str[256]; + // sprintf(str, "%d", joystick_ratio); + // SEND_STRING(str); } break; - case KC_JS_DEC: + case MY_JSDD: if (record->event.pressed) { - joystick_ratio = joystick_ratio - 10; + joystick_ratio = joystick_ratio - 5; user_config.joystick_ratio = joystick_ratio; eeconfig_update_kb(user_config.raw); + + // char str[256]; + // sprintf(str, "%d", joystick_ratio); + // SEND_STRING(str); } break; + case MY_STGE: + if (record->event.pressed) { + disable_setting_layer(); + } + break; + default: if (record->event.pressed) { diff --git a/keyboards/takashicompany/left_slinger/left_slinger.h b/keyboards/takashicompany/left_slinger/left_slinger.h index 130d57ca228..e669845d439 100644 --- a/keyboards/takashicompany/left_slinger/left_slinger.h +++ b/keyboards/takashicompany/left_slinger/left_slinger.h @@ -3,15 +3,15 @@ #include "quantum.h" enum custom_keycodes_kb { - KC_MY_BTN1 = SAFE_RANGE, - KC_MY_BTN2, - KC_MY_BTN3, - KC_MY_SCR, - KC_TO_CLICKABLE_INC, - KC_TO_CLICKABLE_DEC, - KC_SCROLL_DIR_V, - KC_SCROLL_DIR_H, - KC_OLED, - KC_JS_INC, - KC_JS_DEC + MY_BTN1 = SAFE_RANGE, + MY_BTN2, + MY_BTN3, + MY_SCRL, // Scroll + MY_CLKI, // Click time increase + MY_CLKD, // Click time decrease + MY_SCDV, // Scroll vertical + MY_SCDH, // Scroll horizontal + MY_JSDI, // Joy stick movement divisor increase + MY_JSDD, // Joy stick movement divisor decrease + MY_STGE, // Setting End }; \ No newline at end of file