Merge pull request #57 from ykz89/dumbpad
Add support for imchipwood's dumbpad
This commit is contained in:
commit
29ffe545e2
13
keyboards/dumbpad/v1x_dualencoder/keymaps/vial/config.h
Normal file
13
keyboards/dumbpad/v1x_dualencoder/keymaps/vial/config.h
Normal file
@ -0,0 +1,13 @@
|
||||
#pragma once
|
||||
#define VIAL_KEYBOARD_UID {0x49, 0x6B, 0x7A, 0xA8, 0x6C, 0x78, 0xF6, 0x21}
|
||||
|
||||
#define NO_ACTION_MACRO
|
||||
#define NO_ACTION_FUNCTION
|
||||
|
||||
#define ENCODER_RESOLUTION 2
|
||||
|
||||
#define VIAL_ENCODER_DEFAULT { KC_A, KC_B, KC_C, KC_D, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_A, KC_B, KC_C, KC_D, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS }
|
||||
|
||||
|
||||
#define VIAL_UNLOCK_COMBO_ROWS { 0, 0 }
|
||||
#define VIAL_UNLOCK_COMBO_COLS { 1, 4 }
|
147
keyboards/dumbpad/v1x_dualencoder/keymaps/vial/keymap.c
Normal file
147
keyboards/dumbpad/v1x_dualencoder/keymaps/vial/keymap.c
Normal file
@ -0,0 +1,147 @@
|
||||
/* Copyright 2020 imchipwood
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation, either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
#include QMK_KEYBOARD_H
|
||||
|
||||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||
/*
|
||||
BASE LAYER
|
||||
/-----------------------------------------------------`
|
||||
| | 7 | 8 | 9 | Bkspc |
|
||||
| |---------|---------|---------|---------|
|
||||
| | 4 | 5 | 6 | Esc |
|
||||
| |---------|---------|---------|---------|
|
||||
| | 1 | 2 | 3 | Tab |
|
||||
|-------------|---------|---------|---------|---------|
|
||||
| Left mouse | TT(1) | 0 | . | Enter |
|
||||
\-----------------------------------------------------'
|
||||
*/
|
||||
[0] = LAYOUT(
|
||||
KC_7, KC_8, KC_9, KC_BSPC,
|
||||
KC_4, KC_5, KC_6, KC_ESC,
|
||||
KC_1, KC_2, KC_3, KC_TAB,
|
||||
KC_BTN1, TT(1), KC_0, LSFT_T(KC_DOT), KC_ENTER
|
||||
),
|
||||
/*
|
||||
SUB LAYER
|
||||
/-----------------------------------------------------`
|
||||
| | | | | Reset |
|
||||
| |---------|---------|---------|---------|
|
||||
| | | | | + |
|
||||
| |---------|---------|---------|---------|
|
||||
| | | | | - |
|
||||
|-------------|---------|---------|---------|---------|
|
||||
| LOCK | | | | = |
|
||||
\-----------------------------------------------------'
|
||||
*/
|
||||
[1] = LAYOUT(
|
||||
_______, _______, _______, RESET,
|
||||
_______, _______, _______, KC_KP_PLUS,
|
||||
_______, _______, _______, KC_KP_MINUS,
|
||||
KC_LOCK, _______, _______, _______, KC_EQL
|
||||
),
|
||||
[2] = LAYOUT(
|
||||
_______, _______, _______, _______,
|
||||
_______, _______, _______, _______,
|
||||
_______, _______, _______, _______,
|
||||
KC_LOCK, _______, _______, _______, _______
|
||||
),
|
||||
[3] = LAYOUT(
|
||||
_______, _______, _______, _______,
|
||||
_______, _______, _______, _______,
|
||||
_______, _______, _______, _______,
|
||||
_______, _______, _______, _______, _______
|
||||
)
|
||||
};
|
||||
|
||||
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
||||
// If console is enabled, it will print the matrix position and status of each key pressed
|
||||
/*
|
||||
#ifdef CONSOLE_ENABLE
|
||||
uprintf("KL: kc: %u, col: %u, row: %u, pressed: %u\n", keycode, record->event.key.col, record->event.key.row, record->event.pressed);
|
||||
#endif
|
||||
*/
|
||||
return true;
|
||||
}
|
||||
|
||||
void keyboard_post_init_user(void) {
|
||||
// Customise these values to desired behaviour
|
||||
// debug_enable = true;
|
||||
// debug_matrix = true;
|
||||
// debug_keyboard = true;
|
||||
// debug_mouse = true;
|
||||
}
|
||||
|
||||
bool encoder_update_user(uint8_t index, bool clockwise) {
|
||||
/* Custom encoder control - handles CW/CCW turning of encoder
|
||||
* Default behavior:
|
||||
* left encoder:
|
||||
* main layer:
|
||||
* CW: move mouse right
|
||||
* CCW: move mouse left
|
||||
* other layers:
|
||||
* CW: = (equals/plus - increase slider in Adobe products)
|
||||
* CCW: - (minus/underscore - decrease slider in adobe products)
|
||||
* right encoder:
|
||||
* main layer:
|
||||
* CW: colume up
|
||||
* CCW: volume down
|
||||
* other layers:
|
||||
* CW: right arrow
|
||||
* CCW: left arrow
|
||||
*/
|
||||
if (index == 0) {
|
||||
switch (get_highest_layer(layer_state)) {
|
||||
case 0:
|
||||
// main layer - move mouse right (CW) and left (CCW)
|
||||
if (clockwise) {
|
||||
tap_code(KC_MS_R);
|
||||
} else {
|
||||
tap_code(KC_MS_L);
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
// other layers - =/+ (quals/plus) (CW) and -/_ (minus/underscore) (CCW)
|
||||
if (clockwise) {
|
||||
tap_code(KC_EQL);
|
||||
} else {
|
||||
tap_code(KC_MINS);
|
||||
}
|
||||
break;
|
||||
}
|
||||
} else if (index == 1) {
|
||||
switch (get_highest_layer(layer_state)) {
|
||||
case 0:
|
||||
// main layer - volume up (CW) and down (CCW)
|
||||
if (clockwise) {
|
||||
tap_code(KC_VOLU);
|
||||
} else {
|
||||
tap_code(KC_VOLD);
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
// other layers - right (CW) and left (CCW)
|
||||
if (clockwise) {
|
||||
tap_code(KC_RIGHT);
|
||||
} else {
|
||||
tap_code(KC_LEFT);
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
5
keyboards/dumbpad/v1x_dualencoder/keymaps/vial/rules.mk
Normal file
5
keyboards/dumbpad/v1x_dualencoder/keymaps/vial/rules.mk
Normal file
@ -0,0 +1,5 @@
|
||||
VIA_ENABLE = yes
|
||||
VIAL_ENABLE = yes
|
||||
VIAL_ENCODERS_ENABLE = yes
|
||||
|
||||
EXTRAFLAGS += -flto
|
60
keyboards/dumbpad/v1x_dualencoder/keymaps/vial/vial.json
Normal file
60
keyboards/dumbpad/v1x_dualencoder/keymaps/vial/vial.json
Normal file
@ -0,0 +1,60 @@
|
||||
{
|
||||
"name": "Dumbpad",
|
||||
"vendorId": "0xFEED",
|
||||
"productId": "0x0913",
|
||||
"lighting": "none",
|
||||
"matrix": {
|
||||
"rows": 4,
|
||||
"cols": 5
|
||||
},
|
||||
"layouts": {
|
||||
"keymap": [
|
||||
[{
|
||||
"y": 0.5,
|
||||
"x": 1
|
||||
},
|
||||
"0,1\n\n\n\n\n\n\n\n\ne",
|
||||
"0,0\n\n\n\n\n\n\n\n\ne",
|
||||
{
|
||||
"x": 1
|
||||
},
|
||||
"1,1\n\n\n\n\n\n\n\n\ne",
|
||||
"1,0\n\n\n\n\n\n\n\n\ne"
|
||||
],
|
||||
[{
|
||||
"y": 0.5,
|
||||
"x": 3
|
||||
},
|
||||
"0,1",
|
||||
"0,2",
|
||||
"0,3",
|
||||
"0,4"
|
||||
],
|
||||
[{
|
||||
"x": 3
|
||||
},
|
||||
"1,1",
|
||||
"1,2",
|
||||
"1,3",
|
||||
"1,4"
|
||||
],
|
||||
[{
|
||||
"x": 3
|
||||
},
|
||||
"2,1",
|
||||
"2,2",
|
||||
"2,3",
|
||||
"2,4"
|
||||
],
|
||||
[{
|
||||
"x": 2
|
||||
},
|
||||
"3,0",
|
||||
"3,1",
|
||||
"3,2",
|
||||
"3,3",
|
||||
"3,4"
|
||||
]
|
||||
]
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user