Update api for sensor bindings
This commit is contained in:
parent
41d2c5cfd4
commit
7f19804f83
6 changed files with 13 additions and 78 deletions
|
@ -54,7 +54,6 @@ if ((NOT CONFIG_ZMK_SPLIT) OR CONFIG_ZMK_SPLIT_ROLE_CENTRAL)
|
||||||
target_sources(app PRIVATE src/behaviors/behavior_none.c)
|
target_sources(app PRIVATE src/behaviors/behavior_none.c)
|
||||||
target_sources_ifdef(CONFIG_ZMK_BEHAVIOR_SENSOR_ROTATE app PRIVATE src/behaviors/behavior_sensor_rotate.c)
|
target_sources_ifdef(CONFIG_ZMK_BEHAVIOR_SENSOR_ROTATE app PRIVATE src/behaviors/behavior_sensor_rotate.c)
|
||||||
target_sources_ifdef(CONFIG_ZMK_BEHAVIOR_SENSOR_ROTATE_VAR app PRIVATE src/behaviors/behavior_sensor_rotate_var.c)
|
target_sources_ifdef(CONFIG_ZMK_BEHAVIOR_SENSOR_ROTATE_VAR app PRIVATE src/behaviors/behavior_sensor_rotate_var.c)
|
||||||
target_sources(app PRIVATE src/behaviors/behavior_sensor_rotate_key_press.c)
|
|
||||||
target_sources(app PRIVATE src/combo.c)
|
target_sources(app PRIVATE src/combo.c)
|
||||||
target_sources(app PRIVATE src/behavior_queue.c)
|
target_sources(app PRIVATE src/behavior_queue.c)
|
||||||
target_sources(app PRIVATE src/conditional_layer.c)
|
target_sources(app PRIVATE src/conditional_layer.c)
|
||||||
|
|
|
@ -26,7 +26,7 @@ typedef int (*behavior_keymap_binding_callback_t)(struct zmk_behavior_binding *b
|
||||||
struct zmk_behavior_binding_event event);
|
struct zmk_behavior_binding_event event);
|
||||||
typedef int (*behavior_sensor_keymap_binding_callback_t)(struct zmk_behavior_binding *binding,
|
typedef int (*behavior_sensor_keymap_binding_callback_t)(struct zmk_behavior_binding *binding,
|
||||||
const struct device *sensor,
|
const struct device *sensor,
|
||||||
int64_t timestamp);
|
struct zmk_behavior_binding_event event);
|
||||||
|
|
||||||
enum behavior_locality {
|
enum behavior_locality {
|
||||||
BEHAVIOR_LOCALITY_CENTRAL,
|
BEHAVIOR_LOCALITY_CENTRAL,
|
||||||
|
@ -160,11 +160,12 @@ static inline int z_impl_behavior_keymap_binding_released(struct zmk_behavior_bi
|
||||||
*/
|
*/
|
||||||
__syscall int behavior_sensor_keymap_binding_triggered(struct zmk_behavior_binding *binding,
|
__syscall int behavior_sensor_keymap_binding_triggered(struct zmk_behavior_binding *binding,
|
||||||
const struct device *sensor,
|
const struct device *sensor,
|
||||||
int64_t timestamp);
|
struct zmk_behavior_binding_event event);
|
||||||
|
|
||||||
static inline int
|
static inline int
|
||||||
z_impl_behavior_sensor_keymap_binding_triggered(struct zmk_behavior_binding *binding,
|
z_impl_behavior_sensor_keymap_binding_triggered(struct zmk_behavior_binding *binding,
|
||||||
const struct device *sensor, int64_t timestamp) {
|
const struct device *sensor,
|
||||||
|
struct zmk_behavior_binding_event event) {
|
||||||
const struct device *dev = device_get_binding(binding->behavior_dev);
|
const struct device *dev = device_get_binding(binding->behavior_dev);
|
||||||
|
|
||||||
if (dev == NULL) {
|
if (dev == NULL) {
|
||||||
|
@ -177,7 +178,7 @@ z_impl_behavior_sensor_keymap_binding_triggered(struct zmk_behavior_binding *bin
|
||||||
return -ENOTSUP;
|
return -ENOTSUP;
|
||||||
}
|
}
|
||||||
|
|
||||||
return api->sensor_binding_triggered(binding, sensor, timestamp);
|
return api->sensor_binding_triggered(binding, sensor, event);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -25,7 +25,8 @@ struct behavior_sensor_rotate_config {
|
||||||
};
|
};
|
||||||
|
|
||||||
static int on_sensor_binding_triggered(struct zmk_behavior_binding *binding,
|
static int on_sensor_binding_triggered(struct zmk_behavior_binding *binding,
|
||||||
const struct device *sensor, int64_t timestamp) {
|
const struct device *sensor,
|
||||||
|
struct zmk_behavior_binding_event event) {
|
||||||
const struct device *dev = device_get_binding(binding->behavior_dev);
|
const struct device *dev = device_get_binding(binding->behavior_dev);
|
||||||
const struct behavior_sensor_rotate_config *cfg = dev->config;
|
const struct behavior_sensor_rotate_config *cfg = dev->config;
|
||||||
|
|
||||||
|
@ -53,8 +54,8 @@ static int on_sensor_binding_triggered(struct zmk_behavior_binding *binding,
|
||||||
|
|
||||||
LOG_DBG("Sensor binding: %s", log_strdup(binding->behavior_dev));
|
LOG_DBG("Sensor binding: %s", log_strdup(binding->behavior_dev));
|
||||||
|
|
||||||
zmk_behavior_queue_add(0, *triggered_binding, true, cfg->tap_ms);
|
zmk_behavior_queue_add(ZMK_KEYMAP_LEN + event.position, *triggered_binding, true, cfg->tap_ms);
|
||||||
zmk_behavior_queue_add(0, *triggered_binding, false, 0);
|
zmk_behavior_queue_add(ZMK_KEYMAP_LEN + event.position, *triggered_binding, false, 0);
|
||||||
|
|
||||||
return ZMK_BEHAVIOR_OPAQUE;
|
return ZMK_BEHAVIOR_OPAQUE;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,68 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright (c) 2020 The ZMK Contributors
|
|
||||||
*
|
|
||||||
* SPDX-License-Identifier: MIT
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define DT_DRV_COMPAT zmk_behavior_sensor_rotate_key_press
|
|
||||||
|
|
||||||
#include <device.h>
|
|
||||||
#include <drivers/behavior.h>
|
|
||||||
#include <logging/log.h>
|
|
||||||
|
|
||||||
#include <drivers/sensor.h>
|
|
||||||
#include <zmk/event_manager.h>
|
|
||||||
#include <zmk/events/keycode_state_changed.h>
|
|
||||||
|
|
||||||
LOG_MODULE_DECLARE(zmk, CONFIG_ZMK_LOG_LEVEL);
|
|
||||||
|
|
||||||
#if DT_HAS_COMPAT_STATUS_OKAY(DT_DRV_COMPAT)
|
|
||||||
|
|
||||||
static int behavior_sensor_rotate_key_press_init(const struct device *dev) { return 0; };
|
|
||||||
|
|
||||||
static int on_sensor_binding_triggered(struct zmk_behavior_binding *binding,
|
|
||||||
const struct device *sensor, int64_t timestamp) {
|
|
||||||
struct sensor_value value;
|
|
||||||
int err;
|
|
||||||
uint32_t keycode;
|
|
||||||
LOG_DBG("inc keycode 0x%02X dec keycode 0x%02X", binding->param1, binding->param2);
|
|
||||||
|
|
||||||
err = sensor_channel_get(sensor, SENSOR_CHAN_ROTATION, &value);
|
|
||||||
|
|
||||||
if (err) {
|
|
||||||
LOG_WRN("Failed to ge sensor rotation value: %d", err);
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (value.val1) {
|
|
||||||
case 1:
|
|
||||||
keycode = binding->param1;
|
|
||||||
break;
|
|
||||||
case -1:
|
|
||||||
keycode = binding->param2;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
return -ENOTSUP;
|
|
||||||
}
|
|
||||||
|
|
||||||
LOG_DBG("SEND %d", keycode);
|
|
||||||
|
|
||||||
ZMK_EVENT_RAISE(zmk_keycode_state_changed_from_encoded(keycode, true, timestamp));
|
|
||||||
|
|
||||||
// TODO: Better way to do this?
|
|
||||||
k_msleep(5);
|
|
||||||
|
|
||||||
return ZMK_EVENT_RAISE(zmk_keycode_state_changed_from_encoded(keycode, false, timestamp));
|
|
||||||
}
|
|
||||||
|
|
||||||
static const struct behavior_driver_api behavior_sensor_rotate_key_press_driver_api = {
|
|
||||||
.sensor_binding_triggered = on_sensor_binding_triggered};
|
|
||||||
|
|
||||||
#define KP_INST(n) \
|
|
||||||
DEVICE_DT_INST_DEFINE(n, behavior_sensor_rotate_key_press_init, NULL, NULL, NULL, APPLICATION, \
|
|
||||||
CONFIG_KERNEL_INIT_PRIORITY_DEFAULT, \
|
|
||||||
&behavior_sensor_rotate_key_press_driver_api);
|
|
||||||
|
|
||||||
DT_INST_FOREACH_STATUS_OKAY(KP_INST)
|
|
||||||
|
|
||||||
#endif /* DT_HAS_COMPAT_STATUS_OKAY(DT_DRV_COMPAT) */
|
|
|
@ -25,7 +25,8 @@ struct behavior_sensor_rotate_var_config {
|
||||||
};
|
};
|
||||||
|
|
||||||
static int on_sensor_binding_triggered(struct zmk_behavior_binding *binding,
|
static int on_sensor_binding_triggered(struct zmk_behavior_binding *binding,
|
||||||
const struct device *sensor, int64_t timestamp) {
|
const struct device *sensor,
|
||||||
|
struct zmk_behavior_binding_event event) {
|
||||||
const struct device *dev = device_get_binding(binding->behavior_dev);
|
const struct device *dev = device_get_binding(binding->behavior_dev);
|
||||||
const struct behavior_sensor_rotate_var_config *cfg = dev->config;
|
const struct behavior_sensor_rotate_var_config *cfg = dev->config;
|
||||||
|
|
||||||
|
|
|
@ -269,7 +269,8 @@ int zmk_keymap_sensor_triggered(uint8_t sensor_number, const struct device *sens
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = behavior_sensor_keymap_binding_triggered(binding, sensor, timestamp);
|
struct zmk_behavior_binding_event event = {.position = 0, .timestamp = timestamp};
|
||||||
|
ret = behavior_sensor_keymap_binding_triggered(binding, sensor, event);
|
||||||
|
|
||||||
if (ret > 0) {
|
if (ret > 0) {
|
||||||
LOG_DBG("behavior processing to continue to next layer");
|
LOG_DBG("behavior processing to continue to next layer");
|
||||||
|
|
Loading…
Add table
Reference in a new issue