* Default Factory Settings * Change Keyboard Name in Readme * Fix LED Orders * Change Brightness Step * Enable Lighting Layers * Add RGB Control Mode * Unblink Layer to Clear Stack * Add MacOS RGB Control * Comment Fixespull/17714/head
@ -0,0 +1,50 @@ | |||
/* Copyright 2022 Jason Wihardja | |||
* | |||
* 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 0x0000 | |||
#define DEVICE_VER 0x0002 | |||
#define MANUFACTURER Drop | |||
#define PRODUCT The Key V2 | |||
/* key matrix size */ | |||
#define MATRIX_ROWS 1 | |||
#define MATRIX_COLS 3 | |||
/* | |||
* Keyboard Matrix Assignments | |||
*/ | |||
#define MATRIX_ROW_PINS { D4 } | |||
#define MATRIX_COL_PINS { D2, D1, D0 } | |||
#define DIODE_DIRECTION ROW2COL | |||
#define RGB_DI_PIN B1 | |||
#define RGBLED_NUM 5 | |||
#define RGBLIGHT_LED_MAP {4, 0, 1, 2, 3} | |||
#define RGBLIGHT_ANIMATIONS | |||
#define RGBLIGHT_HUE_STEP 10 | |||
#define RGBLIGHT_SAT_STEP 10 | |||
#define RGBLIGHT_VAL_STEP 15 | |||
#define RGBLIGHT_LIMIT_VAL 255 /* The maximum brightness level */ | |||
#define RGBLIGHT_SLEEP /* If defined, the RGB lighting will be switched off when the host goes to sleep */ | |||
#define RGBLIGHT_LAYERS /* Enable lighting layers */ | |||
#define RGBLIGHT_LAYER_BLINK /* Enable lighting layer blink */ |
@ -0,0 +1,14 @@ | |||
{ | |||
"keyboard_name": "The Key V2", | |||
"url": "https://drop.com/buy/stack-overflow-the-key-v2-macropad", | |||
"maintainer": "massdrop", | |||
"layouts": { | |||
"LAYOUT": { | |||
"layout": [ | |||
{ "label": "K00 (D4,D2)", "x": 0, "y": 0 }, | |||
{ "label": "K01 (D4,D1)", "x": 1, "y": 0 }, | |||
{ "label": "K02 (D4,D0)", "x": 2, "y": 0 } | |||
] | |||
} | |||
} | |||
} |
@ -0,0 +1,23 @@ | |||
/* Copyright 2022 Jason Wihardja | |||
* | |||
* 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] = { | |||
[0] = LAYOUT(KC_LGUI, KC_C, KC_V), | |||
}; |
@ -0,0 +1,23 @@ | |||
/* Copyright 2022 Jason Wihardja | |||
* | |||
* 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] = { | |||
[0] = LAYOUT(KC_LCTL, KC_C, KC_V), | |||
}; |
@ -0,0 +1,109 @@ | |||
/* Copyright 2022 Jason Wihardja | |||
* | |||
* 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 | |||
enum custom_keycodes { | |||
LAYER_SWITCH = SAFE_RANGE, | |||
}; | |||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
/* Default */ | |||
[0] = LAYOUT(LAYER_SWITCH, G(KC_C), G(KC_V)), | |||
/* RGB Toggle + Mode Change */ | |||
[1] = LAYOUT(LAYER_SWITCH, RGB_TOG, RGB_MOD), | |||
/* RGB Brightness */ | |||
[2] = LAYOUT(LAYER_SWITCH, RGB_VAD, RGB_VAI), | |||
/* RGB Hue */ | |||
[3] = LAYOUT(LAYER_SWITCH, RGB_HUD, RGB_HUI), | |||
/* RGB Saturation */ | |||
[4] = LAYOUT(LAYER_SWITCH, RGB_SAD, RGB_SAI), | |||
}; | |||
/* Lighting layers */ | |||
const rgblight_segment_t PROGMEM layer_indicator_0[] = RGBLIGHT_LAYER_SEGMENTS( | |||
{0, 1, HSV_WHITE}, | |||
{1, 4, HSV_OFF} | |||
); | |||
const rgblight_segment_t PROGMEM layer_indicator_1[] = RGBLIGHT_LAYER_SEGMENTS( | |||
{0, 1, HSV_OFF}, | |||
{1, 1, HSV_WHITE}, | |||
{2, 3, HSV_OFF} | |||
); | |||
const rgblight_segment_t PROGMEM layer_indicator_2[] = RGBLIGHT_LAYER_SEGMENTS( | |||
{0, 2, HSV_OFF}, | |||
{2, 1, HSV_WHITE}, | |||
{3, 2, HSV_OFF} | |||
); | |||
const rgblight_segment_t PROGMEM layer_indicator_3[] = RGBLIGHT_LAYER_SEGMENTS( | |||
{0, 3, HSV_OFF}, | |||
{3, 1, HSV_WHITE}, | |||
{4, 1, HSV_OFF} | |||
); | |||
const rgblight_segment_t PROGMEM layer_indicator_4[] = RGBLIGHT_LAYER_SEGMENTS( | |||
{0, 4, HSV_OFF}, | |||
{4, 1, HSV_WHITE} | |||
); | |||
const rgblight_segment_t* const PROGMEM rgb_layers[] = RGBLIGHT_LAYERS_LIST( | |||
layer_indicator_0, | |||
layer_indicator_1, | |||
layer_indicator_2, | |||
layer_indicator_3, | |||
layer_indicator_4 | |||
); | |||
void keyboard_post_init_user(void) { | |||
/* Enable the LED layers */ | |||
rgblight_layers = rgb_layers; | |||
} | |||
/* Layer handler */ | |||
uint16_t layer = 0; | |||
bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||
switch (keycode) { | |||
case LAYER_SWITCH: | |||
if (record->event.pressed) { | |||
if (layer > 0) { | |||
layer_off(layer); | |||
} | |||
rgblight_unblink_layer(layer); | |||
layer = (layer + 1) % 5; | |||
rgblight_blink_layer_repeat(layer, 1000, 1); | |||
if (layer > 0) { | |||
layer_on(layer); | |||
} | |||
} | |||
return false; | |||
default: | |||
return true; | |||
} | |||
} |
@ -0,0 +1,109 @@ | |||
/* Copyright 2022 Jason Wihardja | |||
* | |||
* 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 | |||
enum custom_keycodes { | |||
LAYER_SWITCH = SAFE_RANGE, | |||
}; | |||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
/* Default */ | |||
[0] = LAYOUT(LAYER_SWITCH, C(KC_C), C(KC_V)), | |||
/* RGB Toggle + Mode Change */ | |||
[1] = LAYOUT(LAYER_SWITCH, RGB_TOG, RGB_MOD), | |||
/* RGB Brightness */ | |||
[2] = LAYOUT(LAYER_SWITCH, RGB_VAD, RGB_VAI), | |||
/* RGB Hue */ | |||
[3] = LAYOUT(LAYER_SWITCH, RGB_HUD, RGB_HUI), | |||
/* RGB Saturation */ | |||
[4] = LAYOUT(LAYER_SWITCH, RGB_SAD, RGB_SAI), | |||
}; | |||
/* Lighting layers */ | |||
const rgblight_segment_t PROGMEM layer_indicator_0[] = RGBLIGHT_LAYER_SEGMENTS( | |||
{0, 1, HSV_WHITE}, | |||
{1, 4, HSV_OFF} | |||
); | |||
const rgblight_segment_t PROGMEM layer_indicator_1[] = RGBLIGHT_LAYER_SEGMENTS( | |||
{0, 1, HSV_OFF}, | |||
{1, 1, HSV_WHITE}, | |||
{2, 3, HSV_OFF} | |||
); | |||
const rgblight_segment_t PROGMEM layer_indicator_2[] = RGBLIGHT_LAYER_SEGMENTS( | |||
{0, 2, HSV_OFF}, | |||
{2, 1, HSV_WHITE}, | |||
{3, 2, HSV_OFF} | |||
); | |||
const rgblight_segment_t PROGMEM layer_indicator_3[] = RGBLIGHT_LAYER_SEGMENTS( | |||
{0, 3, HSV_OFF}, | |||
{3, 1, HSV_WHITE}, | |||
{4, 1, HSV_OFF} | |||
); | |||
const rgblight_segment_t PROGMEM layer_indicator_4[] = RGBLIGHT_LAYER_SEGMENTS( | |||
{0, 4, HSV_OFF}, | |||
{4, 1, HSV_WHITE} | |||
); | |||
const rgblight_segment_t* const PROGMEM rgb_layers[] = RGBLIGHT_LAYERS_LIST( | |||
layer_indicator_0, | |||
layer_indicator_1, | |||
layer_indicator_2, | |||
layer_indicator_3, | |||
layer_indicator_4 | |||
); | |||
void keyboard_post_init_user(void) { | |||
/* Enable the LED layers */ | |||
rgblight_layers = rgb_layers; | |||
} | |||
/* Layer handler */ | |||
uint16_t layer = 0; | |||
bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||
switch (keycode) { | |||
case LAYER_SWITCH: | |||
if (record->event.pressed) { | |||
if (layer > 0) { | |||
layer_off(layer); | |||
} | |||
rgblight_unblink_layer(layer); | |||
layer = (layer + 1) % 5; | |||
rgblight_blink_layer_repeat(layer, 1000, 1); | |||
if (layer > 0) { | |||
layer_on(layer); | |||
} | |||
} | |||
return false; | |||
default: | |||
return true; | |||
} | |||
} |
@ -0,0 +1,39 @@ | |||
/* Copyright 2022 Jason Wihardja | |||
* | |||
* 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 | |||
enum custom_keycodes { | |||
TK_URL = SAFE_RANGE, | |||
}; | |||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
[0] = LAYOUT(TK_URL, G(KC_C), G(KC_V)), | |||
}; | |||
bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||
switch (keycode) { | |||
case TK_URL: | |||
if (record->event.pressed) { | |||
// when keycode TK_URL is pressed | |||
SEND_STRING("https://stackoverflow.com/\n"); | |||
} | |||
break; | |||
default: | |||
break; | |||
} | |||
return true; | |||
} |
@ -0,0 +1,40 @@ | |||
/* Copyright 2022 Jason Wihardja | |||
* | |||
* 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 | |||
enum custom_keycodes { | |||
TK_URL = SAFE_RANGE, | |||
}; | |||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
[0] = LAYOUT(TK_URL, C(KC_C), C(KC_V)), | |||
}; | |||
bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||
switch (keycode) { | |||
case TK_URL: | |||
if (record->event.pressed) { | |||
// when keycode TK_URL is pressed | |||
SEND_STRING("https://stackoverflow.com/"); | |||
} | |||
break; | |||
default: | |||
break; | |||
} | |||
return true; | |||
} |
@ -0,0 +1,38 @@ | |||
# The Key V2 | |||
![The Key V2](https://massdrop-s3.imgix.net/product-images/stack-overflow-the-key-v2-macropad/FP/vSqOp9eUQNGXW4zl3EVQ_7528-copy-pdp.jpg) | |||
The Stack Overflow "The Key V2" is a 3 button macropad based on atmega32u4 with hot-swappble Kailh Black Box switches. | |||
> Last year, we brought Stack Overflow’s iconic April Fool’s joke to life. Advertised as the new (and only) way to copy and paste on the site, it was an ultra-compact macropad called The Key. The punchline-turned product was a huge hit, selling over 10K units and earning a nearly 5-star average review. Now, we’re back with a second act: The Key V2. The same size as its portable predecessor, this punchline-turned-product has a few notable changes—including an acrylic case to accent its two built-in RGB LEDs. Plus, we made it hot-swappable, so you can easily change out the switches for a truly custom experience. And just like the original, a portion of all proceeds from The Key V2 will go to the data-driven social startup digitalundivided. | |||
Keyboard Maintainer: [Drop / Massdrop](https://github.com/Massdrop/qmk_firmware) | |||
Hardware Supported: Massdrop, Inc. **The Key V2** | |||
Hardware Availability: Limited Release - https://drop.com/buy/stack-overflow-the-key-v2-macropad | |||
Make example for this keyboard (after setting up your build environment): | |||
```bash | |||
# default provided by Drop / Stack Overflow | |||
make massdrop/thekey_v2:default | |||
# common modification where C = CTRL+C, V = CTRL+V | |||
make massdrop/thekey_v2:url-copy-paste | |||
``` | |||
Flashing example for this keyboard: | |||
```bash | |||
# install in dfu mode | |||
make massdrop/thekey_v2:default:dfu | |||
``` | |||
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). | |||
Make example for this keyboard (after setting up your build environment): | |||
## Bootloader | |||
Enter the bootloader as follows: | |||
* **Bootmagic reset**: Hold down the "Stack Overflow" key, the "left-most" or furthest from the USB plug while inserting the USB cable for a few seconds. The LEDs will **NOT** turn on. | |||
* **Physical reset button**: Briefly press and hold the reset button while pluggin in the USB port. The LEDs on the back will **NOT** turn on. Depending on your case revision, you may have to remove the 4 screws on the back plate to access the switch OR you can use the associated access hole on newer releases. |
@ -0,0 +1,18 @@ | |||
# MCU name | |||
MCU = atmega32u4 | |||
# Bootloader selection | |||
BOOTLOADER = atmel-dfu | |||
# Build Options | |||
# change yes to no to disable | |||
# | |||
BOOTMAGIC_ENABLE = yes # Enable Bootmagic Lite | |||
MOUSEKEY_ENABLE = no # Mouse keys | |||
EXTRAKEY_ENABLE = yes # Audio control and System control | |||
CONSOLE_ENABLE = no # Console for debug | |||
COMMAND_ENABLE = no # Commands for debug and configuration | |||
NKRO_ENABLE = no # Enable N-Key Rollover | |||
BACKLIGHT_ENABLE = no # Enable keyboard backlight functionality | |||
RGBLIGHT_ENABLE = yes # Enable keyboard RGB underglow | |||
AUDIO_ENABLE = no # Audio output |
@ -0,0 +1,17 @@ | |||
/* Copyright 2022 Jason Wihardja | |||
* | |||
* 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 "thekey_v2.h" |
@ -0,0 +1,27 @@ | |||
/* Copyright 2022 Jason Wihardja | |||
* | |||
* 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 XXX KC_NO | |||
#define LAYOUT( \ | |||
K00, K01, K02 \ | |||
) { \ | |||
{ K00, K01, K02 }, \ | |||
} |