Skip to content

Commit

Permalink
Update encoder callback
Browse files Browse the repository at this point in the history
  • Loading branch information
Gondolindrim committed Oct 9, 2021
1 parent f90d8b3 commit b228d29
Show file tree
Hide file tree
Showing 7 changed files with 47 additions and 22 deletions.
2 changes: 2 additions & 0 deletions keyboards/evolv/config.h
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,8 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.

#define ENCODERS_PAD_A { B3 }
#define ENCODERS_PAD_B { A15 }
#define ENCODER_RESOLUTION 2
#define TAPPING_TERM 200

/*
* Feature disable options
Expand Down
12 changes: 0 additions & 12 deletions keyboards/evolv/evolv.c
Original file line number Diff line number Diff line change
Expand Up @@ -16,15 +16,3 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
*/

#include "evolv.h"

bool encoder_update_kb(uint8_t index, bool clockwise) {
if (!encoder_update_user(index, clockwise)) return false;
if (index == 0) { /* First encoder */
if (clockwise) {
tap_code(KC_VOLU);
} else {
tap_code(KC_VOLD);
}
}
return true;
}
14 changes: 14 additions & 0 deletions keyboards/evolv/keymaps/default/keymap.c
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.

#include QMK_KEYBOARD_H

#define MEDIA_KEY_DELAY 100

const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
[0] = LAYOUT_evolv_ansi(
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_INS ,
Expand Down Expand Up @@ -47,3 +49,15 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
_______, _______, _______, _______, _______, _______, _______, _______, _______)
};

uint32_t held_keycode_timer = 0;
uint16_t mapped_code = 0;
bool encoder_update_user(uint8_t index, bool clockwise) {
if (clockwise) mapped_code = KC_VOLU;
else mapped_code = KC_VOLD;
register_code(mapped_code);
held_keycode_timer = timer_read32();
while (timer_elapsed32(held_keycode_timer) < MEDIA_KEY_DELAY) ;
unregister_code(mapped_code);
return true;
}
14 changes: 14 additions & 0 deletions keyboards/evolv/keymaps/iso/keymap.c
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.

#include QMK_KEYBOARD_H

#define MEDIA_KEY_DELAY 100

const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
[0] = LAYOUT_evolv_iso(
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_INS ,
Expand Down Expand Up @@ -47,3 +49,15 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
_______, _______, _______, _______, _______, _______, _______, _______, _______)
};

uint32_t held_keycode_timer = 0;
uint16_t mapped_code = 0;
bool encoder_update_user(uint8_t index, bool clockwise) {
if (clockwise) mapped_code = KC_VOLU;
else mapped_code = KC_VOLD;
register_code(mapped_code);
held_keycode_timer = timer_read32();
while (timer_elapsed32(held_keycode_timer) < MEDIA_KEY_DELAY) ;
unregister_code(mapped_code);
return true;
}
14 changes: 14 additions & 0 deletions keyboards/evolv/keymaps/via/keymap.c
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.

#include QMK_KEYBOARD_H

#define MEDIA_KEY_DELAY 100

const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
[0] = LAYOUT_evolv_iso(
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_INS ,
Expand Down Expand Up @@ -47,3 +49,15 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
_______, _______, _______, _______, _______, _______, _______, _______, _______)
};

uint32_t held_keycode_timer = 0;
uint16_t mapped_code = 0;
bool encoder_update_user(uint8_t index, bool clockwise) {
if (clockwise) mapped_code = KC_VOLU;
else mapped_code = KC_VOLD;
register_code(mapped_code);
held_keycode_timer = timer_read32();
while (timer_elapsed32(held_keycode_timer) < MEDIA_KEY_DELAY) ;
unregister_code(mapped_code);
return true;
}
4 changes: 0 additions & 4 deletions keyboards/evolv/mcuconf.h
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,5 @@

#include_next <mcuconf.h>

#undef STM32_I2C_USE_DMA
#define STM32_I2C_USE_DMA FALSE

#undef STM32_SPI_USE_SPI2
#define STM32_SPI_USE_SPI2 TRUE

9 changes: 3 additions & 6 deletions keyboards/evolv/rules.mk
Original file line number Diff line number Diff line change
@@ -1,17 +1,14 @@
# MCU name
MCU = STM32F072

# Bootloader selection
BOOTLOADER = stm32-dfu

# Build Options
# change yes to no to disable
#
BOOTMAGIC_ENABLE = lite # Enable Bootmagic Lite
BOOTMAGIC_ENABLE = yes # Enable Bootmagic Lite
MOUSEKEY_ENABLE = yes # Mouse keys
EXTRAKEY_ENABLE = yes # Audio control and System control
CONSOLE_ENABLE = yes # Console for debug
COMMAND_ENABLE = yes # Commands for debug and configuration
CONSOLE_ENABLE = no # Console for debug
COMMAND_ENABLE = no # Commands for debug and configuration
# Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE
SLEEP_LED_ENABLE = no # Breathing sleep LED during USB suspend
# if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work
Expand Down

0 comments on commit b228d29

Please sign in to comment.