Merge remote-tracking branch 'upstream/master' into develop
commit
d6b707403e
|
@ -19,11 +19,11 @@
|
|||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||
[0] = LAYOUT(
|
||||
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_PAUS, KC_PSCR, KC_SLCK, KC_ESC,
|
||||
KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, KC_NLCK, KC_KP_SLSH, KC__KP_ASTR, KC_KP_MINS,
|
||||
KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_KP_7, KC_KP_8, KC_KP_9, KC_KP_PLUS,
|
||||
KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENT, KC_KP_4, KC_KP_5, KC_CP_6,
|
||||
KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, KC_KP_1, KC_KP_2, KC_KP_3, KC__PENT,
|
||||
KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_RALT, KC_RGUI, KC_RCTL, KC_KP_0, KC_KP_DOT
|
||||
KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, KC_NLCK, KC_PSLS, KC_PAST, KC_PMNS,
|
||||
KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_P7, KC_P8, KC_P9, KC_PPLS,
|
||||
KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENT, KC_P4, KC_P5, KC_P6,
|
||||
KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, KC_P1, KC_P2, KC_P3, KC_PENT,
|
||||
KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_RALT, KC_RGUI, KC_RCTL, KC_P0, KC_PDOT
|
||||
),
|
||||
|
||||
};
|
||||
|
|
|
@ -0,0 +1,18 @@
|
|||
# Marauder
|
||||
|
||||
90% hand-wired mechanical keyboard in an old Razer case; built around an Elite-C v3.1 controller.
|
||||
|
||||
[Build Log](https://imgur.com/a/TvsXpq5)
|
||||
|
||||
* Keyboard Maintainer: [%YOUR_NAME%](https://github.com/BB-66)
|
||||
* Hardware Supported: Elite-C, Razer Marauder
|
||||
|
||||
Make example for this keyboard (after setting up your build environment):
|
||||
|
||||
make handwired/marauder:default
|
||||
|
||||
Flashing example for this keyboard:
|
||||
|
||||
make handwired/marauder:default:flash
|
||||
|
||||
See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with our [Complete Newbs Guide](https://docs.qmk.fm/#/newbs).
|
|
@ -0,0 +1,34 @@
|
|||
/*
|
||||
Copyright 2021 rookiebwoy
|
||||
|
||||
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/>.
|
||||
*/
|
||||
#pragma once
|
||||
|
||||
#include "config_common.h"
|
||||
|
||||
/* USB Device descriptor parameter */
|
||||
#define VENDOR_ID 0xFEED
|
||||
#define PRODUCT_ID 0x0913
|
||||
#define MANUFACTURER rookiebwoy
|
||||
#define PRODUCT neopad
|
||||
|
||||
/* Column/Row IO definitions */
|
||||
#define DIODE_DIRECTION COL2ROW
|
||||
|
||||
/* Debounce reduces chatter (unintended double-presses) - set 0 if debouncing is not needed */
|
||||
#define DEBOUNCE 5
|
||||
|
||||
/* Reduce tapdance required taps from 5 to 2 */
|
||||
#define TAPPING_TOGGLE 2
|
|
@ -0,0 +1,25 @@
|
|||
# Neopad
|
||||
|
||||
Neopad is a little macropad with four switches and two rotary encoders, made by through hole components only.
|
||||
_Actually the number of switches is six, because even the encoder are allowed to click._
|
||||
|
||||
![Neopad](https://i.imgur.com/TgOkj2Fh.jpg "Neopad first proto")
|
||||
|
||||
The Neopad in the photo above is the first prototype. See the project repository for revision 1 update and KiCad files.
|
||||
|
||||
* Keyboard maintainer: [rookiebwoy](https://github.com/rookiebwoy)
|
||||
* Hardware supported: ProMicro, _Elite-C (not tested)_
|
||||
* Project repository: [Neopad on github](https://github.com/rookiebwoy/neopad)
|
||||
|
||||
Make example for this keyboard (after setting up your build environment):
|
||||
|
||||
make neopad/rev1:default
|
||||
|
||||
Flashing example for this keyboard:
|
||||
|
||||
make neopad/rev1:default:flash
|
||||
|
||||
When asked by the terminal, press the dedicated `RESET` button (the one above the 2 LEDs) to enter the bootloader and let the OS detects the device.
|
||||
|
||||
See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with [Complete Newbs Guide](https://docs.qmk.fm/#/newbs).
|
||||
|
|
@ -0,0 +1,41 @@
|
|||
/*
|
||||
Copyright 2021 rookiebwoy
|
||||
|
||||
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/>.
|
||||
*/
|
||||
#pragma once
|
||||
|
||||
#include "config_common.h"
|
||||
|
||||
/* USB Device descriptor parameter */
|
||||
#define DEVICE_VER 0x0010
|
||||
|
||||
/* Column/Row IO definitions */
|
||||
#define MATRIX_ROWS 2
|
||||
#define MATRIX_COLS 3
|
||||
#define MATRIX_ROW_PINS { F4, F5 }
|
||||
#define MATRIX_COL_PINS { B3, B2, B6 }
|
||||
#define UNUSED_PINS
|
||||
|
||||
/* Dual rotary encoders */
|
||||
#define ENCODERS_PAD_A { D1, D4 }
|
||||
#define ENCODERS_PAD_B { D0, C6 }
|
||||
|
||||
/* Onboard LEDs */
|
||||
#define LED_00 F6
|
||||
#define LED_01 F7
|
||||
|
||||
/* Bootmagic - hold down rotary encoder pushbutton while plugging in to enter bootloader */
|
||||
#define BOOTMAGIC_LITE_ROW 0
|
||||
#define BOOTMAGIC_LITE_COLUMN 0
|
|
@ -0,0 +1,16 @@
|
|||
{
|
||||
"keyboard_name": "neopad",
|
||||
"keyboard_folder": "neopad/rev1",
|
||||
"url": "https://github.com/rookiebwoy/neopad)",
|
||||
"maintainer": "rookiebwoy",
|
||||
"width": 3,
|
||||
"height": 2,
|
||||
"layouts": {
|
||||
"LAYOUT": {
|
||||
"layout": [
|
||||
{"x":0, "y":0}, {"x":1, "y":0}, {"x":2, "y":0},
|
||||
{"x":0, "y":1}, {"x":1, "y":1}, {"x":2, "y":1}
|
||||
]
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,153 @@
|
|||
/* Copyright 2021 rookiebwoy
|
||||
*
|
||||
* 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] = {
|
||||
/*
|
||||
LAYER 0 - MUSIC
|
||||
/-----------------------------`
|
||||
| TO(1) | stop | mute | L ENC: prev/next song
|
||||
|---------|---------|---------|
|
||||
| prev | play | next | R ENC: vol up/down
|
||||
\-----------------------------'
|
||||
*/
|
||||
[0] = LAYOUT(
|
||||
TO(1), KC_MSTP, KC_MUTE,
|
||||
KC_MPRV, KC_MPLY, KC_MNXT
|
||||
),
|
||||
|
||||
/*
|
||||
LAYER 1 - MOVEMENT IN WINDOWS
|
||||
/---------------------------------------`
|
||||
| TO(2) | maximize | show desktop | L ENC: change desktop
|
||||
|-------------|----------|--------------|
|
||||
| move window | minimize | move window | R ENC: change browser tab + change explorer window
|
||||
\---------------------------------------'
|
||||
*/
|
||||
[1] = LAYOUT(
|
||||
TO(2), LGUI(KC_UP), LGUI(KC_D),
|
||||
LGUI(KC_LEFT), LGUI(KC_DOWN), LGUI(KC_RIGHT)
|
||||
),
|
||||
|
||||
/*
|
||||
LAYER 2 - SHORTCUT
|
||||
/------------------------------`
|
||||
| TO(3) | esc | task man | L ENC: redo/undo
|
||||
|---------|---------|----------|
|
||||
| cut | copy | paste | R ENC: mouse wheel up/down
|
||||
\------------------------------'
|
||||
*/
|
||||
[2] = LAYOUT(
|
||||
TO(3), KC_ESC, LCTL(LSFT(KC_ESC)),
|
||||
LCTL(KC_X), LCTL(KC_C), LCTL(KC_V)
|
||||
),
|
||||
|
||||
/*
|
||||
LAYER 3 - AUDACITY
|
||||
/-----------------------------`
|
||||
| TO(0) | REC | canc | L ENC: pan right/left
|
||||
|---------|---------|---------|
|
||||
| ctrl | play | pause | R ENC: mouse wheel up/down
|
||||
\-----------------------------'
|
||||
*/
|
||||
[3] = LAYOUT(
|
||||
TO(0), LSFT(KC_R), KC_DEL,
|
||||
KC_LCTL, KC_SPC, KC_P
|
||||
),
|
||||
|
||||
};
|
||||
|
||||
|
||||
void encoder_update_user(uint8_t index, bool clockwise) {
|
||||
if (index == 0) { /* LEFT ENCODER */
|
||||
switch (get_highest_layer(layer_state)) {
|
||||
case 0:
|
||||
// layer 0 - next song (CW) and previous (CCW)
|
||||
if (clockwise) {
|
||||
tap_code(KC_MNXT);
|
||||
} else {
|
||||
tap_code(KC_MPRV);
|
||||
}
|
||||
break;
|
||||
|
||||
case 1:
|
||||
// layer 1 - change desktop right (CW) and left (CCW)
|
||||
if (clockwise) {
|
||||
tap_code16(LCTL(LGUI(KC_RIGHT)));
|
||||
} else {
|
||||
tap_code16(LCTL(LGUI(KC_LEFT)));
|
||||
}
|
||||
break;
|
||||
|
||||
case 2:
|
||||
// layer 2 - redo (CW) and undo (CCW)
|
||||
if (clockwise) {
|
||||
tap_code16(LCTL(KC_Y));
|
||||
} else {
|
||||
tap_code16(LCTL(KC_Z));
|
||||
}
|
||||
break;
|
||||
|
||||
case 3:
|
||||
// layer 3 - pan right (CW) and left (CCW)
|
||||
if (clockwise) {
|
||||
tap_code(KC_WH_R);
|
||||
} else {
|
||||
tap_code(KC_WH_L);
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
} else if (index == 1) { /* RIGHT ENCODER */
|
||||
switch (get_highest_layer(layer_state)) {
|
||||
case 0:
|
||||
// layer 0 - volume up (CW) and down (CCW)
|
||||
if (clockwise) {
|
||||
tap_code(KC_VOLU);
|
||||
} else {
|
||||
tap_code(KC_VOLD);
|
||||
}
|
||||
break;
|
||||
|
||||
case 1:
|
||||
// layer 1 - change browser tab (CW) and change explorer window (CCW)
|
||||
if (clockwise) {
|
||||
tap_code16(LCTL(KC_TAB));
|
||||
} else {
|
||||
tap_code16(LALT(LSFT(KC_TAB)));
|
||||
}
|
||||
break;
|
||||
|
||||
case 2:
|
||||
// layer 2 - wheel up (CW) and down (CCW)
|
||||
if (clockwise) {
|
||||
tap_code(KC_WH_U);
|
||||
} else {
|
||||
tap_code(KC_WH_D);
|
||||
}
|
||||
break;
|
||||
|
||||
case 3:
|
||||
// layer 3 - wheel up (CW) and down (CCW)
|
||||
if (clockwise) {
|
||||
tap_code(KC_WH_U);
|
||||
} else {
|
||||
tap_code(KC_WH_D);
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
# Neopad rev1
|
||||
|
||||
Final revision of the Neopad macropad. For in depth look please go to [project repository](https://github.com/rookiebwoy/neopad).
|
||||
|
||||
|
|
@ -0,0 +1,61 @@
|
|||
/* Copyright 2021 rookiebwoy
|
||||
*
|
||||
* 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 "rev1.h"
|
||||
|
||||
void keyboard_pre_init_kb(void) {
|
||||
// Set LED IO as outputs
|
||||
setPinOutput(LED_00);
|
||||
setPinOutput(LED_01);
|
||||
keyboard_pre_init_user();
|
||||
}
|
||||
|
||||
void shutdown_user() {
|
||||
// Shutdown LEDs
|
||||
writePinLow(LED_00);
|
||||
writePinLow(LED_01);
|
||||
}
|
||||
|
||||
layer_state_t layer_state_set_kb(layer_state_t state) {
|
||||
state = layer_state_set_user(state);
|
||||
|
||||
// Layer LEDs act as binary indication of current layer
|
||||
uint8_t layer = get_highest_layer(state);
|
||||
writePin(LED_00, layer & 0b1);
|
||||
writePin(LED_01, (layer >> 1) & 0b1);
|
||||
return state;
|
||||
}
|
||||
|
||||
// Optional override functions below.
|
||||
// You can leave any or all of these undefined.
|
||||
// These are only required if you want to perform custom actions.
|
||||
|
||||
void matrix_init_kb(void) {
|
||||
// put your keyboard start-up code here
|
||||
// runs once when the firmware starts up
|
||||
uint8_t led_delay_ms = 80;
|
||||
for (int i = 0; i < 2; i++) {
|
||||
writePinHigh(LED_00);
|
||||
writePinHigh(LED_01);
|
||||
wait_ms(led_delay_ms);
|
||||
writePinLow(LED_00);
|
||||
writePinLow(LED_01);
|
||||
if (i < 1) {
|
||||
wait_ms(led_delay_ms);
|
||||
}
|
||||
}
|
||||
|
||||
matrix_init_user();
|
||||
}
|
|
@ -0,0 +1,26 @@
|
|||
/* Copyright 2021 rookiebwoy
|
||||
*
|
||||
* 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/>.
|
||||
*/
|
||||
#pragma once
|
||||
#include "quantum.h"
|
||||
|
||||
#define LAYOUT( \
|
||||
k00, k01, k02, \
|
||||
k10, k11, k12 \
|
||||
) \
|
||||
{ \
|
||||
{ k00, k01, k02 }, \
|
||||
{ k10, k11, k12 } \
|
||||
}
|
|
@ -0,0 +1,25 @@
|
|||
# MCU name
|
||||
MCU = atmega32u4
|
||||
|
||||
# Bootloader selection
|
||||
BOOTLOADER = caterina
|
||||
|
||||
# Build Options
|
||||
# change yes to no to disable
|
||||
#
|
||||
BOOTMAGIC_ENABLE = lite # Virtual DIP switch configuration
|
||||
MOUSEKEY_ENABLE = yes # Mouse keys
|
||||
EXTRAKEY_ENABLE = yes # Audio control and System control
|
||||
CONSOLE_ENABLE = yes # 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
|
||||
NKRO_ENABLE = no # USB Nkey Rollover
|
||||
BACKLIGHT_ENABLE = no # Enable keyboard backlight functionality
|
||||
RGBLIGHT_ENABLE = no # Enable keyboard RGB underglow
|
||||
BLUETOOTH_ENABLE = no # Enable Bluetooth
|
||||
AUDIO_ENABLE = no # Audio output
|
||||
|
||||
ENCODER_ENABLE = yes
|
||||
KEY_LOCK_ENABLE = yes
|
|
@ -0,0 +1 @@
|
|||
DEFAULT_FOLDER = neopad/rev1
|
Loading…
Reference in New Issue