summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorQMK Bot <hello@qmk.fm>2021-06-22 23:34:48 +0000
committerQMK Bot <hello@qmk.fm>2021-06-22 23:34:48 +0000
commit540d95125c9d0cc80ce1b1bd6be2d468edacd905 (patch)
tree1ce83353c86fe999a1ccc73c5399dbe3142ad0a0
parent010715877f88032bdc3e54f29c33e48ca8f1b575 (diff)
parent4ef2b0f81817aa24931293215b10dd5a031f109d (diff)
Merge remote-tracking branch 'origin/master' into develop
-rw-r--r--keyboards/makrosu/config.h70
-rw-r--r--keyboards/makrosu/info.json21
-rw-r--r--keyboards/makrosu/keymaps/default/keymap.c133
-rw-r--r--keyboards/makrosu/keymaps/via/keymap.c133
-rw-r--r--keyboards/makrosu/keymaps/via/rules.mk1
-rw-r--r--keyboards/makrosu/makrosu.c16
-rw-r--r--keyboards/makrosu/makrosu.h20
-rw-r--r--keyboards/makrosu/readme.md14
-rw-r--r--keyboards/makrosu/rules.mk23
9 files changed, 431 insertions, 0 deletions
diff --git a/keyboards/makrosu/config.h b/keyboards/makrosu/config.h
new file mode 100644
index 0000000000..8a5214fe68
--- /dev/null
+++ b/keyboards/makrosu/config.h
@@ -0,0 +1,70 @@
+/* Copyright 2021 Valdydesu_
+ *
+ * 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 0xAB69
+#define PRODUCT_ID 0x8585
+#define DEVICE_VER 0x0001
+#define MANUFACTURER valdydesu_
+#define PRODUCT makrosu
+
+/* key matrix size */
+#define MATRIX_ROWS 1
+#define MATRIX_COLS 6
+
+/* key matrix pins */
+#define MATRIX_ROW_PINS { B6 }
+#define MATRIX_COL_PINS { B2, B3, B1, F7, F6, F5}
+#define UNUSED_PINS
+
+#define ENCODERS_PAD_A { D1 }
+#define ENCODERS_PAD_B { E6 }
+#define ENCODER_DIRECTION_FLIP
+#define TAP_CODE_DELAY 10
+/* COL2ROW or ROW2COL */
+#define DIODE_DIRECTION COL2ROW
+
+#define BOOTMAGIC_LITE_ROW 0
+#define BOOTMAGIC_LITE_COLUMN 5
+/* number of backlight levels */
+
+#ifdef BACKLIGHT_PIN
+#define BACKLIGHT_LEVELS 0
+#endif
+
+
+/* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */
+#define LOCKING_SUPPORT_ENABLE
+
+/* Locking resynchronize hack */
+#define LOCKING_RESYNC_ENABLE
+
+
+
+// EEPROM usage
+
+
+#ifdef RGB_DI_PIN
+#define RGBLIGHT_ANIMATIONS
+#define RGBLED_NUM 0
+#define RGBLIGHT_HUE_STEP 8
+#define RGBLIGHT_SAT_STEP 8
+#define RGBLIGHT_VAL_STEP 8
+#endif
diff --git a/keyboards/makrosu/info.json b/keyboards/makrosu/info.json
new file mode 100644
index 0000000000..caf039ac63
--- /dev/null
+++ b/keyboards/makrosu/info.json
@@ -0,0 +1,21 @@
+{
+ "keyboard_name": "MakrOSU",
+ "url": "",
+ "maintainer": "Valdydesu_",
+ "width": 3,
+ "height": 2,
+ "layouts": {
+ "LAYOUT": {
+ "layout": [
+
+ {"label" : "Esc", "x":0, "y":0},
+ {"label" : "F1", "x":1, "y":0},
+ {"label" : "F2", "x":2, "y":0},
+
+ {"label" : "Lower", "x":0, "y":1},
+ {"label" : "Z", "x":1.5, "y":1},
+ {"label" : "X", "x":2.5, "y":1}
+ ]
+ }
+ }
+}
diff --git a/keyboards/makrosu/keymaps/default/keymap.c b/keyboards/makrosu/keymaps/default/keymap.c
new file mode 100644
index 0000000000..b7f60a4141
--- /dev/null
+++ b/keyboards/makrosu/keymaps/default/keymap.c
@@ -0,0 +1,133 @@
+/* Copyright 2021 Valdydesu_
+ *
+ * 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 planck_layers {
+ _1,
+ _2,
+ _3,
+ _4
+
+};
+
+
+enum planck_keycodes {
+ L1 = SAFE_RANGE,
+ L2,
+ L3
+
+};
+
+#define LOWER MO(_4)
+#define IND_1 D4
+#define IND_2 C6
+#define IND_3 D7
+
+const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
+
+ [_1] = LAYOUT(
+ KC_ESC, KC_F1, KC_F2,
+ LOWER, KC_Z, KC_X),
+
+ [_2] = LAYOUT(
+ LALT(KC_TAB), LGUI(KC_TAB), LCTL(KC_S),
+ LOWER, LCTL(KC_C), LCTL(KC_V)),
+
+ [_3] = LAYOUT(
+ KC_TRNS, KC_TRNS, KC_TRNS,
+ KC_TRNS, KC_TRNS, KC_TRNS),
+
+ [_4] = LAYOUT(
+ L1, L2, L3,
+ _______, _______, _______),
+
+};
+
+
+layer_state_t layer_state_set_user(layer_state_t state) {
+ state = update_tri_layer_state(state, _4, X_PAUSE, X_PAUSE);
+ writePin(IND_1, layer_state_cmp(state, 1));
+ writePin(IND_2, layer_state_cmp(state, 2));
+ writePin(IND_3, layer_state_cmp(state, 3));
+ return state;
+}
+
+bool process_record_user(uint16_t keycode, keyrecord_t *record) {
+ switch (keycode) {
+ case L1:
+ if (record->event.pressed) {
+ set_single_persistent_default_layer(_1);
+
+
+ }
+ return false;
+ break;
+ case L2:
+ if (record->event.pressed) {
+ set_single_persistent_default_layer(_2);
+
+ }
+ return false;
+ break;
+ case L3:
+ if (record->event.pressed) {
+ set_single_persistent_default_layer(_3);
+
+ }
+ return false;
+ break;
+
+ }
+ return true;
+}
+
+void matrix_init_user(void) {
+ //init the Pro Micro on-board LEDs
+ setPinOutput(IND_1);
+ setPinOutput(IND_2);
+ setPinOutput(IND_3);
+ //set to off
+ writePinHigh(IND_1);
+ writePinHigh(IND_2);
+ writePinHigh(IND_3);
+}
+
+void encoder_update_user(uint8_t index, bool clockwise) {
+ if (layer_state_is(_1)) {
+ if (clockwise) {
+ tap_code(KC_UP);
+ } else {
+ tap_code(KC_DOWN);
+ }
+ }
+
+ else if (layer_state_is(_2)) {
+ if (clockwise) {
+ tap_code(KC_RGHT);
+ } else {
+ tap_code(KC_LEFT);
+ }
+ }
+
+ else if (layer_state_is(_3)) {
+ if (clockwise) {
+ tap_code(KC_VOLU);
+ } else {
+ tap_code(KC_VOLD);
+ }
+ }
+}
diff --git a/keyboards/makrosu/keymaps/via/keymap.c b/keyboards/makrosu/keymaps/via/keymap.c
new file mode 100644
index 0000000000..b7f60a4141
--- /dev/null
+++ b/keyboards/makrosu/keymaps/via/keymap.c
@@ -0,0 +1,133 @@
+/* Copyright 2021 Valdydesu_
+ *
+ * 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 planck_layers {
+ _1,
+ _2,
+ _3,
+ _4
+
+};
+
+
+enum planck_keycodes {
+ L1 = SAFE_RANGE,
+ L2,
+ L3
+
+};
+
+#define LOWER MO(_4)
+#define IND_1 D4
+#define IND_2 C6
+#define IND_3 D7
+
+const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
+
+ [_1] = LAYOUT(
+ KC_ESC, KC_F1, KC_F2,
+ LOWER, KC_Z, KC_X),
+
+ [_2] = LAYOUT(
+ LALT(KC_TAB), LGUI(KC_TAB), LCTL(KC_S),
+ LOWER, LCTL(KC_C), LCTL(KC_V)),
+
+ [_3] = LAYOUT(
+ KC_TRNS, KC_TRNS, KC_TRNS,
+ KC_TRNS, KC_TRNS, KC_TRNS),
+
+ [_4] = LAYOUT(
+ L1, L2, L3,
+ _______, _______, _______),
+
+};
+
+
+layer_state_t layer_state_set_user(layer_state_t state) {
+ state = update_tri_layer_state(state, _4, X_PAUSE, X_PAUSE);
+ writePin(IND_1, layer_state_cmp(state, 1));
+ writePin(IND_2, layer_state_cmp(state, 2));
+ writePin(IND_3, layer_state_cmp(state, 3));
+ return state;
+}
+
+bool process_record_user(uint16_t keycode, keyrecord_t *record) {
+ switch (keycode) {
+ case L1:
+ if (record->event.pressed) {
+ set_single_persistent_default_layer(_1);
+
+
+ }
+ return false;
+ break;
+ case L2:
+ if (record->event.pressed) {
+ set_single_persistent_default_layer(_2);
+
+ }
+ return false;
+ break;
+ case L3:
+ if (record->event.pressed) {
+ set_single_persistent_default_layer(_3);
+
+ }
+ return false;
+ break;
+
+ }
+ return true;
+}
+
+void matrix_init_user(void) {
+ //init the Pro Micro on-board LEDs
+ setPinOutput(IND_1);
+ setPinOutput(IND_2);
+ setPinOutput(IND_3);
+ //set to off
+ writePinHigh(IND_1);
+ writePinHigh(IND_2);
+ writePinHigh(IND_3);
+}
+
+void encoder_update_user(uint8_t index, bool clockwise) {
+ if (layer_state_is(_1)) {
+ if (clockwise) {
+ tap_code(KC_UP);
+ } else {
+ tap_code(KC_DOWN);
+ }
+ }
+
+ else if (layer_state_is(_2)) {
+ if (clockwise) {
+ tap_code(KC_RGHT);
+ } else {
+ tap_code(KC_LEFT);
+ }
+ }
+
+ else if (layer_state_is(_3)) {
+ if (clockwise) {
+ tap_code(KC_VOLU);
+ } else {
+ tap_code(KC_VOLD);
+ }
+ }
+}
diff --git a/keyboards/makrosu/keymaps/via/rules.mk b/keyboards/makrosu/keymaps/via/rules.mk
new file mode 100644
index 0000000000..036bd6d1c3
--- /dev/null
+++ b/keyboards/makrosu/keymaps/via/rules.mk
@@ -0,0 +1 @@
+VIA_ENABLE = yes \ No newline at end of file
diff --git a/keyboards/makrosu/makrosu.c b/keyboards/makrosu/makrosu.c
new file mode 100644
index 0000000000..8a9a222789
--- /dev/null
+++ b/keyboards/makrosu/makrosu.c
@@ -0,0 +1,16 @@
+ /* Copyright 2021 Valdydesu_
+ *
+ * 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 "makrosu.h"
diff --git a/keyboards/makrosu/makrosu.h b/keyboards/makrosu/makrosu.h
new file mode 100644
index 0000000000..ee61ce1185
--- /dev/null
+++ b/keyboards/makrosu/makrosu.h
@@ -0,0 +1,20 @@
+#pragma once
+
+#include "quantum.h"
+
+/* This is a shortcut to help you visually see your layout.
+ *
+ * The first section contains all of the arguments representing the physical
+ * layout of the board and position of the keys.
+ *
+ * The second converts the arguments into a two-dimensional array which
+ * represents the switch matrix.
+ */
+#define LAYOUT( \
+ K02, K03, K04, \
+ K00, K01, K05 \
+) \
+{ \
+ { K00, K01, K02, K03, K04, K05 }, \
+}
+
diff --git a/keyboards/makrosu/readme.md b/keyboards/makrosu/readme.md
new file mode 100644
index 0000000000..fab6c09115
--- /dev/null
+++ b/keyboards/makrosu/readme.md
@@ -0,0 +1,14 @@
+# [Makrosu Keypad](https://www.instagram.com/p/CJ8eoQ7BoGZ/)
+
+A Macropad that has 1 rotary encoder, 2 switches and 3 push buttons. Default function is for playing OSU!
+
+* Keyboard Maintainer: [Valdy](https://github.com/valdiieee)
+* Hardware Supported: Pro Micro, EC11 rotary encoder, MX Style Switches, Push Buttons, 1n4148 diodes
+* Hardware Availability: Private GB
+
+Make example for this keyboard (after setting up your build environment):
+
+ make makrosu:default
+
+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).
+
diff --git a/keyboards/makrosu/rules.mk b/keyboards/makrosu/rules.mk
new file mode 100644
index 0000000000..d12ce50377
--- /dev/null
+++ b/keyboards/makrosu/rules.mk
@@ -0,0 +1,23 @@
+# 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 = 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
+# 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 = yes # 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