/* Copyright 2020 Duckle * * 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 #include "analog.h" #include "qmk_midi.h" // Defines names for use in layer keycodes and the keymap enum layer_names { _BASE, _FN, _DEMO }; // Defines the keycodes used by our macros in process_record_user enum custom_keycodes { QMKBEST = SAFE_RANGE, QMKURL }; const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { /* Base */ [_BASE] = LAYOUT( TO(_FN), KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_0 ), [_FN] = LAYOUT( TO(_DEMO), RGB_TOG, RGB_MOD, RGB_VAI, _______, _______, _______, _______ ), [_DEMO] = LAYOUT( TO(_BASE), QMKBEST, _______, _______, _______, _______, _______, QMKURL ) }; bool process_record_user(uint16_t keycode, keyrecord_t *record) { switch (keycode) { case QMKBEST: if (record->event.pressed) { // when keycode QMKBEST is pressed SEND_STRING("QMK is the best thing ever!"); } else { // when keycode QMKBEST is released } break; case QMKURL: if (record->event.pressed) { // when keycode QMKURL is pressed SEND_STRING("https://qmk.fm/\n"); } else { // when keycode QMKURL is released } break; } return true; } uint8_t divisor = 0; void slider(void) { if (divisor++) { // only run the slider function 1/256 times it's called return; } midi_send_cc(&midi_device, 2, 0x3E, 0x7F - (analogReadPin(SLIDER_PIN) >> 3)); } void matrix_scan_user(void) { slider(); }