mirror of
https://github.com/qmk/qmk_firmware.git
synced 2024-11-22 03:19:24 +00:00
Compare commits
8 Commits
49bfa98ce2
...
7f5f984099
Author | SHA1 | Date | |
---|---|---|---|
|
7f5f984099 | ||
|
c843ad1268 | ||
|
0988523851 | ||
|
250c987bc8 | ||
|
9ba088133e | ||
|
5d59e06f8d | ||
|
2e2ae506ce | ||
|
d667eb193d |
File diff suppressed because it is too large
Load Diff
@ -33,7 +33,8 @@
|
|||||||
"$ref": "qmk.definitions.v1#/hex_number_4d"
|
"$ref": "qmk.definitions.v1#/hex_number_4d"
|
||||||
},
|
},
|
||||||
"additionalProperties": {
|
"additionalProperties": {
|
||||||
"type": "object", // use 'qmk.definitions.v1#/keycode_decl' when problem keycodes are removed
|
"$comment": "use 'qmk.definitions.v1#/keycode_decl' when problem keycodes are removed",
|
||||||
|
"type": "object",
|
||||||
"required": [
|
"required": [
|
||||||
"key"
|
"key"
|
||||||
],
|
],
|
||||||
|
@ -8,7 +8,7 @@
|
|||||||
],
|
],
|
||||||
"properties": {
|
"properties": {
|
||||||
"userspace_version": {
|
"userspace_version": {
|
||||||
"type": "string",
|
"type": "string"
|
||||||
},
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
{"$ref": "qmk.definitions.v1#/keyboard_keymap_tuple"},
|
{"$ref": "qmk.definitions.v1#/keyboard_keymap_tuple"},
|
||||||
{"$ref": "qmk.definitions.v1#/json_file_path"}
|
{"$ref": "qmk.definitions.v1#/json_file_path"}
|
||||||
]
|
]
|
||||||
},
|
}
|
||||||
},
|
},
|
||||||
"required": [
|
"required": [
|
||||||
"userspace_version",
|
"userspace_version",
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
{"$ref": "qmk.definitions.v1#/keyboard_keymap_env"},
|
{"$ref": "qmk.definitions.v1#/keyboard_keymap_env"},
|
||||||
{"$ref": "qmk.definitions.v1#/json_file_path"}
|
{"$ref": "qmk.definitions.v1#/json_file_path"}
|
||||||
]
|
]
|
||||||
},
|
}
|
||||||
},
|
},
|
||||||
"required": [
|
"required": [
|
||||||
"userspace_version",
|
"userspace_version",
|
||||||
|
@ -4,7 +4,7 @@ This page attempts to introduce developers to the QMK Compiler. It does not go i
|
|||||||
|
|
||||||
# Overview
|
# Overview
|
||||||
|
|
||||||
The QMK Compile API consists of a few movings parts:
|
The QMK Compile API consists of a few moving parts:
|
||||||
|
|
||||||
![Architecture Diagram](https://raw.githubusercontent.com/qmk/qmk_api/master/docs/architecture.svg)
|
![Architecture Diagram](https://raw.githubusercontent.com/qmk/qmk_api/master/docs/architecture.svg)
|
||||||
|
|
||||||
|
@ -60,6 +60,14 @@
|
|||||||
"resync": true
|
"resync": true
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"encoder": {
|
||||||
|
"rotary": [
|
||||||
|
{"pin_a": "B12", "pin_b": "B11", "resolution": 2},
|
||||||
|
{"pin_a": "B12", "pin_b": "B11", "resolution": 2},
|
||||||
|
{"pin_a": "B12", "pin_b": "B11", "resolution": 2},
|
||||||
|
{"pin_a": "B12", "pin_b": "B11", "resolution": 2}
|
||||||
|
]
|
||||||
|
},
|
||||||
"layouts": {
|
"layouts": {
|
||||||
"LAYOUT_default": {
|
"LAYOUT_default": {
|
||||||
"layout": [
|
"layout": [
|
||||||
|
@ -44,3 +44,10 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
|||||||
KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS
|
KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS
|
||||||
)
|
)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#if defined(ENCODER_MAP_ENABLE)
|
||||||
|
const uint16_t PROGMEM encoder_map[][NUM_ENCODERS][NUM_DIRECTIONS] = {
|
||||||
|
[0] = { ENCODER_CCW_CW(KC_MS_WH_UP, KC_MS_WH_DOWN), ENCODER_CCW_CW(KC_VOLD, KC_VOLU), ENCODER_CCW_CW(UG_HUED, UG_HUEU), ENCODER_CCW_CW(UG_SATD, UG_SATU) },
|
||||||
|
[1] = { ENCODER_CCW_CW(UG_VALD, UG_VALU), ENCODER_CCW_CW(UG_SPDD, UG_SPDU), ENCODER_CCW_CW(UG_PREV, UG_NEXT), ENCODER_CCW_CW(KC_RIGHT, KC_LEFT) },
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
@ -0,0 +1,2 @@
|
|||||||
|
ENCODER_ENABLE = yes
|
||||||
|
ENCODER_MAP_ENABLE = yes
|
40
keyboards/cannonkeys/sagittarius/sagittarius.c
Normal file
40
keyboards/cannonkeys/sagittarius/sagittarius.c
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
// Copyright 2024 Nick Brassel (@tzarc)
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
#include QMK_KEYBOARD_H
|
||||||
|
|
||||||
|
#if defined(ENCODER_ENABLE) || defined(ENCODER_MAP_ENABLE)
|
||||||
|
|
||||||
|
# if !defined(ENCODER_SETTLE_PIN_STATE_DELAY_US)
|
||||||
|
# define ENCODER_SETTLE_PIN_STATE_DELAY_US 2
|
||||||
|
# endif
|
||||||
|
|
||||||
|
static pin_t matrix_row_pins[MATRIX_ROWS] = MATRIX_ROW_PINS;
|
||||||
|
|
||||||
|
void encoder_driver_task(void) {
|
||||||
|
// Set all relevant rows to output, which is different to the matrix expectations
|
||||||
|
for (uint8_t i = 0; i < 4; i++) {
|
||||||
|
gpio_set_pin_output(matrix_row_pins[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Read each encoder
|
||||||
|
for (uint8_t i = 0; i < 4; i++) {
|
||||||
|
// Set the row pin low for the corresponding encoder...
|
||||||
|
for (uint8_t j = 0; j < 4; j++) {
|
||||||
|
gpio_write_pin(matrix_row_pins[j], (i == j) ? 0 : 1);
|
||||||
|
}
|
||||||
|
// ...and let them settle.
|
||||||
|
wait_us(ENCODER_SETTLE_PIN_STATE_DELAY_US);
|
||||||
|
|
||||||
|
// Run the normal encoder handling
|
||||||
|
extern void encoder_quadrature_handle_read(uint8_t index, uint8_t pin_a_state, uint8_t pin_b_state);
|
||||||
|
extern uint8_t encoder_quadrature_read_pin(uint8_t index, bool pad_b);
|
||||||
|
encoder_quadrature_handle_read(i, encoder_quadrature_read_pin(i, false), encoder_quadrature_read_pin(i, true));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set all rows back to input-high as per matrix expectations
|
||||||
|
for (uint8_t i = 0; i < 4; i++) {
|
||||||
|
gpio_set_pin_input_high(matrix_row_pins[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // defined(ENCODER_ENABLE) || defined(ENCODER_MAP_ENABLE)
|
Loading…
Reference in New Issue
Block a user