~ruther/qmk_firmware

4d1ed37bdcb3641e35dc2324592a1f7fa0509bd2 — Jordan Blackbourn 3 years ago e910704
Orthocode update default keymap, and fix encoder function for keymaps built in configurator (#15161)

* Updated default keymap to match one shipping with the boards

* Fix encoder function so it works for users
of the online configurator

* Updated Info.json to match default keymap

* Changes as per review
M keyboards/orthocode/info.json => keyboards/orthocode/info.json +6 -6
@@ 5,9 5,9 @@
    "layouts": {
        "LAYOUT": {
            "layout": [
                {"label":"Rotary", "x":0.5, "y":0},
                {"label":"Mute", "x":0.5, "y":0},

                {"label":"Game", "x":0.5, "y":1},
                {"label":"RGB Tog", "x":0.5, "y":1},
                {"label":"Esc", "x":1.75, "y":1},
                {"label":"1", "x":3, "y":1},
                {"label":"2", "x":4, "y":1},


@@ 23,7 23,7 @@
                {"label":"+", "x":16.5, "y":1},
                {"label":"Home", "x":17.5, "y":1},

                {"label":"M1", "x":0.25, "y":2},
                {"label":"RGB Mode", "x":0.25, "y":2},
                {"label":"Tab", "x":1.5, "y":2, "w":1.5},
                {"label":"Q", "x":3, "y":2},
                {"label":"W", "x":4, "y":2},


@@ 39,8 39,8 @@
                {"label":"Delete", "x":17, "y":2},
                {"label":"End", "x":18, "y":2},

                {"label":"M2", "x":0, "y":3},
                {"label":"Ctrl", "x":1.25, "y":3, "w":1.75},
                {"label":"RGB RMode", "x":0, "y":3},
                {"label":"Caps", "x":1.25, "y":3, "w":1.75},
                {"label":"A", "x":3, "y":3},
                {"label":"S", "x":4, "y":3},
                {"label":"D", "x":5, "y":3},


@@ 54,7 54,7 @@
                {"label":"\"", "x":15.5, "y":3},
                {"label":"Enter", "x":16.5, "y":3, "w":2.25},

                {"label":"Layer", "x":0.75, "y":4, "w":2.25},
                {"label":"Shift", "x":0.75, "y":4, "w":2.25},
                {"label":"Z", "x":3, "y":4},
                {"label":"X", "x":4, "y":4},
                {"label":"C", "x":5, "y":4},

M keyboards/orthocode/keymaps/default/keymap.c => keyboards/orthocode/keymaps/default/keymap.c +16 -123
@@ 17,43 17,36 @@

enum custom_keycodes {
  QWERTY = SAFE_RANGE,
  SHIFTSPACE,
  ILIKEFROG
};

#define KC_SHSP SHIFTSPACE
#define KC_FROG ILIKEFROG



const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
    [0] = LAYOUT(
     /* Rotary                                                                                                                                  */
        KC__MUTE,
     /*           esc      1        2        3        4        5        6        7        8        9        0        -        =        home     */
        TG(2),    KC_GESC, 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_HOME,
        RGB_TOG,    KC_GESC, 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_HOME,
     /*           tab      Q        W        E        R        T        Y        U        I        O        P        \        delete   end      */
        RGB_TOG,  KC_TAB,  KC_Q,    KC_W,    KC_E,    KC_R,    KC_T,    KC_Y,    KC_U,    KC_I,    KC_O,    KC_P,    KC_BSLS, KC_DEL,  KC_END,
        RGB_MOD,    KC_TAB,  KC_Q,    KC_W,    KC_E,  KC_R,    KC_T,    KC_Y,    KC_U,   KC_I,    KC_O,    KC_P,    KC_BSLS, KC_DEL,  KC_END,
     /*           caps     A        S        D        F        G        H        J        K        L        ;        '        enter             */
        RGB_MOD,  KC_LCTL, KC_A,    KC_S,    KC_D,    KC_F,    KC_G,    KC_H,    KC_J,    KC_K,    KC_L,    KC_SCLN, KC_QUOT, KC_ENT,
        RGB_RMOD,   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,
     /*           shift    Z        X        C        V        B        N        M        ,        .        /                 up                */
                  KC_LSFT, KC_Z,    KC_X,    KC_C,    KC_V,    KC_B,    KC_N,    KC_M,    KC_COMM, KC_DOT,  KC_SLSH,          KC_UP,
                  KC_LSFT,   KC_Z,    KC_X,    KC_C,  KC_V,    KC_B,    KC_N,    KC_M,   KC_COMM, KC_DOT,  KC_SLSH,          KC_UP,
     /*           ctrl     win      alt      fn       th1      th2      th3      th4      fn       alt      ctrl     left     down     right    */
                  KC_LCTL, KC_LGUI, KC_LALT, MO(1),   KC_RSFT, KC_ENT,  KC_BSPC, KC_SHSP, MO(1),   KC_RALT, KC_RCTL, KC_LEFT, KC_DOWN, KC_RGHT
                  KC_LCTL, KC_LGUI, KC_LALT, MO(1),  KC_RSFT, KC_ENT,  KC_BSPC, KC_SPC, MO(1),   KC_RALT, KC_RCTL, KC_LEFT, KC_DOWN, KC_RIGHT
    ),
    [1] = LAYOUT(
     /* Rotary                                                                                                                                                  */
        KC_TRNS,
     /*          esc      1        2        3        4        5        6        7             8              9              0        -        =        home     */
        TG(3),   KC_GRV,  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_TRNS,
     /*          tab      Q        W        E        R        T        Y        U             I              O              P        \        delete   end      */
        KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, RESET,   KC_TRNS, KC_TRNS, KC_TRNS,      LSFT(KC_LBRC), LSFT(KC_RBRC), KC_TRNS, KC_TRNS, KC_PAUS, KC_TRNS,
     /*          caps     A        S        D        F        G        H        J             K              L              ;        '        enter             */
        KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,      KC_LBRC,       KC_RBRC,       KC_TRNS, KC_TRNS, KC_TRNS,
     /*          shift    Z        X        C        V        B        N        M             ,              .              /                 up                */
                 KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_EQL,  LSFT(KC_EQL), LSFT(KC_9),    LSFT(KC_0),    KC_TRNS,          KC_VOLU,
     /*          ctrl     win      alt      fn       th1      th2      th3      th4           fn             alt            ctrl     left     down     right    */
                 KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_MINS,      KC_TRNS,       KC_TRNS,       KC_TRNS, KC_TRNS, KC_VOLD, KC_TRNS
        TG(2),
     /*          esc      1        2        3        4       5       6        7            8          9           0        -         =     home  */
      KC_TRNS, KC_GRV,  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_TRNS,
     /*          tab      Q       W        E        R        T       Y        U             I           O          P         \      delete     end */
      RGB_HUI, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, RESET,  KC_TRNS,KC_TRNS, KC_TRNS, LSFT(KC_LBRC), LSFT(KC_RBRC), KC_TRNS, KC_TRNS,  KC_PAUS, KC_TRNS,
     /*          caps      A       S        D        F        G      H         J            K          L         ;        '        enter    */
      RGB_HUD, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,KC_TRNS,KC_TRNS, KC_TRNS,     KC_LBRC,    KC_RBRC, KC_TRNS, KC_TRNS,  KC_TRNS,
     /*         shift      Z         X        C       V       B       N       M             ,           .          /                       up      */
              KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,KC_TRNS,KC_TRNS, LSFT(KC_EQL), LSFT(KC_9), LSFT(KC_0), KC_TRNS,             KC_VOLU,
     /*         ctrl     win      alt        fn     th1      th2     th3      th4          fn         alt       ctrl      left     down     right*/
              KC_TRNS, KC_TRNS, KC_TRNS,  KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,  KC_TRNS,  KC_TRNS,   KC_TRNS,  KC_TRNS,   KC_TRNS, KC_VOLD,  KC_TRNS
    ),
    [2] = LAYOUT(
     /* Rotary                                                                                                                                 */


@@ 69,107 62,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
     /*          ctrl     win      alt      fn       th1      th2      th3      th4      fn       alt      ctrl     left     down     right    */
                 KC_TRNS, KC_NO,   KC_TRNS, KC_TRNS, KC_SPC,  KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS

    ),
    [3] = LAYOUT(
     /* Rotary                                                                                                                                 */
        KC_FROG,
     /*          esc      1        2        3        4        5        6        7        8        9        0        -        =        home     */
        TG(3),   KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG,
     /*          tab      Q        W        E        R        T        Y        U        I        O        P        \        delete   end      */
        KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG,
     /*          caps     A        S        D        F        G        H        J        K        L        ;        '        enter             */
        KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG,
     /*          shift    Z        X        C        V        B        N        M        ,        .        /                 up                */
                 KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG,          KC_FROG,
     /*          ctrl     win      alt      fn       th1      th2      th3      th4      fn       alt      ctrl     left     down     right    */
                 KC_FROG, KC_FROG, KC_FROG, MO(1),   KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG, KC_FROG
    )
};




bool process_record_user(uint16_t keycode, keyrecord_t *record) {
    static bool shiftspace_mods = false;
    static int frogchar = 0;
    switch (keycode) {
    case SHIFTSPACE:
        if (record->event.pressed) {
            if(get_mods() & MOD_BIT(KC_RSFT)) {
                register_code(KC_MINS);
                shiftspace_mods = true;
            }
            else {
                register_code(KC_SPC);
            }
        } else {
            if (shiftspace_mods) {
                unregister_code(KC_MINS);
                shiftspace_mods = false;
            } else {
                unregister_code(KC_SPC);
            }
        }
        return false;
        break;
    case ILIKEFROG:
        if (record->event.pressed) {
            switch (frogchar)
            {
            case 0:
                SEND_STRING("I");
                break;
            case 1:
                SEND_STRING(" ");
                break;
            case 2:
                SEND_STRING("L");
                break;
            case 3:
                SEND_STRING("i");
                break;
            case 4:
                SEND_STRING("k");
                break;
            case 5:
                SEND_STRING("e");
                break;
            case 6:
                SEND_STRING(" ");
                break;
            case 7:
                SEND_STRING("F");
                break;
            case 8:
                SEND_STRING("r");
                break;
            case 9:
                SEND_STRING("o");
                break;
            case 10:
                SEND_STRING("g");
                break;
            case 11:
                SEND_STRING(" ");
                break;
            }
            frogchar = (frogchar + 1) % 12;
        }
        break;
    }
    return true;

}


#ifdef ENCODER_ENABLE
bool encoder_update_user(uint8_t index, bool clockwise) {
    // Volume control
    if (clockwise) {
        tap_code(KC_VOLD);
    } else {
        tap_code(KC_VOLU);
    }
    return true;
}
#endif

M keyboards/orthocode/orthocode.c => keyboards/orthocode/orthocode.c +14 -1
@@ 13,4 13,17 @@
 * 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 "orthocode.h"
\ No newline at end of file
#include "orthocode.h"

#ifdef ENCODER_ENABLE
bool encoder_update_kb(uint8_t index, bool clockwise) {
    if (!encoder_update_user(index, clockwise)) { return false; }
    // Volume control
    if (clockwise) {
        tap_code(KC_VOLU);
    } else {
        tap_code(KC_VOLD);
    }
    return true;
}
#endif