~ruther/qmk_firmware

6e79767f5aa0bad763639846d44c69d3990c7cbe — Felix Springer 4 years ago 3bc7f46
[Keymap] jumper149 keymap for the dztech/dz65rgb (#12142)

A keyboards/dztech/dz65rgb/keymaps/jumper149/config.h => keyboards/dztech/dz65rgb/keymaps/jumper149/config.h +63 -0
@@ 0,0 1,63 @@
/* Copyright 2021 Felix Springer
 *
 * 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

#define FORCE_NKRO

#ifdef RGB_MATRIX_ENABLE

#define DISABLE_RGB_MATRIX_ALPHAS_MODS
#define DISABLE_RGB_MATRIX_GRADIENT_UP_DOWN
#define DISABLE_RGB_MATRIX_BREATHING
#define DISABLE_RGB_MATRIX_BAND_SAT
#define DISABLE_RGB_MATRIX_BAND_VAL
#define DISABLE_RGB_MATRIX_BAND_PINWHEEL_SAT
#define DISABLE_RGB_MATRIX_BAND_PINWHEEL_VAL
#define DISABLE_RGB_MATRIX_BAND_SPIRAL_SAT
#define DISABLE_RGB_MATRIX_BAND_SPIRAL_VAL
#define DISABLE_RGB_MATRIX_CYCLE_ALL
#define DISABLE_RGB_MATRIX_CYCLE_LEFT_RIGHT
#define DISABLE_RGB_MATRIX_CYCLE_UP_DOWN
#define DISABLE_RGB_MATRIX_CYCLE_OUT_IN
#define DISABLE_RGB_MATRIX_CYCLE_OUT_IN_DUAL
#define DISABLE_RGB_MATRIX_RAINBOW_MOVING_CHEVRON
#define DISABLE_RGB_MATRIX_DUAL_BEACON
#define DISABLE_RGB_MATRIX_CYCLE_PINWHEEL
#define DISABLE_RGB_MATRIX_CYCLE_SPIRAL
#define DISABLE_RGB_MATRIX_RAINBOW_BEACON
#define DISABLE_RGB_MATRIX_RAINBOW_PINWHEELS
#define DISABLE_RGB_MATRIX_RAINDROPS
#define DISABLE_RGB_MATRIX_JELLYBEAN_RAINDROPS
#define DISABLE_RGB_MATRIX_TYPING_HEATMAP
#define DISABLE_RGB_MATRIX_DIGITAL_RAIN
#define DISABLE_RGB_MATRIX_SOLID_REACTIVE
#define DISABLE_RGB_MATRIX_SOLID_REACTIVE_SIMPLE
#define DISABLE_RGB_MATRIX_SOLID_REACTIVE_WIDE
#define DISABLE_RGB_MATRIX_SOLID_REACTIVE_MULTIWIDE
#define DISABLE_RGB_MATRIX_SOLID_REACTIVE_CROSS
#define DISABLE_RGB_MATRIX_SOLID_REACTIVE_MULTICROSS
#define DISABLE_RGB_MATRIX_SOLID_REACTIVE_NEXUS
#define DISABLE_RGB_MATRIX_SOLID_REACTIVE_MULTINEXUS
#define DISABLE_RGB_MATRIX_SPLASH
#define DISABLE_RGB_MATRIX_MULTISPLASH
#define DISABLE_RGB_MATRIX_SOLID_SPLASH
#define DISABLE_RGB_MATRIX_SOLID_MULTISPLASH

// Fix RGB_MATRIX_STARTUP, because RGB_MATRIX_CYCLE_ALL is disabled.
// The actual handling of RGB_EFFECTs is done in keymap.c
#undef RGB_MATRIX_STARTUP_MODE

#endif

A keyboards/dztech/dz65rgb/keymaps/jumper149/keymap.c => keyboards/dztech/dz65rgb/keymaps/jumper149/keymap.c +120 -0
@@ 0,0 1,120 @@
/* Copyright 2021 Felix Springer
 *
 * 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 layers_user {
    _QWERTY,
    _AD,
    _VI,
    _FN,
    _KB
};

enum keycodes_user {
    _BASEEF = SAFE_RANGE,
    _KITTEF
};

int selected_mode_user = RGB_MATRIX_CUSTOM_base_effect; // for layer_state_set_user()
bool process_record_user(uint16_t keycode, keyrecord_t * record) {
    switch (keycode) {
        case _BASEEF:
            if (record->event.pressed) {
                selected_mode_user = RGB_MATRIX_CUSTOM_base_effect;
            }
            return false;
        case _KITTEF:
            if (record->event.pressed) {
                selected_mode_user = RGB_MATRIX_CUSTOM_kitt_effect;
            }
            return false;
        default:
            return true;
    }
}

const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
    [_QWERTY] = LAYOUT_65_ansi(
        KC_GRAVE,       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_BSPC, KC_HOME,
        KC_TAB,         KC_Q,    KC_W,    KC_E,    KC_R,    KC_T,    KC_Y,    KC_U,    KC_I,    KC_O,    KC_P,    KC_LBRC, KC_RBRC, KC_BSLS, KC_PGUP,
        KC_ESC,         KC_A,    KC_S,    KC_D,    KC_F,    KC_G,    KC_H,    KC_J,    KC_K,    KC_L,    KC_SCLN, KC_QUOT,          KC_ENT,  KC_PGDN,
        KC_LSFT,                 KC_Z,    KC_X,    KC_C,    KC_V,    KC_B,    KC_N,    KC_M,    KC_COMM, KC_DOT,  KC_SLSH, KC_RSFT, KC_UP,   KC_END,
        KC_LCTL,        KC_LGUI, KC_LALT,                            KC_SPC,                    KC_RALT, MO(_FN), KC_RCTL, KC_LEFT, KC_DOWN, KC_RGHT
    ),
    [_AD] = LAYOUT_65_ansi(
        _______,        _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_DEL,
        _______,        _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_INS,
        _______,        _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,          _______, KC_HOME,
        _______,                 _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_END,
        _______,        _______, _______,                            _______,                   _______, _______, _______, _______, _______, _______
    ),
    [_VI] = LAYOUT_65_ansi(
        KC_ESC,         XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX,
        _______,        XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_PGUP, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX,
        KC_ESC,         XXXXXXX, XXXXXXX, KC_PGDN, XXXXXXX, XXXXXXX, KC_LEFT, KC_DOWN, KC_UP,   KC_RGHT, XXXXXXX, XXXXXXX,          _______, XXXXXXX,
        _______,                 XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_FIND, _______, _______, XXXXXXX,
        _______,        _______, _______,                            _______,                   _______, _______, _______, _______, _______, _______
    ),
    [_FN] = LAYOUT_65_ansi(
        XXXXXXX,        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_DEL,  KC_INS,
        XXXXXXX,        KC_MUTE, KC_VOLU, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_PSCR, KC_SLCK, KC_PAUS, XXXXXXX, KC_PSTE,
        CTL_T(KC_CAPS), KC_BRID, KC_VOLD, KC_BRIU, XXXXXXX, XXXXXXX, TG(_AD), TG(_VI), XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX,          XXXXXXX, KC_COPY,
        KC_LSFT,                 XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_APP,  XXXXXXX, XXXXXXX, XXXXXXX, KC_RSFT, KC_MSTP, KC_CUT,
        KC_LCTL,        KC_LGUI, KC_LALT,                            XXXXXXX,                   MO(_KB), XXXXXXX, KC_RCTL, KC_MPRV, KC_MPLY, KC_MNXT
    ),
    [_KB] = LAYOUT_65_ansi(
        XXXXXXX,        XXXXXXX, XXXXXXX, XXXXXXX, RGB_SPI, RGB_SPD, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, RESET,   XXXXXXX,
        XXXXXXX,        RGB_TOG, RGB_MOD, RGB_HUI, RGB_HUD, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX,
        XXXXXXX,        XXXXXXX, RGB_SAI, RGB_SAD, XXXXXXX, XXXXXXX, _BASEEF, _KITTEF, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX,          EEP_RST, XXXXXXX,
        KC_LSFT,                 RGB_VAI, RGB_VAD, XXXXXXX, XXXXXXX, XXXXXXX, NK_TOGG, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_RSFT, XXXXXXX, XXXXXXX,
        XXXXXXX,        XXXXXXX, XXXXXXX,                            XXXXXXX,                   XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX
    )
    /*
    [_LEDS]    = LAYOUT_65_ansi(
         0  ,            1  ,     2  ,     3  ,     4  ,     5  ,     6  ,     7  ,     8  ,     9  ,    10  ,    11  ,    12  ,    13  ,    14  ,
        15  ,           16 Q,    17 W,    18 E,    19 R,    20 T,    21 Y,    22 U,    23 I,    24 O,    25 P,    26  ,    27  ,    28  ,    29  ,
        30  ,           31 A,    32 S,    33 D,    34 F,    35 G,    36 H,    37 J,    38 K,    39 L,    40  ,    41  ,             42  ,    43  ,
        44  ,                    45 Z,    46 X,    47 C,    48 V,    49 B,    50 N,    51 M,    52  ,    53  ,    54  ,    55  ,    56  ,    57  ,
        58  ,           59  ,    60  ,                               61  ,                      62  ,    63  ,    64  ,    65  ,    66  ,    67
    )
    */
};

layer_state_t layer_state_set_user(layer_state_t state) {
    switch (get_highest_layer(state)) {
        case _QWERTY:
            rgb_matrix_mode(selected_mode_user);
            break;
        case _AD:
            if (selected_mode_user == RGB_MATRIX_CUSTOM_base_effect) {
                rgb_matrix_mode(RGB_MATRIX_CUSTOM_base_ad_effect);
            } else {
                rgb_matrix_mode(selected_mode_user);
            }
            break;
        case _VI:
            rgb_matrix_mode(RGB_MATRIX_CUSTOM_vi_effect);
            break;
        case _FN:
            rgb_matrix_mode(RGB_MATRIX_CUSTOM_fn_indicator);
            break;
        case _KB:
            rgb_matrix_mode(RGB_MATRIX_CUSTOM_kb_indicator);
            break;
    }

    return state;
}

A keyboards/dztech/dz65rgb/keymaps/jumper149/readme.md => keyboards/dztech/dz65rgb/keymaps/jumper149/readme.md +24 -0
@@ 0,0 1,24 @@
# jumper149's DZ65RGB v2

Run commands in the root directory of this repository.

```
./bin/qmk compile && sudo dfu-programmer atmega32u4 erase && sudo dfu-programmer atmega32u4 flash ./dztech_dz65rgb_v2_jumper149.hex && sudo dfu-programmer atmega32u4 reset
```

## build

```
./bin/qmk compile
```

## flash

Use `qmk flash` or if it is broken (unknown reason) you can try this workaround.
I personally had some problems on ArchLinux, that I didn't debug any further though.

```
sudo dfu-programmer atmega32u4 erase
sudo dfu-programmer atmega32u4 flash ./dztech_dz65rgb_v2_jumper149.hex
sudo dfu-programmer atmega32u4 reset
```

A keyboards/dztech/dz65rgb/keymaps/jumper149/rgb_matrix_user.inc => keyboards/dztech/dz65rgb/keymaps/jumper149/rgb_matrix_user.inc +700 -0
@@ 0,0 1,700 @@
/* Copyright 2021 Felix Springer
 *
 * 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/>.
 */
RGB_MATRIX_EFFECT(base_effect)
RGB_MATRIX_EFFECT(base_ad_effect)
RGB_MATRIX_EFFECT(vi_effect)
RGB_MATRIX_EFFECT(fn_indicator)
RGB_MATRIX_EFFECT(kb_indicator)
RGB_MATRIX_EFFECT(kitt_effect)

#ifdef RGB_MATRIX_CUSTOM_EFFECT_IMPLS

/*
[_LEDS]    = LAYOUT_65_ansi(
     0  ,            1  ,     2  ,     3  ,     4  ,     5  ,     6  ,     7  ,     8  ,     9  ,    10  ,    11  ,    12  ,    13  ,    14  ,
    15  ,           16 Q,    17 W,    18 E,    19 R,    20 T,    21 Y,    22 U,    23 I,    24 O,    25 P,    26  ,    27  ,    28  ,    29  ,
    30  ,           31 A,    32 S,    33 D,    34 F,    35 G,    36 H,    37 J,    38 K,    39 L,    40  ,    41  ,             42  ,    43  ,
    44  ,                    45 Z,    46 X,    47 C,    48 V,    49 B,    50 N,    51 M,    52  ,    53  ,    54  ,    55  ,    56  ,    57  ,
    58  ,           59  ,    60  ,                               61  ,                      62  ,    63  ,    64  ,    65  ,    66  ,    67
)
*/

// variable for startup animation
bool BASE_EFFECT_NOT_STARTED_YET = true;
uint8_t base_effect_startup_counter = 255;

static HSV base_effect_math(HSV hsv, uint8_t i, uint8_t time) {

    if (BASE_EFFECT_NOT_STARTED_YET) {
        base_effect_startup_counter = 0;
        BASE_EFFECT_NOT_STARTED_YET = false;
    }

    // startup animation
    if (base_effect_startup_counter < 255) {

        // jump to correct indices for alpha keys
        if (i == 0) { // only run for one key (key 0 is an arbitrary choice)
            if (base_effect_startup_counter == 0) {
                base_effect_startup_counter = 1;
            } else if (base_effect_startup_counter == 1) {
                base_effect_startup_counter = 17;
            } else if (base_effect_startup_counter == 26) {
                base_effect_startup_counter = 31;
            } else if (base_effect_startup_counter == 40) {
                base_effect_startup_counter = 45;
            } else if (base_effect_startup_counter == 52) {
                base_effect_startup_counter = 100;
            } else if (base_effect_startup_counter == 120) {
                base_effect_startup_counter = 255;
            } else {
                base_effect_startup_counter++;
            }
        }

        // overwrite some highlit keys
        if (3 + 39 - i < base_effect_startup_counter - 100 && i >= 36 && i <= 39) {
            hsv.s = hsv.s;
        } else if (3 + 39 - i < base_effect_startup_counter - 100 && i >= 31 && i <= 34) {
            hsv.s = hsv.s;
        // light up alpha keys
        } else if (i < base_effect_startup_counter && i >= 16 && i <= 25) {
            hsv.s = 0;
        } else if (31 + 39 - i < base_effect_startup_counter && i >= 31 && i <= 39) {
            hsv.s = 0;
        } else if (i < base_effect_startup_counter && i >= 45 && i <= 51) {
            hsv.s = 0;
        // light up number row
        } else if (12 + 1 - i < base_effect_startup_counter - 100 && i == 2) {
            hsv.s = 0;
            hsv.v = 1 * (hsv.v / 8);
        } else if (12 + 1 - i < base_effect_startup_counter - 100 && i == 3) {
            hsv.s = 0;
            hsv.v = 2 * (hsv.v / 8);
        } else if (12 + 1 - i < base_effect_startup_counter - 100 && i == 4) {
            hsv.s = 0;
            hsv.v = 3 * (hsv.v / 8);
        } else if (12 + 1 - i < base_effect_startup_counter - 100 && i >= 5 && i <= 8) {
            hsv.v = hsv.v;
        } else if (12 + 1 - i < base_effect_startup_counter - 100 && i == 9) {
            hsv.s = 0;
            hsv.v = 3 * (hsv.v / 8);
        } else if (12 + 1 - i < base_effect_startup_counter - 100 && i == 10) {
            hsv.s = 0;
            hsv.v = 2 * (hsv.v / 8);
        } else if (12 + 1 - i < base_effect_startup_counter - 100 && i == 11) {
            hsv.s = 0;
            hsv.v = 1 * (hsv.v / 8);
        // light up punctuation keys
        } else if (27 + 1 - i < base_effect_startup_counter - 100 && i >= 26 && i <= 27) {
            hsv.s = 0;
            hsv.v = hsv.v / 8;
        } else if (41 + 2 - i < base_effect_startup_counter - 100 && i >= 40 && i <= 41) {
            hsv.s = 0;
            hsv.v = hsv.v / 8;
        } else if (54 + 3 - i < base_effect_startup_counter - 100 && i >= 52 && i <= 54) {
            hsv.s = 0;
            hsv.v = hsv.v / 8;
        // rest
        } else {
            hsv.v = 0;
        }

    } else {

        switch (i) {

            // number row
            case 0:
                hsv.v = 0;
                break;
            case 1:
                hsv.v = 0;
                break;
            case 2:
                hsv.s = 0;
                hsv.v = 1 * (hsv.v / 8);
                break;
            case 3:
                hsv.s = 0;
                hsv.v = 2 * (hsv.v / 8);
                break;
            case 4:
                hsv.s = 0;
                hsv.v = 3 * (hsv.v / 8);
                break;
            case 5:
                hsv.v = hsv.v;
                break;
            case 6:
                hsv.v = hsv.v;
                break;
            case 7:
                hsv.v = hsv.v;
                break;
            case 8:
                hsv.v = hsv.v;
                break;
            case 9:
                hsv.s = 0;
                hsv.v = 3 * (hsv.v / 8);
                break;
            case 10:
                hsv.s = 0;
                hsv.v = 2 * (hsv.v / 8);
                break;
            case 11:
                hsv.s = 0;
                hsv.v = 1 * (hsv.v / 8);
                break;
            case 12:
                hsv.v = 0;
                break;

            // punctuation keys
            case 26:
                hsv.s = 0;
                hsv.v = hsv.v / 8;
                break;
            case 27:
                hsv.s = 0;
                hsv.v = hsv.v / 8;
                break;
            case 40:
                hsv.s = 0;
                hsv.v = hsv.v / 8;
                break;
            case 41:
                hsv.s = 0;
                hsv.v = hsv.v / 8;
                break;
            case 52:
                hsv.s = 0;
                hsv.v = hsv.v / 8;
                break;
            case 53:
                hsv.s = 0;
                hsv.v = hsv.v / 8;
                break;
            case 54:
                hsv.s = 0;
                hsv.v = hsv.v / 8;
                break;

            default:
                if (
                    (i > 15 && i <= 25) ||
                    (i > 30 && i <= 39) ||
                    (i > 44 && i <= 51)
                ) {
                    if (i > 35 && i <= 39) {
                        hsv.s = hsv.s;
                    } else if (i > 30 && i <= 34) {
                        hsv.s = hsv.s;
                    } else {
                        hsv.s = 0;
                    }
                } else {
                    hsv.v = 0;
                }
                break;

        }

    }

    return hsv;
}

bool base_effect(effect_params_t* params) {
    return effect_runner_i(params, &base_effect_math);
}

static HSV base_ad_effect_math(HSV hsv, uint8_t i, uint8_t time) {

    // no startup animation
    if (BASE_EFFECT_NOT_STARTED_YET) {
        base_effect_startup_counter = 255; // act like startup is already completed
        BASE_EFFECT_NOT_STARTED_YET = false;
    }

    switch (i) {

        // delete
        case 14:
            hsv.h = 0;
            hsv.s = 255;
            break;

        // insert
        case 29:
            hsv.h = 255/3;
            hsv.s = 255;
            break;

        // home
        case 43:
            hsv.s = 0;
            break;

        // end
        case 57:
            hsv.s = 255;
            break;

        default:
            hsv = base_effect_math(hsv, i, time);
            break;

    }

    return hsv;
}

bool base_ad_effect(effect_params_t* params) {
    return effect_runner_i(params, &base_ad_effect_math);
}

static HSV vi_effect_math(HSV hsv, uint8_t i, uint8_t time) {

    // no startup animation
    if (BASE_EFFECT_NOT_STARTED_YET) {
        base_effect_startup_counter = 255; // act like startup is already completed
        BASE_EFFECT_NOT_STARTED_YET = false;
    }

    switch (i) {

        // hjkl
        case 36:
            break;
        case 37:
            break;
        case 38:
            break;
        case 39:
            break;

        // page up
        case 22:
            hsv.s = 0;
            break;

        // page down
        case 33:
            hsv.s = 0;
            break;

        // find
        case 54:
            hsv.s = 0;
            break;

        default:
            hsv.v = 0;
            break;

    }

    return hsv;
}

bool vi_effect(effect_params_t* params) {
    return effect_runner_i(params, &vi_effect_math);
}

static HSV fn_indicator_math(HSV hsv, uint8_t i, uint8_t time) {

    // cancel base effect startup
    base_effect_startup_counter = 255;

    switch (i) {

        // F1 - F12
        case 1:
            hsv.h = 0 * 255 / 3;
            hsv.s = 255;
            break;
        case 2:
            hsv.h = 0 * 255 / 3;
            hsv.s = 255;
            break;
        case 3:
            hsv.h = 0 * 255 / 3;
            hsv.s = 255;
            break;
        case 4:
            hsv.h = 0 * 255 / 3;
            hsv.s = 255;
            break;
        case 5:
            hsv.h = 1 * 255 / 3;
            hsv.s = 255;
            break;
        case 6:
            hsv.h = 1 * 255 / 3;
            hsv.s = 255;
            break;
        case 7:
            hsv.h = 1 * 255 / 3;
            hsv.s = 255;
            break;
        case 8:
            hsv.h = 1 * 255 / 3;
            hsv.s = 255;
            break;
        case 9:
            hsv.h = 2 * 255 / 3;
            hsv.s = 255;
            break;
        case 10:
            hsv.h = 2 * 255 / 3;
            hsv.s = 255;
            break;
        case 11:
            hsv.h = 2 * 255 / 3;
            hsv.s = 255;
            break;
        case 12:
            hsv.h = 2 * 255 / 3;
            hsv.s = 255;
            break;

        // delete/insert
        case 13:
            hsv.h = 0;
            hsv.s = 255;
            break;
        case 14:
            hsv.h = 1 * (255 / 3);
            hsv.s = 255;
            break;

        // paste/copy/cut
        case 29:
            hsv.s = 0;
            break;
        case 43:
            hsv.h = 200;
            hsv.s = 255;
            break;
        case 57:
            hsv.h = 0;
            hsv.s = 255;
            break;

        // print/scroll/pause
        case 25:
            hsv.s = 0;
            break;
        case 26:
            hsv.s = 0;
            break;
        case 27:
            hsv.s = 0;
            break;

        // caps lock
        case 30:
            hsv.s = 0;
            break;

        // modifier
        case 44:
            hsv.s = 0;
            hsv.v = hsv.v / 2;
            break;
        case 55:
            hsv.s = 0;
            hsv.v = hsv.v / 2;
            break;
        case 58:
            hsv.s = 0;
            hsv.v = hsv.v / 2;
            break;
        case 59:
            hsv.s = 0;
            hsv.v = hsv.v / 2;
            break;
        case 60:
            hsv.s = 0;
            hsv.v = hsv.v / 2;
            break;
        case 64:
            hsv.s = 0;
            hsv.v = hsv.v / 2;
            break;

        // volume
        case 18: // mute
            hsv.h = 0;
            break;
        case 17: // increase
            hsv.s = 255;
            break;
        case 32: // decrease
            hsv.s = 0;
            break;

        // brightness
        case 33: // increase
            hsv.s = 255;
            break;
        case 31: // decrease
            hsv.s = 0;
            break;

        // media
        case 65: // previous
            hsv.s = 0;
            break;
        case 67: // next
            hsv.s = 0;
            break;
        case 56: // stop
            hsv.h = 0;
            break;
        case 66: // play/pause
            hsv.h = 255/3;
            break;

        // menu
        case 51:
            hsv.s = 0;
            break;

        // toggle AD layer
        case 36:
            hsv.h = 0;
            break;

        // toggle VI layer
        case 37:
            hsv.h = 255/3;
            break;

        // KB layer
        case 62:
            hsv.h = time;
            hsv.s = 255;
            break;

        // no function
        default:
            hsv.v = 0;
            break;

    }

    return hsv;
}

bool fn_indicator(effect_params_t* params) {
    return effect_runner_i(params, &fn_indicator_math);
}

static HSV kb_indicator_math(HSV hsv, uint8_t i, uint8_t time) {

    // cancel base effect startup
    base_effect_startup_counter = 255;

    switch (i) {

        // test HSV
        case 14:
            break;
        case 29:
            break;
        case 43:
            break;
        case 57:
            break;
        case 67:
            break;

        // toggle RGB
        case 16:
            hsv.s = 0;
            if (time < (255 / 2)) {
                hsv.v = 255;
            } else {
                hsv.v = 0;
            }
            break;

        // cycle effect
        case 17:
            hsv.s = 255;
            hsv.v = 255;
            if (time < (255 / 3)) {
                hsv.h = 0;
            } else if (time < (2 * 255 / 3)) {
                hsv.h = 255 / 3;
            } else {
                hsv.h = 2 * 255 / 3;
            }
            break;

        // adjust hue
        case 18:
            hsv.h = time;
            hsv.s = 255;
            hsv.v = 255;
            break;
        case 19:
            hsv.h = 255 - time;
            hsv.s = 255;
            hsv.v = 255;
            break;

        // adjust saturation
        case 32:
            hsv.s = 255;
            hsv.v = 255;
            break;
        case 33:
            hsv.s = 0;
            hsv.v = 255;
            break;

        // adjust value
        case 45:
            hsv.v = 255;
            break;
        case 46:
            hsv.v = 63;
            break;

        // adjust speed
        case 4:
            if (((time / 8) % 2) == 0) {
                hsv.v = 255;
            } else {
                hsv.v = 63;
            }
            break;
        case 5:
            if (((time / 16) % 2) == 0) {
                hsv.v = 63;
            } else {
                hsv.v = 255;
            }
            break;

        // set main effect
        case 36: // BASE
            hsv.s = 0;
            break;
        case 37: // KITT
            hsv.h = 0;
            hsv.s = 255;
            if (time < 128) {
                hsv.v = time;
            } else {
                hsv.v = 255 - time;
            }
            break;

        // reset (for flashing)
        case 13:
            hsv.s = 0;
            if (time < 16) {
                hsv.v = 255 - time * 128 / 16;
            } else {
                hsv.v = 127;
            }
            break;

        // reset (reinitialize EEPROM)
        case 42:
            hsv.s = 0;
            hsv.v = 127;
            break;

        // shift
        case 44:
            hsv.s = 0;
            hsv.v = 63;
            break;
        case 55:
            hsv.s = 0;
            hsv.v = 63;
            break;

        // no function
        default:
            hsv.v = 0;

    }

    return hsv;
}

bool kb_indicator(effect_params_t* params) {
    return effect_runner_i(params, &kb_indicator_math);
}

uint8_t led_count = 7;
uint8_t led_first = 33;
static uint8_t time_to_led(uint8_t time, uint8_t led_behind) {
    uint16_t led_time = led_count * time;
    uint16_t step = ((2 * led_count + (led_time / 128)) - led_behind) % (2 * led_count);
    uint8_t led;
    if (step < led_count) {
        led = step;
    } else {
        led = led_count - 1 - (step - led_count);
    }
    return led;
}

static HSV kitt_effect_math(HSV hsv, uint8_t i, uint8_t time) {

    // reset base effect startup
    if (i == 0) {
        BASE_EFFECT_NOT_STARTED_YET = true;
    }

    hsv.h = 0;
    hsv.s = 255;

    if (i >= led_first && i < led_first + led_count) {
        uint8_t j = i - led_first;
        if (j == time_to_led(time, 0)) {
            hsv.v = hsv.v;
        } else if (j == time_to_led(time, 1)) {
            hsv.v = hsv.v/2;
        } else if (j == time_to_led(time, 2)) {
            hsv.v = hsv.v/4;
        } else if (j == time_to_led(time, 3)) {
            hsv.v = hsv.v/8;
        } else {
            hsv.v = 0;
        }
    } else {
        hsv.v = 0;
    }

    return hsv;
}

bool kitt_effect(effect_params_t* params) {
    return effect_runner_i(params, &kitt_effect_math);
}

#endif // RGB_MATRIX_CUSTOM_EFFECT_IMPLS

// vim: syntax=c

A keyboards/dztech/dz65rgb/keymaps/jumper149/rules.mk => keyboards/dztech/dz65rgb/keymaps/jumper149/rules.mk +1 -0
@@ 0,0 1,1 @@
RGB_MATRIX_CUSTOM_USER = yes