From 1f38221ec5ea95429fe3dbc739065b5598fedfc9 Mon Sep 17 00:00:00 2001 From: duoshock <33636898+duoshock@users.noreply.github.com> Date: Thu, 14 Jan 2021 06:57:55 +0000 Subject: [Keyboard] Add ISO Macro keyboard (#11517) * - * - * - * - * - Co-authored-by: online <33636898+online@users.noreply.github.com> --- keyboards/merge/iso_macro/keymaps/default/keymap.c | 49 +++++++++++++++++ .../merge/iso_macro/keymaps/default/readme.md | 5 ++ keyboards/merge/iso_macro/keymaps/via/keymap.c | 64 ++++++++++++++++++++++ keyboards/merge/iso_macro/keymaps/via/rules.mk | 2 + 4 files changed, 120 insertions(+) create mode 100644 keyboards/merge/iso_macro/keymaps/default/keymap.c create mode 100644 keyboards/merge/iso_macro/keymaps/default/readme.md create mode 100644 keyboards/merge/iso_macro/keymaps/via/keymap.c create mode 100644 keyboards/merge/iso_macro/keymaps/via/rules.mk (limited to 'keyboards/merge/iso_macro/keymaps') diff --git a/keyboards/merge/iso_macro/keymaps/default/keymap.c b/keyboards/merge/iso_macro/keymaps/default/keymap.c new file mode 100644 index 0000000000..a86d35502c --- /dev/null +++ b/keyboards/merge/iso_macro/keymaps/default/keymap.c @@ -0,0 +1,49 @@ +/* Copyright 2021 duoshock + * + * 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 . + */ + +#include QMK_KEYBOARD_H + +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { + +/* LAYER 0 + * ,---------------------------------------------. + * | Encoder A | 4 | 5 | 6 | Enter | + * |------------|-------+-------+-------| | + * | Encoder B | 1 | 2 | 3 | | + * `---------------------------------------------' + */ +[0] = LAYOUT( + KC_HOME, KC_4, KC_5, KC_6, KC_ENT, + KC_MUTE, KC_1, KC_2, KC_3 +), +}; + + +void encoder_update_user(uint8_t index, bool clockwise) { + if (index == 0) { // Encdoer A + if (clockwise) { + tap_code(KC_UP); + } else { + tap_code(KC_DOWN); + } + } else if (index == 1) { // Encoder B + if (clockwise) { + tap_code(KC_VOLU); + } else { + tap_code(KC_VOLD); + } + } +} \ No newline at end of file diff --git a/keyboards/merge/iso_macro/keymaps/default/readme.md b/keyboards/merge/iso_macro/keymaps/default/readme.md new file mode 100644 index 0000000000..008d125d4d --- /dev/null +++ b/keyboards/merge/iso_macro/keymaps/default/readme.md @@ -0,0 +1,5 @@ +# Default ISO Macro Layout + +![ISO Macro Layout Image](https://i.imgur.com/5NEfKVz.jpg) + +This is the default layout that comes flashed on every ISO Macro. diff --git a/keyboards/merge/iso_macro/keymaps/via/keymap.c b/keyboards/merge/iso_macro/keymaps/via/keymap.c new file mode 100644 index 0000000000..b97e79acf1 --- /dev/null +++ b/keyboards/merge/iso_macro/keymaps/via/keymap.c @@ -0,0 +1,64 @@ + /* Copyright 2021 duoshock + * + * 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 . + */ + +#include QMK_KEYBOARD_H + +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { + +/* LAYER 0 + * ,---------------------------------------------. + * | Encoder A | 4 | 5 | 6 | Enter | + * |------------|-------+-------+-------| | + * | Encoder B | 1 | 2 | 3 | | + * `---------------------------------------------' + */ +[0] = LAYOUT( + BL_TOGG, KC_4, KC_5, KC_6, KC_ENT, + KC_MUTE, KC_1, KC_2, KC_3 +), + +[1] = LAYOUT( + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS +), + +[2] = LAYOUT( + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS +), + +[3] = LAYOUT( + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS +), +}; + + +void encoder_update_user(uint8_t index, bool clockwise) { + if (index == 0) { // Encoder A + if (clockwise) { + backlight_increase(); + } else { + backlight_decrease(); + } + } else if (index == 1) { // Encoder B + if (clockwise) { + tap_code(KC_VOLU); + } else { + tap_code(KC_VOLD); + } + } +} \ No newline at end of file diff --git a/keyboards/merge/iso_macro/keymaps/via/rules.mk b/keyboards/merge/iso_macro/keymaps/via/rules.mk new file mode 100644 index 0000000000..43061db1dd --- /dev/null +++ b/keyboards/merge/iso_macro/keymaps/via/rules.mk @@ -0,0 +1,2 @@ +VIA_ENABLE = yes +LTO_ENABLE = yes \ No newline at end of file -- cgit v1.2.3