Merge remote-tracking branch 'origin/master' into develop
This commit is contained in:
commit
e3404d21fe
16 changed files with 2310 additions and 0 deletions
64
keyboards/mechlovin/infinity875/config.h
Normal file
64
keyboards/mechlovin/infinity875/config.h
Normal file
|
@ -0,0 +1,64 @@
|
||||||
|
/*
|
||||||
|
Copyright 2021 Mechlovin' Studio
|
||||||
|
|
||||||
|
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 0x4D4C // ML
|
||||||
|
#define PRODUCT_ID 0x0875
|
||||||
|
#define DEVICE_VER 0x0001
|
||||||
|
#define PRODUCT Infinity87.5
|
||||||
|
/* key matrix size */
|
||||||
|
#define MATRIX_ROWS 6
|
||||||
|
#define MATRIX_COLS 17
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Keyboard Matrix Assignments
|
||||||
|
*
|
||||||
|
* Change this to how you wired your keyboard
|
||||||
|
* COLS: AVR pins used for columns, left to right
|
||||||
|
* ROWS: AVR pins used for rows, top to bottom
|
||||||
|
* DIODE_DIRECTION: COL2ROW = COL = Anode (+), ROW = Cathode (-, marked on diode)
|
||||||
|
* ROW2COL = ROW = Anode (+), COL = Cathode (-, marked on diode)
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define MATRIX_ROW_PINS { D5, D2, D4, D3, D0, D1 }
|
||||||
|
#define UNUSED_PINS
|
||||||
|
|
||||||
|
/* COL2ROW, ROW2COL*/
|
||||||
|
#define DIODE_DIRECTION ROW2COL
|
||||||
|
|
||||||
|
#define LED_CAPS_LOCK_PIN D6
|
||||||
|
#define LED_SCROLL_LOCK_PIN B4
|
||||||
|
#define LED_PIN_ON_STATE 1
|
||||||
|
|
||||||
|
#ifdef RGB_MATRIX_ENABLE
|
||||||
|
#define RGB_DI_PIN E2
|
||||||
|
#define DRIVER_LED_TOTAL 42
|
||||||
|
#define RGB_DISABLE_AFTER_TIMEOUT 0 // number of ticks to wait until disabling effects
|
||||||
|
#define RGB_DISABLE_WHEN_USB_SUSPENDED // turn off effects when suspended
|
||||||
|
#define RGB_MATRIX_LED_FLUSH_LIMIT 16 // limits in milliseconds how frequently an animation will update the LEDs. 16 (16ms) is equivalent to limiting to 60fps (increases keyboard responsiveness)
|
||||||
|
#define RGB_MATRIX_MAXIMUM_BRIGHTNESS 220 // limits maximum brightness of LEDs to 200 out of 255. If not defined maximum brightness is set to 255
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* Bootmagic Lite key configuration */
|
||||||
|
//#define BOOTMAGIC_LITE_ROW 0
|
||||||
|
//#define BOOTMAGIC_LITE_COLUMN 0
|
45
keyboards/mechlovin/infinity875/infinity875.c
Normal file
45
keyboards/mechlovin/infinity875/infinity875.c
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
/* Copyright 2021 Mechlovin' Studio
|
||||||
|
*
|
||||||
|
* 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 "infinity875.h"
|
||||||
|
#ifdef RGB_MATRIX_ENABLE
|
||||||
|
led_config_t g_led_config = { {
|
||||||
|
//Key Matrix to LED Index
|
||||||
|
{0, 1, 2, 3, 4, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17},
|
||||||
|
{NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED},
|
||||||
|
{NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED},
|
||||||
|
{NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED},
|
||||||
|
{NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED},
|
||||||
|
{NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED, NO_LED}
|
||||||
|
}, {
|
||||||
|
//LED Index to Physical Positon
|
||||||
|
{0,0}, {14,0}, {28,0}, {42,0}, {56,0}, {67,0}, {70,0}, {84,0}, {98,0}, {112,0}, {126,0}, {140,0}, {154,0}, {168,0}, {182,0}, {196,0}, {210,0}, {224,0},
|
||||||
|
{224,13}, {196,13}, {182,13}, {154,13}, {112,13}, {84,13}, {56,13}, {28,13}, {0,13},
|
||||||
|
{0,25}, {0,38},
|
||||||
|
{0,51}, {0,64},
|
||||||
|
{28,64}, {56,64},
|
||||||
|
{84,64}, {112,64}, {154,64}, {182,64}, {196,64}, {224,64}, {224,51}, {224,38}, {224,25},
|
||||||
|
//{244,64}, {196,64}, {182,64}, {154,64}, {112,64}, {84,64}, {56,64}, {28,64}, {0,64},
|
||||||
|
}, {
|
||||||
|
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
||||||
|
1, 1, 1, 1, 1, 1, 1, 1, 1,
|
||||||
|
1, 1,
|
||||||
|
1, 1,
|
||||||
|
1, 1,
|
||||||
|
1, 1, 1, 1, 1, 1, 1, 1, 1,
|
||||||
|
} };
|
||||||
|
#endif
|
||||||
|
|
99
keyboards/mechlovin/infinity875/infinity875.h
Normal file
99
keyboards/mechlovin/infinity875/infinity875.h
Normal file
|
@ -0,0 +1,99 @@
|
||||||
|
/* Copyright 2021 Mechlovin' Studio
|
||||||
|
*
|
||||||
|
* 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 "quantum.h"
|
||||||
|
|
||||||
|
#define LAYOUT_all( \
|
||||||
|
K00, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D, K0E, K0F, K0G, \
|
||||||
|
K10, K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, K1C, K1D, K2D, K1E, K1F, K1G, \
|
||||||
|
K20, K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A, K2B, K2C, K3C, K2E, K2F, K2G, \
|
||||||
|
K30, K31, K32, K33, K34, K35, K36, K37, K38, K39, K3A, K3B, K3D, \
|
||||||
|
K40, K41, K42, K43, K44, K45, K46, K47, K48, K49, K4A, K4B, K4C, K4D, K4F, \
|
||||||
|
K50, K51, K52, K56, K5A, K5B, K5C, K5D, K5E, K5F, K5G \
|
||||||
|
) { \
|
||||||
|
{ K00, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D, K0E, K0F, K0G }, \
|
||||||
|
{ K10, K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, K1C, K1D, K1E, K1F, K1G }, \
|
||||||
|
{ K20, K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A, K2B, K2C, K2D, K2E, K2F, K2G }, \
|
||||||
|
{ K30, K31, K32, K33, K34, K35, K36, K37, K38, K39, K3A, K3B, K3C, K3D, KC_NO, KC_NO, KC_NO }, \
|
||||||
|
{ K40, K41, K42, K43, K44, K45, K46, K47, K48, K49, K4A, K4B, K4C, K4D, KC_NO, K4F, KC_NO }, \
|
||||||
|
{ K50, K51, K52, KC_NO, KC_NO, KC_NO, K56, KC_NO, KC_NO, KC_NO, K5A, K5B, K5C, K5D, K5E, K5F, K5G }, \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define LAYOUT_tkl_f13_ansi_split_bs_rshift( \
|
||||||
|
K00, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D, K0E, K0F, K0G, \
|
||||||
|
K10, K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, K1C, K1D, K2D, K1E, K1F, K1G, \
|
||||||
|
K20, K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A, K2B, K2C, K3C, K2E, K2F, K2G, \
|
||||||
|
K30, K31, K32, K33, K34, K35, K36, K37, K38, K39, K3A, K3B, K3D, \
|
||||||
|
K40, K42, K43, K44, K45, K46, K47, K48, K49, K4A, K4B, K4C, K4D, K4F, \
|
||||||
|
K50, K51, K52, K56, K5A, K5B, K5C, K5D, K5E, K5F, K5G \
|
||||||
|
) { \
|
||||||
|
{ K00, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D, K0E, K0F, K0G }, \
|
||||||
|
{ K10, K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, K1C, K1D, K1E, K1F, K1G }, \
|
||||||
|
{ K20, K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A, K2B, K2C, K2D, K2E, K2F, K2G }, \
|
||||||
|
{ K30, K31, K32, K33, K34, K35, K36, K37, K38, K39, K3A, K3B, K3C, K3D, KC_NO, KC_NO, KC_NO }, \
|
||||||
|
{ K40, KC_NO, K42, K43, K44, K45, K46, K47, K48, K49, K4A, K4B, K4C, K4D, KC_NO, K4F, KC_NO }, \
|
||||||
|
{ K50, K51, K52, KC_NO, KC_NO, KC_NO, K56, KC_NO, KC_NO, KC_NO, K5A, K5B, K5C, K5D, K5E, K5F, K5G }, \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define LAYOUT_tkl_f13_iso_split_bs_rshift( \
|
||||||
|
K00, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D, K0E, K0F, K0G, \
|
||||||
|
K10, K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, K1C, K1D, K2D, K1E, K1F, K1G, \
|
||||||
|
K20, K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A, K2B, K2C, K2E, K2F, K2G, \
|
||||||
|
K30, K31, K32, K33, K34, K35, K36, K37, K38, K39, K3A, K3B, K3C, K3D, \
|
||||||
|
K40, K41, K42, K43, K44, K45, K46, K47, K48, K49, K4A, K4B, K4C, K4D, K4F, \
|
||||||
|
K50, K51, K52, K56, K5A, K5B, K5C, K5D, K5E, K5F, K5G \
|
||||||
|
) { \
|
||||||
|
{ K00, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D, K0E, K0F, K0G }, \
|
||||||
|
{ K10, K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, K1C, K1D, K1E, K1F, K1G }, \
|
||||||
|
{ K20, K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A, K2B, K2C, K2D, K2E, K2F, K2G }, \
|
||||||
|
{ K30, K31, K32, K33, K34, K35, K36, K37, K38, K39, K3A, K3B, K3C, K3D, KC_NO, KC_NO, KC_NO }, \
|
||||||
|
{ K40, K41, K42, K43, K44, K45, K46, K47, K48, K49, K4A, K4B, K4C, K4D, KC_NO, K4F, KC_NO }, \
|
||||||
|
{ K50, K51, K52, KC_NO, KC_NO, KC_NO, K56, KC_NO, KC_NO, KC_NO, K5A, K5B, K5C, K5D, K5E, K5F, K5G }, \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define LAYOUT_tkl_ansi_split_bs_rshift( \
|
||||||
|
K00, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D, K0E, K0F, K0G, \
|
||||||
|
K10, K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, K1C, K1D, K2D, K1E, K1F, K1G, \
|
||||||
|
K20, K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A, K2B, K2C, K3C, K2E, K2F, K2G, \
|
||||||
|
K30, K31, K32, K33, K34, K35, K36, K37, K38, K39, K3A, K3B, K3D, \
|
||||||
|
K40, K42, K43, K44, K45, K46, K47, K48, K49, K4A, K4B, K4C, K4D, K4F, \
|
||||||
|
K50, K51, K52, K56, K5A, K5B, K5C, K5D, K5E, K5F, K5G \
|
||||||
|
) { \
|
||||||
|
{ K00, KC_NO, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D, K0E, K0F, K0G }, \
|
||||||
|
{ K10, K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, K1C, K1D, K1E, K1F, K1G }, \
|
||||||
|
{ K20, K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A, K2B, K2C, K2D, K2E, K2F, K2G }, \
|
||||||
|
{ K30, K31, K32, K33, K34, K35, K36, K37, K38, K39, K3A, K3B, K3C, K3D, KC_NO, KC_NO, KC_NO }, \
|
||||||
|
{ K40, KC_NO, K42, K43, K44, K45, K46, K47, K48, K49, K4A, K4B, K4C, K4D, KC_NO, K4F, KC_NO }, \
|
||||||
|
{ K50, K51, K52, KC_NO, KC_NO, KC_NO, K56, KC_NO, KC_NO, KC_NO, K5A, K5B, K5C, K5D, K5E, K5F, K5G }, \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define LAYOUT_tkl_iso_split_bs_rshift( \
|
||||||
|
K00, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D, K0E, K0F, K0G, \
|
||||||
|
K10, K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, K1C, K1D, K2D, K1E, K1F, K1G, \
|
||||||
|
K20, K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A, K2B, K2C, K2E, K2F, K2G, \
|
||||||
|
K30, K31, K32, K33, K34, K35, K36, K37, K38, K39, K3A, K3B, K3C, K3D, \
|
||||||
|
K40, K41, K42, K43, K44, K45, K46, K47, K48, K49, K4A, K4B, K4C, K4D, K4F, \
|
||||||
|
K50, K51, K52, K56, K5A, K5B, K5C, K5D, K5E, K5F, K5G \
|
||||||
|
) { \
|
||||||
|
{ K00, KC_NO, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D, K0E, K0F, K0G }, \
|
||||||
|
{ K10, K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, K1C, K1D, K1E, K1F, K1G }, \
|
||||||
|
{ K20, K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A, K2B, K2C, K2D, K2E, K2F, K2G }, \
|
||||||
|
{ K30, K31, K32, K33, K34, K35, K36, K37, K38, K39, K3A, K3B, K3C, K3D, KC_NO, KC_NO, KC_NO }, \
|
||||||
|
{ K40, K41, K42, K43, K44, K45, K46, K47, K48, K49, K4A, K4B, K4C, K4D, KC_NO, K4F, KC_NO }, \
|
||||||
|
{ K50, K51, K52, KC_NO, KC_NO, KC_NO, K56, KC_NO, KC_NO, KC_NO, K5A, K5B, K5C, K5D, K5E, K5F, K5G }, \
|
||||||
|
}
|
23
keyboards/mechlovin/infinity875/info.json
Normal file
23
keyboards/mechlovin/infinity875/info.json
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
{
|
||||||
|
"keyboard_name": "Infinity87.5",
|
||||||
|
"url": "",
|
||||||
|
"maintainer": "Mechlovin' Studio",
|
||||||
|
"layouts": {
|
||||||
|
"LAYOUT_tkl_ansi_split_bs_rshift": {
|
||||||
|
"layout": [{"label":"0,0", "x":0, "y":0}, {"label":"0,1", "x":2, "y":0}, {"label":"0,2", "x":3, "y":0}, {"label":"0,3", "x":4, "y":0}, {"label":"0,4", "x":5, "y":0}, {"label":"0,5", "x":6.5, "y":0}, {"label":"0,6", "x":7.5, "y":0}, {"label":"0,7", "x":8.5, "y":0}, {"label":"0,8", "x":9.5, "y":0}, {"label":"0,9", "x":11, "y":0}, {"label":"0,10", "x":12, "y":0}, {"label":"0,11", "x":13, "y":0}, {"label":"0,12", "x":14, "y":0}, {"label":"0,14", "x":15.25, "y":0}, {"label":"0,15", "x":16.25, "y":0}, {"label":"0,16", "x":17.25, "y":0}, {"label":"1,0", "x":0, "y":1.25}, {"label":"1,1", "x":1, "y":1.25}, {"label":"1,2", "x":2, "y":1.25}, {"label":"1,3", "x":3, "y":1.25}, {"label":"1,4", "x":4, "y":1.25}, {"label":"1,5", "x":5, "y":1.25}, {"label":"1,6", "x":6, "y":1.25}, {"label":"1,7", "x":7, "y":1.25}, {"label":"1,8", "x":8, "y":1.25}, {"label":"1,9", "x":9, "y":1.25}, {"label":"1,10", "x":10, "y":1.25}, {"label":"1,11", "x":11, "y":1.25}, {"label":"1,12", "x":12, "y":1.25}, {"label":"1,13", "x":13, "y":1.25}, {"label":"2,13", "x":14, "y":1.25}, {"label":"1,14", "x":15.25, "y":1.25}, {"label":"1,15", "x":16.25, "y":1.25}, {"label":"1,16", "x":17.25, "y":1.25}, {"label":"2,0", "x":0, "y":2.25, "w":1.5}, {"label":"2,1", "x":1.5, "y":2.25}, {"label":"2,2", "x":2.5, "y":2.25}, {"label":"2,3", "x":3.5, "y":2.25}, {"label":"2,4", "x":4.5, "y":2.25}, {"label":"2,5", "x":5.5, "y":2.25}, {"label":"2,6", "x":6.5, "y":2.25}, {"label":"2,7", "x":7.5, "y":2.25}, {"label":"2,8", "x":8.5, "y":2.25}, {"label":"2,9", "x":9.5, "y":2.25}, {"label":"2,10", "x":10.5, "y":2.25}, {"label":"2,11", "x":11.5, "y":2.25}, {"label":"2,12", "x":12.5, "y":2.25}, {"label":"3,12", "x":13.5, "y":2.25, "w":1.5}, {"label":"2,14", "x":15.25, "y":2.25}, {"label":"2,15", "x":16.25, "y":2.25}, {"label":"2,16", "x":17.25, "y":2.25}, {"label":"3,0", "x":0, "y":3.25, "w":1.75}, {"label":"3,1", "x":1.75, "y":3.25}, {"label":"3,2", "x":2.75, "y":3.25}, {"label":"3,3", "x":3.75, "y":3.25}, {"label":"3,4", "x":4.75, "y":3.25}, {"label":"3,5", "x":5.75, "y":3.25}, {"label":"3,6", "x":6.75, "y":3.25}, {"label":"3,7", "x":7.75, "y":3.25}, {"label":"3,8", "x":8.75, "y":3.25}, {"label":"3,9", "x":9.75, "y":3.25}, {"label":"3,10", "x":10.75, "y":3.25}, {"label":"3,11", "x":11.75, "y":3.25}, {"label":"3,13", "x":12.75, "y":3.25, "w":2.25}, {"label":"4,0", "x":0, "y":4.25, "w":2.25}, {"label":"4,2", "x":2.25, "y":4.25}, {"label":"4,3", "x":3.25, "y":4.25}, {"label":"4,4", "x":4.25, "y":4.25}, {"label":"4,5", "x":5.25, "y":4.25}, {"label":"4,6", "x":6.25, "y":4.25}, {"label":"4,7", "x":7.25, "y":4.25}, {"label":"4,8", "x":8.25, "y":4.25}, {"label":"4,9", "x":9.25, "y":4.25}, {"label":"4,10", "x":10.25, "y":4.25}, {"label":"4,11", "x":11.25, "y":4.25}, {"label":"4,12", "x":12.25, "y":4.25}, {"label":"4,13", "x":13.25, "y":4.25, "w":1.75}, {"label":"4,15", "x":16.25, "y":4.25}, {"label":"5,0", "x":0, "y":5.25, "w":1.25}, {"label":"5,1", "x":1.25, "y":5.25, "w":1.25}, {"label":"5,2", "x":2.5, "y":5.25, "w":1.25}, {"label":"5,6", "x":3.75, "y":5.25, "w":6.25}, {"label":"5,10", "x":10, "y":5.25, "w":1.25}, {"label":"5,11", "x":11.25, "y":5.25, "w":1.25}, {"label":"5,12", "x":12.5, "y":5.25, "w":1.25}, {"label":"5,13", "x":13.75, "y":5.25, "w":1.25}, {"label":"5,14", "x":15.25, "y":5.25}, {"label":"5,15", "x":16.25, "y":5.25}, {"label":"5,16", "x":17.25, "y":5.25}]
|
||||||
|
},
|
||||||
|
"LAYOUT_tkl_iso_split_bs_rshift": {
|
||||||
|
"layout": [{"label":"0,0", "x":0, "y":0}, {"label":"0,1", "x":2, "y":0}, {"label":"0,2", "x":3, "y":0}, {"label":"0,3", "x":4, "y":0}, {"label":"0,4", "x":5, "y":0}, {"label":"0,5", "x":6.5, "y":0}, {"label":"0,6", "x":7.5, "y":0}, {"label":"0,7", "x":8.5, "y":0}, {"label":"0,8", "x":9.5, "y":0}, {"label":"0,9", "x":11, "y":0}, {"label":"0,10", "x":12, "y":0}, {"label":"0,11", "x":13, "y":0}, {"label":"0,12", "x":14, "y":0}, {"label":"0,14", "x":15.25, "y":0}, {"label":"0,15", "x":16.25, "y":0}, {"label":"0,16", "x":17.25, "y":0}, {"label":"1,0", "x":0, "y":1.25}, {"label":"1,1", "x":1, "y":1.25}, {"label":"1,2", "x":2, "y":1.25}, {"label":"1,3", "x":3, "y":1.25}, {"label":"1,4", "x":4, "y":1.25}, {"label":"1,5", "x":5, "y":1.25}, {"label":"1,6", "x":6, "y":1.25}, {"label":"1,7", "x":7, "y":1.25}, {"label":"1,8", "x":8, "y":1.25}, {"label":"1,9", "x":9, "y":1.25}, {"label":"1,10", "x":10, "y":1.25}, {"label":"1,11", "x":11, "y":1.25}, {"label":"1,12", "x":12, "y":1.25}, {"label":"1,13", "x":13, "y":1.25}, {"label":"2,13", "x":14, "y":1.25}, {"label":"1,14", "x":15.25, "y":1.25}, {"label":"1,15", "x":16.25, "y":1.25}, {"label":"1,16", "x":17.25, "y":1.25}, {"label":"2,0", "x":0, "y":2.25, "w":1.5}, {"label":"2,1", "x":1.5, "y":2.25}, {"label":"2,2", "x":2.5, "y":2.25}, {"label":"2,3", "x":3.5, "y":2.25}, {"label":"2,4", "x":4.5, "y":2.25}, {"label":"2,5", "x":5.5, "y":2.25}, {"label":"2,6", "x":6.5, "y":2.25}, {"label":"2,7", "x":7.5, "y":2.25}, {"label":"2,8", "x":8.5, "y":2.25}, {"label":"2,9", "x":9.5, "y":2.25}, {"label":"2,10", "x":10.5, "y":2.25}, {"label":"2,11", "x":11.5, "y":2.25}, {"label":"2,12", "x":12.5, "y":2.25}, {"label":"3,13", "x":13.75, "y":2.25, "w":1.25, "h":2}, {"label":"2,14", "x":15.25, "y":2.25}, {"label":"2,15", "x":16.25, "y":2.25}, {"label":"2,16", "x":17.25, "y":2.25}, {"label":"3,0", "x":0, "y":3.25, "w":1.75}, {"label":"3,1", "x":1.75, "y":3.25}, {"label":"3,2", "x":2.75, "y":3.25}, {"label":"3,3", "x":3.75, "y":3.25}, {"label":"3,4", "x":4.75, "y":3.25}, {"label":"3,5", "x":5.75, "y":3.25}, {"label":"3,6", "x":6.75, "y":3.25}, {"label":"3,7", "x":7.75, "y":3.25}, {"label":"3,8", "x":8.75, "y":3.25}, {"label":"3,9", "x":9.75, "y":3.25}, {"label":"3,10", "x":10.75, "y":3.25}, {"label":"3,11", "x":11.75, "y":3.25}, {"label":"3,12", "x":12.75, "y":3.25}, {"label":"4,0", "x":0, "y":4.25, "w":1.25}, {"label":"4,1", "x":1.25, "y":4.25}, {"label":"4,2", "x":2.25, "y":4.25}, {"label":"4,3", "x":3.25, "y":4.25}, {"label":"4,4", "x":4.25, "y":4.25}, {"label":"4,5", "x":5.25, "y":4.25}, {"label":"4,6", "x":6.25, "y":4.25}, {"label":"4,7", "x":7.25, "y":4.25}, {"label":"4,8", "x":8.25, "y":4.25}, {"label":"4,9", "x":9.25, "y":4.25}, {"label":"4,10", "x":10.25, "y":4.25}, {"label":"4,11", "x":11.25, "y":4.25}, {"label":"4,12", "x":12.25, "y":4.25}, {"label":"4,13", "x":13.25, "y":4.25, "w":1.75}, {"label":"4,15", "x":16.25, "y":4.25}, {"label":"5,0", "x":0, "y":5.25, "w":1.25}, {"label":"5,1", "x":1.25, "y":5.25, "w":1.25}, {"label":"5,2", "x":2.5, "y":5.25, "w":1.25}, {"label":"5,6", "x":3.75, "y":5.25, "w":6.25}, {"label":"5,10", "x":10, "y":5.25, "w":1.25}, {"label":"5,11", "x":11.25, "y":5.25, "w":1.25}, {"label":"5,12", "x":12.5, "y":5.25, "w":1.25}, {"label":"5,13", "x":13.75, "y":5.25, "w":1.25}, {"label":"5,14", "x":15.25, "y":5.25}, {"label":"5,15", "x":16.25, "y":5.25}, {"label":"5,16", "x":17.25, "y":5.25}]
|
||||||
|
},
|
||||||
|
"LAYOUT_tkl_f13_ansi_split_bs_rshift": {
|
||||||
|
"layout": [{"label":"0,0", "x":0, "y":0}, {"label":"0,1", "x":1.25, "y":0}, {"label":"0,2", "x":2.25, "y":0}, {"label":"0,3", "x":3.25, "y":0}, {"label":"0,4", "x":4.25, "y":0}, {"label":"0,5", "x":5.5, "y":0}, {"label":"0,6", "x":6.5, "y":0}, {"label":"0,7", "x":7.5, "y":0}, {"label":"0,8", "x":8.5, "y":0}, {"label":"0,9", "x":9.75, "y":0}, {"label":"0,10", "x":10.75, "y":0}, {"label":"0,11", "x":11.75, "y":0}, {"label":"0,12", "x":12.75, "y":0}, {"label":"0,13", "x":14, "y":0}, {"label":"0,14", "x":15.25, "y":0}, {"label":"0,15", "x":16.25, "y":0}, {"label":"0,16", "x":17.25, "y":0}, {"label":"1,0", "x":0, "y":1.25}, {"label":"1,1", "x":1, "y":1.25}, {"label":"1,2", "x":2, "y":1.25}, {"label":"1,3", "x":3, "y":1.25}, {"label":"1,4", "x":4, "y":1.25}, {"label":"1,5", "x":5, "y":1.25}, {"label":"1,6", "x":6, "y":1.25}, {"label":"1,7", "x":7, "y":1.25}, {"label":"1,8", "x":8, "y":1.25}, {"label":"1,9", "x":9, "y":1.25}, {"label":"1,10", "x":10, "y":1.25}, {"label":"1,11", "x":11, "y":1.25}, {"label":"1,12", "x":12, "y":1.25}, {"label":"1,13", "x":13, "y":1.25}, {"label":"2,13", "x":14, "y":1.25}, {"label":"1,14", "x":15.25, "y":1.25}, {"label":"1,15", "x":16.25, "y":1.25}, {"label":"1,16", "x":17.25, "y":1.25}, {"label":"2,0", "x":0, "y":2.25, "w":1.5}, {"label":"2,1", "x":1.5, "y":2.25}, {"label":"2,2", "x":2.5, "y":2.25}, {"label":"2,3", "x":3.5, "y":2.25}, {"label":"2,4", "x":4.5, "y":2.25}, {"label":"2,5", "x":5.5, "y":2.25}, {"label":"2,6", "x":6.5, "y":2.25}, {"label":"2,7", "x":7.5, "y":2.25}, {"label":"2,8", "x":8.5, "y":2.25}, {"label":"2,9", "x":9.5, "y":2.25}, {"label":"2,10", "x":10.5, "y":2.25}, {"label":"2,11", "x":11.5, "y":2.25}, {"label":"2,12", "x":12.5, "y":2.25}, {"label":"3,12", "x":13.5, "y":2.25, "w":1.5}, {"label":"2,14", "x":15.25, "y":2.25}, {"label":"2,15", "x":16.25, "y":2.25}, {"label":"2,16", "x":17.25, "y":2.25}, {"label":"3,0", "x":0, "y":3.25, "w":1.75}, {"label":"3,1", "x":1.75, "y":3.25}, {"label":"3,2", "x":2.75, "y":3.25}, {"label":"3,3", "x":3.75, "y":3.25}, {"label":"3,4", "x":4.75, "y":3.25}, {"label":"3,5", "x":5.75, "y":3.25}, {"label":"3,6", "x":6.75, "y":3.25}, {"label":"3,7", "x":7.75, "y":3.25}, {"label":"3,8", "x":8.75, "y":3.25}, {"label":"3,9", "x":9.75, "y":3.25}, {"label":"3,10", "x":10.75, "y":3.25}, {"label":"3,11", "x":11.75, "y":3.25}, {"label":"3,13", "x":12.75, "y":3.25, "w":2.25}, {"label":"4,0", "x":0, "y":4.25, "w":2.25}, {"label":"4,2", "x":2.25, "y":4.25}, {"label":"4,3", "x":3.25, "y":4.25}, {"label":"4,4", "x":4.25, "y":4.25}, {"label":"4,5", "x":5.25, "y":4.25}, {"label":"4,6", "x":6.25, "y":4.25}, {"label":"4,7", "x":7.25, "y":4.25}, {"label":"4,8", "x":8.25, "y":4.25}, {"label":"4,9", "x":9.25, "y":4.25}, {"label":"4,10", "x":10.25, "y":4.25}, {"label":"4,11", "x":11.25, "y":4.25}, {"label":"4,12", "x":12.25, "y":4.25}, {"label":"4,13", "x":13.25, "y":4.25, "w":1.75}, {"label":"4,15", "x":16.25, "y":4.25}, {"label":"5,0", "x":0, "y":5.25, "w":1.25}, {"label":"5,1", "x":1.25, "y":5.25, "w":1.25}, {"label":"5,2", "x":2.5, "y":5.25, "w":1.25}, {"label":"5,6", "x":3.75, "y":5.25, "w":6.25}, {"label":"5,10", "x":10, "y":5.25, "w":1.25}, {"label":"5,11", "x":11.25, "y":5.25, "w":1.25}, {"label":"5,12", "x":12.5, "y":5.25, "w":1.25}, {"label":"5,13", "x":13.75, "y":5.25, "w":1.25}, {"label":"5,14", "x":15.25, "y":5.25}, {"label":"5,15", "x":16.25, "y":5.25}, {"label":"5,16", "x":17.25, "y":5.25}]
|
||||||
|
},
|
||||||
|
"LAYOUT_tkl_f13_iso_split_bs_rshift": {
|
||||||
|
"layout": [{"label":"0,0", "x":0, "y":0}, {"label":"0,1", "x":1.25, "y":0}, {"label":"0,2", "x":2.25, "y":0}, {"label":"0,3", "x":3.25, "y":0}, {"label":"0,4", "x":4.25, "y":0}, {"label":"0,5", "x":5.5, "y":0}, {"label":"0,6", "x":6.5, "y":0}, {"label":"0,7", "x":7.5, "y":0}, {"label":"0,8", "x":8.5, "y":0}, {"label":"0,9", "x":9.75, "y":0}, {"label":"0,10", "x":10.75, "y":0}, {"label":"0,11", "x":11.75, "y":0}, {"label":"0,12", "x":12.75, "y":0}, {"label":"0,13", "x":14, "y":0}, {"label":"0,14", "x":15.25, "y":0}, {"label":"0,15", "x":16.25, "y":0}, {"label":"0,16", "x":17.25, "y":0}, {"label":"1,0", "x":0, "y":1.25}, {"label":"1,1", "x":1, "y":1.25}, {"label":"1,2", "x":2, "y":1.25}, {"label":"1,3", "x":3, "y":1.25}, {"label":"1,4", "x":4, "y":1.25}, {"label":"1,5", "x":5, "y":1.25}, {"label":"1,6", "x":6, "y":1.25}, {"label":"1,7", "x":7, "y":1.25}, {"label":"1,8", "x":8, "y":1.25}, {"label":"1,9", "x":9, "y":1.25}, {"label":"1,10", "x":10, "y":1.25}, {"label":"1,11", "x":11, "y":1.25}, {"label":"1,12", "x":12, "y":1.25}, {"label":"1,13", "x":13, "y":1.25}, {"label":"2,13", "x":14, "y":1.25}, {"label":"1,14", "x":15.25, "y":1.25}, {"label":"1,15", "x":16.25, "y":1.25}, {"label":"1,16", "x":17.25, "y":1.25}, {"label":"2,0", "x":0, "y":2.25, "w":1.5}, {"label":"2,1", "x":1.5, "y":2.25}, {"label":"2,2", "x":2.5, "y":2.25}, {"label":"2,3", "x":3.5, "y":2.25}, {"label":"2,4", "x":4.5, "y":2.25}, {"label":"2,5", "x":5.5, "y":2.25}, {"label":"2,6", "x":6.5, "y":2.25}, {"label":"2,7", "x":7.5, "y":2.25}, {"label":"2,8", "x":8.5, "y":2.25}, {"label":"2,9", "x":9.5, "y":2.25}, {"label":"2,10", "x":10.5, "y":2.25}, {"label":"2,11", "x":11.5, "y":2.25}, {"label":"2,12", "x":12.5, "y":2.25}, {"label":"3,13", "x":13.75, "y":2.25, "w":1.25, "h":2}, {"label":"2,14", "x":15.25, "y":2.25}, {"label":"2,15", "x":16.25, "y":2.25}, {"label":"2,16", "x":17.25, "y":2.25}, {"label":"3,0", "x":0, "y":3.25, "w":1.75}, {"label":"3,1", "x":1.75, "y":3.25}, {"label":"3,2", "x":2.75, "y":3.25}, {"label":"3,3", "x":3.75, "y":3.25}, {"label":"3,4", "x":4.75, "y":3.25}, {"label":"3,5", "x":5.75, "y":3.25}, {"label":"3,6", "x":6.75, "y":3.25}, {"label":"3,7", "x":7.75, "y":3.25}, {"label":"3,8", "x":8.75, "y":3.25}, {"label":"3,9", "x":9.75, "y":3.25}, {"label":"3,10", "x":10.75, "y":3.25}, {"label":"3,11", "x":11.75, "y":3.25}, {"label":"3,12", "x":12.75, "y":3.25}, {"label":"4,0", "x":0, "y":4.25, "w":1.25}, {"label":"4,1", "x":1.25, "y":4.25}, {"label":"4,2", "x":2.25, "y":4.25}, {"label":"4,3", "x":3.25, "y":4.25}, {"label":"4,4", "x":4.25, "y":4.25}, {"label":"4,5", "x":5.25, "y":4.25}, {"label":"4,6", "x":6.25, "y":4.25}, {"label":"4,7", "x":7.25, "y":4.25}, {"label":"4,8", "x":8.25, "y":4.25}, {"label":"4,9", "x":9.25, "y":4.25}, {"label":"4,10", "x":10.25, "y":4.25}, {"label":"4,11", "x":11.25, "y":4.25}, {"label":"4,12", "x":12.25, "y":4.25}, {"label":"4,13", "x":13.25, "y":4.25, "w":1.75}, {"label":"4,15", "x":16.25, "y":4.25}, {"label":"5,0", "x":0, "y":5.25, "w":1.25}, {"label":"5,1", "x":1.25, "y":5.25, "w":1.25}, {"label":"5,2", "x":2.5, "y":5.25, "w":1.25}, {"label":"5,6", "x":3.75, "y":5.25, "w":6.25}, {"label":"5,10", "x":10, "y":5.25, "w":1.25}, {"label":"5,11", "x":11.25, "y":5.25, "w":1.25}, {"label":"5,12", "x":12.5, "y":5.25, "w":1.25}, {"label":"5,13", "x":13.75, "y":5.25, "w":1.25}, {"label":"5,14", "x":15.25, "y":5.25}, {"label":"5,15", "x":16.25, "y":5.25}, {"label":"5,16", "x":17.25, "y":5.25}]
|
||||||
|
},
|
||||||
|
"LAYOUT_all": {
|
||||||
|
"layout": [{"label":"0,0", "x":0, "y":0}, {"label":"0,1", "x":1.25, "y":0}, {"label":"0,2", "x":2.25, "y":0}, {"label":"0,3", "x":3.25, "y":0}, {"label":"0,4", "x":4.25, "y":0}, {"label":"0,5", "x":5.5, "y":0}, {"label":"0,6", "x":6.5, "y":0}, {"label":"0,7", "x":7.5, "y":0}, {"label":"0,8", "x":8.5, "y":0}, {"label":"0,9", "x":9.75, "y":0}, {"label":"0,10", "x":10.75, "y":0}, {"label":"0,11", "x":11.75, "y":0}, {"label":"0,12", "x":12.75, "y":0}, {"label":"0,13", "x":14, "y":0}, {"label":"0,14", "x":15.25, "y":0}, {"label":"0,15", "x":16.25, "y":0}, {"label":"0,16", "x":17.25, "y":0}, {"label":"1,0", "x":0, "y":1.25}, {"label":"1,1", "x":1, "y":1.25}, {"label":"1,2", "x":2, "y":1.25}, {"label":"1,3", "x":3, "y":1.25}, {"label":"1,4", "x":4, "y":1.25}, {"label":"1,5", "x":5, "y":1.25}, {"label":"1,6", "x":6, "y":1.25}, {"label":"1,7", "x":7, "y":1.25}, {"label":"1,8", "x":8, "y":1.25}, {"label":"1,9", "x":9, "y":1.25}, {"label":"1,10", "x":10, "y":1.25}, {"label":"1,11", "x":11, "y":1.25}, {"label":"1,12", "x":12, "y":1.25}, {"label":"1,13", "x":13, "y":1.25}, {"label":"2,13", "x":14, "y":1.25}, {"label":"1,14", "x":15.25, "y":1.25}, {"label":"1,15", "x":16.25, "y":1.25}, {"label":"1,16", "x":17.25, "y":1.25}, {"label":"2,0", "x":0, "y":2.25, "w":1.5}, {"label":"2,1", "x":1.5, "y":2.25}, {"label":"2,2", "x":2.5, "y":2.25}, {"label":"2,3", "x":3.5, "y":2.25}, {"label":"2,4", "x":4.5, "y":2.25}, {"label":"2,5", "x":5.5, "y":2.25}, {"label":"2,6", "x":6.5, "y":2.25}, {"label":"2,7", "x":7.5, "y":2.25}, {"label":"2,8", "x":8.5, "y":2.25}, {"label":"2,9", "x":9.5, "y":2.25}, {"label":"2,10", "x":10.5, "y":2.25}, {"label":"2,11", "x":11.5, "y":2.25}, {"label":"2,12", "x":12.5, "y":2.25}, {"label":"3,12", "x":13.5, "y":2.25, "w":1.5}, {"label":"2,14", "x":15.25, "y":2.25}, {"label":"2,15", "x":16.25, "y":2.25}, {"label":"2,16", "x":17.25, "y":2.25}, {"label":"3,0", "x":0, "y":3.25, "w":1.75}, {"label":"3,1", "x":1.75, "y":3.25}, {"label":"3,2", "x":2.75, "y":3.25}, {"label":"3,3", "x":3.75, "y":3.25}, {"label":"3,4", "x":4.75, "y":3.25}, {"label":"3,5", "x":5.75, "y":3.25}, {"label":"3,6", "x":6.75, "y":3.25}, {"label":"3,7", "x":7.75, "y":3.25}, {"label":"3,8", "x":8.75, "y":3.25}, {"label":"3,9", "x":9.75, "y":3.25}, {"label":"3,10", "x":10.75, "y":3.25}, {"label":"3,11", "x":11.75, "y":3.25}, {"label":"3,13", "x":12.75, "y":3.25, "w":2.25}, {"label":"4,0", "x":0, "y":4.25, "w":1.25}, {"label":"4,1", "x":1.25, "y":4.25}, {"label":"4,2", "x":2.25, "y":4.25}, {"label":"4,3", "x":3.25, "y":4.25}, {"label":"4,4", "x":4.25, "y":4.25}, {"label":"4,5", "x":5.25, "y":4.25}, {"label":"4,6", "x":6.25, "y":4.25}, {"label":"4,7", "x":7.25, "y":4.25}, {"label":"4,8", "x":8.25, "y":4.25}, {"label":"4,9", "x":9.25, "y":4.25}, {"label":"4,10", "x":10.25, "y":4.25}, {"label":"4,11", "x":11.25, "y":4.25}, {"label":"4,12", "x":12.25, "y":4.25}, {"label":"4,13", "x":13.25, "y":4.25, "w":1.75}, {"label":"4,15", "x":16.25, "y":4.25}, {"label":"5,0", "x":0, "y":5.25, "w":1.25}, {"label":"5,1", "x":1.25, "y":5.25, "w":1.25}, {"label":"5,2", "x":2.5, "y":5.25, "w":1.25}, {"label":"5,6", "x":3.75, "y":5.25, "w":6.25}, {"label":"5,10", "x":10, "y":5.25, "w":1.25}, {"label":"5,11", "x":11.25, "y":5.25, "w":1.25}, {"label":"5,12", "x":12.5, "y":5.25, "w":1.25}, {"label":"5,13", "x":13.75, "y":5.25, "w":1.25}, {"label":"5,14", "x":15.25, "y":5.25}, {"label":"5,15", "x":16.25, "y":5.25}, {"label":"5,16", "x":17.25, "y":5.25}]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
,"meta": "https://noroadsleft.github.io/kbf_qmk_converter/"
|
||||||
|
}
|
35
keyboards/mechlovin/infinity875/keymaps/default/keymap.c
Normal file
35
keyboards/mechlovin/infinity875/keymaps/default/keymap.c
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
/* Copyright 2021 Mechlovin' Studio
|
||||||
|
*
|
||||||
|
* 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
|
||||||
|
|
||||||
|
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
|
[0] = LAYOUT_all(
|
||||||
|
KC_ESC, 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_F13, KC_PSCR, KC_SLCK, KC_PAUS,
|
||||||
|
KC_GRV, 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_DEL, KC_INS, KC_HOME, KC_PGUP,
|
||||||
|
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_DEL, KC_END, KC_PGDN,
|
||||||
|
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,
|
||||||
|
KC_LSFT, KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_LSFT, KC_LSFT, KC_UP,
|
||||||
|
KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_LALT, KC_LGUI, MO(1), KC_LCTL, KC_LEFT, KC_DOWN, KC_RGHT
|
||||||
|
),
|
||||||
|
[1] = LAYOUT_all(
|
||||||
|
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_TRNS, 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_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, RGB_SAI, RGB_HUI,
|
||||||
|
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_TRNS, KC_TRNS, KC_TRNS, RGB_SAD, RGB_HUD,
|
||||||
|
KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, RGB_TOG,
|
||||||
|
KC_TRNS, KC_BSLS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, RGB_VAI,
|
||||||
|
KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, RGB_RMOD, RGB_VAD, RGB_MOD
|
||||||
|
)
|
||||||
|
};
|
|
@ -0,0 +1 @@
|
||||||
|
# The default keymap for infinity875
|
|
@ -0,0 +1,764 @@
|
||||||
|
/*
|
||||||
|
Copyright 2020 Evy Dekkers
|
||||||
|
|
||||||
|
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(solid_esc)
|
||||||
|
RGB_MATRIX_EFFECT(solid_f13)
|
||||||
|
RGB_MATRIX_EFFECT(solid_clus)
|
||||||
|
RGB_MATRIX_EFFECT(breathing_all)
|
||||||
|
RGB_MATRIX_EFFECT(breathing_esc)
|
||||||
|
RGB_MATRIX_EFFECT(breathing_f13)
|
||||||
|
RGB_MATRIX_EFFECT(breathing_clus)
|
||||||
|
RGB_MATRIX_EFFECT(band_val_all)
|
||||||
|
RGB_MATRIX_EFFECT(band_val_esc)
|
||||||
|
RGB_MATRIX_EFFECT(band_val_f13)
|
||||||
|
RGB_MATRIX_EFFECT(band_val_clus)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_up_down_all)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_up_down_esc)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_up_down_f13)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_up_down_clus)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_out_in_dual_all)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_out_in_dual_esc)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_out_in_dual_f13)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_out_in_dual_clus)
|
||||||
|
RGB_MATRIX_EFFECT(rainbow_moving_chevron_all)
|
||||||
|
RGB_MATRIX_EFFECT(rainbow_moving_chevron_esc)
|
||||||
|
RGB_MATRIX_EFFECT(rainbow_moving_chevron_f13)
|
||||||
|
RGB_MATRIX_EFFECT(rainbow_moving_chevron_clus)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_pimwheel_all)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_pimwheel_esc)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_pimwheel_f13)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_pimwheel_clus)
|
||||||
|
RGB_MATRIX_EFFECT(rainbow_beacon_all)
|
||||||
|
RGB_MATRIX_EFFECT(rainbow_beacon_esc)
|
||||||
|
RGB_MATRIX_EFFECT(rainbow_beacon_f13)
|
||||||
|
RGB_MATRIX_EFFECT(rainbow_beacon_clus)
|
||||||
|
RGB_MATRIX_EFFECT(raindrops_all)
|
||||||
|
RGB_MATRIX_EFFECT(raindrops_esc)
|
||||||
|
RGB_MATRIX_EFFECT(raindrops_f13)
|
||||||
|
RGB_MATRIX_EFFECT(raindrops_clus)
|
||||||
|
|
||||||
|
#ifdef RGB_MATRIX_CUSTOM_EFFECT_IMPLS
|
||||||
|
|
||||||
|
bool effect_runner_all(effect_params_t* params, i_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint8_t time = scale16by8(g_rgb_timer, qadd8(rgb_matrix_config.speed / 4, 1));
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, i, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_esc(effect_params_t* params, i_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint8_t time = scale16by8(g_rgb_timer, qadd8(rgb_matrix_config.speed / 4, 1));
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, i, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 1; i < 18; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_f13(effect_params_t* params, i_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
uint8_t time = scale16by8(g_rgb_timer, qadd8(rgb_matrix_config.speed / 4, 1));
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, i, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
rgb_matrix_set_color(15, 0x00, 0x00, 0x00);
|
||||||
|
rgb_matrix_set_color(16, 0x00, 0x00, 0x00);
|
||||||
|
rgb_matrix_set_color(17, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 0; i < 14; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_clus(effect_params_t* params, i_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint8_t time = scale16by8(g_rgb_timer, qadd8(rgb_matrix_config.speed / 4, 1));
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, i, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 0; i < 15; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_dx_dy_all(effect_params_t* params, dx_dy_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint8_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 2);
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
int16_t dx = g_led_config.point[i].x - k_rgb_matrix_center.x;
|
||||||
|
int16_t dy = g_led_config.point[i].y - k_rgb_matrix_center.y;
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, dx, dy, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_dx_dy_esc(effect_params_t* params, dx_dy_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint8_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 2);
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
int16_t dx = g_led_config.point[i].x - k_rgb_matrix_center.x;
|
||||||
|
int16_t dy = g_led_config.point[i].y - k_rgb_matrix_center.y;
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, dx, dy, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 1; i < 18; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_dx_dy_f13(effect_params_t* params, dx_dy_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint8_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 2);
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
int16_t dx = g_led_config.point[i].x - k_rgb_matrix_center.x;
|
||||||
|
int16_t dy = g_led_config.point[i].y - k_rgb_matrix_center.y;
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, dx, dy, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
rgb_matrix_set_color(15, 0x00, 0x00, 0x00);
|
||||||
|
rgb_matrix_set_color(16, 0x00, 0x00, 0x00);
|
||||||
|
rgb_matrix_set_color(17, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 0; i < 14; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_dx_dy_clus(effect_params_t* params, dx_dy_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint8_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 2);
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
int16_t dx = g_led_config.point[i].x - k_rgb_matrix_center.x;
|
||||||
|
int16_t dy = g_led_config.point[i].y - k_rgb_matrix_center.y;
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, dx, dy, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 0; i < 15; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_sin_cos_all(effect_params_t* params, sin_cos_i_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint16_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 4);
|
||||||
|
int8_t cos_value = cos8(time) - 128;
|
||||||
|
int8_t sin_value = sin8(time) - 128;
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, cos_value, sin_value, i, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_sin_cos_esc(effect_params_t* params, sin_cos_i_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint16_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 4);
|
||||||
|
int8_t cos_value = cos8(time) - 128;
|
||||||
|
int8_t sin_value = sin8(time) - 128;
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, cos_value, sin_value, i, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 1; i < 18; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_sin_cos_f13(effect_params_t* params, sin_cos_i_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint16_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 4);
|
||||||
|
int8_t cos_value = cos8(time) - 128;
|
||||||
|
int8_t sin_value = sin8(time) - 128;
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, cos_value, sin_value, i, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
rgb_matrix_set_color(15, 0x00, 0x00, 0x00);
|
||||||
|
rgb_matrix_set_color(16, 0x00, 0x00, 0x00);
|
||||||
|
rgb_matrix_set_color(17, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 0; i < 14; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_sin_cos_clus(effect_params_t* params, sin_cos_i_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint16_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 4);
|
||||||
|
int8_t cos_value = cos8(time) - 128;
|
||||||
|
int8_t sin_value = sin8(time) - 128;
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, cos_value, sin_value, i, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 0; i < 15; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void raindrops_set_color_all(int i, effect_params_t* params) {
|
||||||
|
if (!HAS_ANY_FLAGS(g_led_config.flags[i], params->flags)) return;
|
||||||
|
HSV hsv = {0, rgb_matrix_config.hsv.s, rgb_matrix_config.hsv.v};
|
||||||
|
|
||||||
|
// Take the shortest path between hues
|
||||||
|
int16_t deltaH = ((rgb_matrix_config.hsv.h + 180) % 360 - rgb_matrix_config.hsv.h) / 4;
|
||||||
|
if (deltaH > 127) {
|
||||||
|
deltaH -= 256;
|
||||||
|
} else if (deltaH < -127) {
|
||||||
|
deltaH += 256;
|
||||||
|
}
|
||||||
|
|
||||||
|
hsv.h = rgb_matrix_config.hsv.h + (deltaH * (rand() & 0x03));
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(hsv);
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void raindrops_set_color_esc(int i, effect_params_t* params) {
|
||||||
|
if (!HAS_ANY_FLAGS(g_led_config.flags[i], params->flags)) return;
|
||||||
|
HSV hsv = {0, rgb_matrix_config.hsv.s, rgb_matrix_config.hsv.v};
|
||||||
|
|
||||||
|
// Take the shortest path between hues
|
||||||
|
int16_t deltaH = ((rgb_matrix_config.hsv.h + 180) % 360 - rgb_matrix_config.hsv.h) / 4;
|
||||||
|
if (deltaH > 127) {
|
||||||
|
deltaH -= 256;
|
||||||
|
} else if (deltaH < -127) {
|
||||||
|
deltaH += 256;
|
||||||
|
}
|
||||||
|
|
||||||
|
hsv.h = rgb_matrix_config.hsv.h + (deltaH * (rand() & 0x03));
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(hsv);
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
for (uint8_t i = 1; i < 18; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void raindrops_set_color_f13(int i, effect_params_t* params) {
|
||||||
|
if (!HAS_ANY_FLAGS(g_led_config.flags[i], params->flags)) return;
|
||||||
|
HSV hsv = {0, rgb_matrix_config.hsv.s, rgb_matrix_config.hsv.v};
|
||||||
|
|
||||||
|
// Take the shortest path between hues
|
||||||
|
int16_t deltaH = ((rgb_matrix_config.hsv.h + 180) % 360 - rgb_matrix_config.hsv.h) / 4;
|
||||||
|
if (deltaH > 127) {
|
||||||
|
deltaH -= 256;
|
||||||
|
} else if (deltaH < -127) {
|
||||||
|
deltaH += 256;
|
||||||
|
}
|
||||||
|
|
||||||
|
hsv.h = rgb_matrix_config.hsv.h + (deltaH * (rand() & 0x03));
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(hsv);
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
rgb_matrix_set_color(15, 0x00, 0x00, 0x00);
|
||||||
|
rgb_matrix_set_color(16, 0x00, 0x00, 0x00);
|
||||||
|
rgb_matrix_set_color(17, 0x00, 0x00, 0x00);
|
||||||
|
for (uint8_t i = 0; i < 14; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void raindrops_set_color_clus(int i, effect_params_t* params) {
|
||||||
|
if (!HAS_ANY_FLAGS(g_led_config.flags[i], params->flags)) return;
|
||||||
|
HSV hsv = {0, rgb_matrix_config.hsv.s, rgb_matrix_config.hsv.v};
|
||||||
|
|
||||||
|
// Take the shortest path between hues
|
||||||
|
int16_t deltaH = ((rgb_matrix_config.hsv.h + 180) % 360 - rgb_matrix_config.hsv.h) / 4;
|
||||||
|
if (deltaH > 127) {
|
||||||
|
deltaH -= 256;
|
||||||
|
} else if (deltaH < -127) {
|
||||||
|
deltaH += 256;
|
||||||
|
}
|
||||||
|
|
||||||
|
hsv.h = rgb_matrix_config.hsv.h + (deltaH * (rand() & 0x03));
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(hsv);
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
for (uint8_t i = 0; i < 15; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static HSV BAND_VAL_CUSTOM(HSV hsv, uint8_t i, uint8_t time) {
|
||||||
|
int16_t v = hsv.v - abs(scale8(g_led_config.point[i].x, 228) + 28 - time) * 8;
|
||||||
|
hsv.v = scale8(v < 0 ? 0 : v, hsv.v);
|
||||||
|
return hsv;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HSV CYCLE_UP_DOWN_CUSTOM(HSV hsv, uint8_t i, uint8_t time) {
|
||||||
|
hsv.h = g_led_config.point[i].y - time;
|
||||||
|
return hsv;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HSV CYCLE_OUT_IN_DUAL_CUSTOM(HSV hsv, int16_t dx, int16_t dy, uint8_t time) {
|
||||||
|
dx = (k_rgb_matrix_center.x / 2) - abs8(dx);
|
||||||
|
uint8_t dist = sqrt16(dx * dx + dy * dy);
|
||||||
|
hsv.h = 3 * dist + time;
|
||||||
|
return hsv;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HSV RAINBOW_MOVING_CHEVRON_CUSTOM(HSV hsv, uint8_t i, uint8_t time) {
|
||||||
|
hsv.h += abs8(g_led_config.point[i].y - k_rgb_matrix_center.y) + (g_led_config.point[i].x - time);
|
||||||
|
return hsv;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HSV CYCLE_PINWHEEL_CUSTOM(HSV hsv, int16_t dx, int16_t dy, uint8_t time) {
|
||||||
|
hsv.h = atan2_8(dy, dx) + time;
|
||||||
|
return hsv;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HSV RAINBOW_BEACON_CUSTOM(HSV hsv, int8_t sin, int8_t cos, uint8_t i, uint8_t time) {
|
||||||
|
hsv.h += ((g_led_config.point[i].y - k_rgb_matrix_center.y) * 2 * cos + (g_led_config.point[i].x - k_rgb_matrix_center.x) * 2 * sin) / 128;
|
||||||
|
return hsv;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// Solid ESC
|
||||||
|
static bool solid_esc(effect_params_t* params) {
|
||||||
|
HSV hsv = rgb_matrix_config.hsv;
|
||||||
|
RGB rgb = hsv_to_rgb(hsv);
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 18 ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
rgb_matrix_set_color(0, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Solid F13
|
||||||
|
static bool solid_f13(effect_params_t* params) {
|
||||||
|
HSV hsv = rgb_matrix_config.hsv;
|
||||||
|
RGB rgb = hsv_to_rgb(hsv);
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 18 ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
rgb_matrix_set_color(14, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Solid cluster
|
||||||
|
static bool solid_clus(effect_params_t* params) {
|
||||||
|
HSV hsv = rgb_matrix_config.hsv;
|
||||||
|
RGB rgb = hsv_to_rgb(hsv);
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 15 ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Breathing all
|
||||||
|
|
||||||
|
bool breathing_all(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
HSV hsv = rgb_matrix_config.hsv;
|
||||||
|
uint16_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 8);
|
||||||
|
hsv.v = scale8(abs8(sin8(time) - 128) * 2, hsv.v);
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(hsv);
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Breathing ESC
|
||||||
|
static bool breathing_esc(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
HSV hsv = rgb_matrix_config.hsv;
|
||||||
|
uint16_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 8);
|
||||||
|
hsv.v = scale8(abs8(sin8(time) - 128) * 2, hsv.v);
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(hsv);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 18; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
rgb_matrix_set_color(0, rgb.r, rgb.g, rgb.b);
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Breathing F13
|
||||||
|
static bool breathing_f13(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
HSV hsv = rgb_matrix_config.hsv;
|
||||||
|
uint16_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 8);
|
||||||
|
hsv.v = scale8(abs8(sin8(time) - 128) * 2, hsv.v);
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(hsv);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 18; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
rgb_matrix_set_color(14, rgb.r, rgb.g, rgb.b);
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Breathing cluster
|
||||||
|
static bool breathing_clus(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
HSV hsv = rgb_matrix_config.hsv;
|
||||||
|
uint16_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 8);
|
||||||
|
hsv.v = scale8(abs8(sin8(time) - 128) * 2, hsv.v);
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(hsv);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 15; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Band Val all
|
||||||
|
bool band_val_all(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_all(params, &BAND_VAL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Band Val ESC
|
||||||
|
bool band_val_esc(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_esc(params, &BAND_VAL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Band Val F13
|
||||||
|
bool band_val_f13(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_f13(params, &BAND_VAL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Band Val Cluster
|
||||||
|
bool band_val_clus(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_clus(params, &BAND_VAL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cycle Up Down All
|
||||||
|
static bool cycle_up_down_all(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_all(params, &CYCLE_UP_DOWN_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cycle Up Down ESC
|
||||||
|
static bool cycle_up_down_esc(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_esc(params, &CYCLE_UP_DOWN_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cycle up down F13
|
||||||
|
static bool cycle_up_down_f13(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_f13(params, &CYCLE_UP_DOWN_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cycle up down cluster
|
||||||
|
static bool cycle_up_down_clus(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_clus(params, &CYCLE_UP_DOWN_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cycle out in dual All
|
||||||
|
static bool cycle_out_in_dual_all(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_dx_dy_all(params, &CYCLE_OUT_IN_DUAL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cycle out in dual ESC
|
||||||
|
static bool cycle_out_in_dual_esc(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_dx_dy_esc(params, &CYCLE_OUT_IN_DUAL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cycle out in dual f13
|
||||||
|
static bool cycle_out_in_dual_f13(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_dx_dy_f13(params, &CYCLE_OUT_IN_DUAL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cycle out in dual cluster
|
||||||
|
static bool cycle_out_in_dual_clus(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_dx_dy_clus(params, &CYCLE_OUT_IN_DUAL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving chevron all
|
||||||
|
static bool rainbow_moving_chevron_all(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_all(params, &RAINBOW_MOVING_CHEVRON_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving chevron ESC
|
||||||
|
static bool rainbow_moving_chevron_esc(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_esc(params, &RAINBOW_MOVING_CHEVRON_CUSTOM);
|
||||||
|
}
|
||||||
|
// Moving chevron F13
|
||||||
|
static bool rainbow_moving_chevron_f13(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_f13(params, &RAINBOW_MOVING_CHEVRON_CUSTOM);
|
||||||
|
}
|
||||||
|
// Moving chevron cluster
|
||||||
|
static bool rainbow_moving_chevron_clus(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_clus(params, &RAINBOW_MOVING_CHEVRON_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving cycle pimwheel all
|
||||||
|
static bool cycle_pimwheel_all(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_dx_dy_all(params, &CYCLE_PINWHEEL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving cycle pimwheel esc
|
||||||
|
static bool cycle_pimwheel_esc(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_dx_dy_esc(params, &CYCLE_PINWHEEL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving cycle pimwheel f13
|
||||||
|
static bool cycle_pimwheel_f13(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_dx_dy_f13(params, &CYCLE_PINWHEEL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving cycle pimwheel cluster
|
||||||
|
static bool cycle_pimwheel_clus(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_dx_dy_clus(params, &CYCLE_PINWHEEL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving rainbow beacon all
|
||||||
|
static bool rainbow_beacon_all(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_sin_cos_all(params, &RAINBOW_BEACON_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving rainbow beacon esc
|
||||||
|
static bool rainbow_beacon_esc(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_sin_cos_esc(params, &RAINBOW_BEACON_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving rainbow beacon f13
|
||||||
|
static bool rainbow_beacon_f13(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_sin_cos_f13(params, &RAINBOW_BEACON_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving rainbow beacon cluster
|
||||||
|
static bool rainbow_beacon_clus(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_sin_cos_clus(params, &RAINBOW_BEACON_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Raindrops all
|
||||||
|
static bool raindrops_all(effect_params_t* params) {
|
||||||
|
if (!params->init) {
|
||||||
|
// Change one LED every tick, make sure speed is not 0
|
||||||
|
if (scale16by8(g_rgb_timer, qadd8(rgb_matrix_config.speed, 16)) % 10 == 0) {
|
||||||
|
raindrops_set_color_all(rand() % DRIVER_LED_TOTAL, params);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (int i = led_min; i < led_max; i++) {
|
||||||
|
raindrops_set_color_all(i, params);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Raindrops ESC
|
||||||
|
static bool raindrops_esc(effect_params_t* params) {
|
||||||
|
if (!params->init) {
|
||||||
|
// Change one LED every tick, make sure speed is not 0
|
||||||
|
if (scale16by8(g_rgb_timer, qadd8(rgb_matrix_config.speed, 16)) % 10 == 0) {
|
||||||
|
raindrops_set_color_esc(rand() % DRIVER_LED_TOTAL, params);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (int i = led_min; i < led_max; i++) {
|
||||||
|
raindrops_set_color_esc(i, params);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Raindrops F13
|
||||||
|
static bool raindrops_f13(effect_params_t* params) {
|
||||||
|
if (!params->init) {
|
||||||
|
// Change one LED every tick, make sure speed is not 0
|
||||||
|
if (scale16by8(g_rgb_timer, qadd8(rgb_matrix_config.speed, 16)) % 10 == 0) {
|
||||||
|
raindrops_set_color_f13(rand() % DRIVER_LED_TOTAL, params);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (int i = led_min; i < led_max; i++) {
|
||||||
|
raindrops_set_color_f13(i, params);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Raindrops Cluster
|
||||||
|
static bool raindrops_clus(effect_params_t* params) {
|
||||||
|
if (!params->init) {
|
||||||
|
// Change one LED every tick, make sure speed is not 0
|
||||||
|
if (scale16by8(g_rgb_timer, qadd8(rgb_matrix_config.speed, 16)) % 10 == 0) {
|
||||||
|
raindrops_set_color_clus(rand() % DRIVER_LED_TOTAL, params);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (int i = led_min; i < led_max; i++) {
|
||||||
|
raindrops_set_color_clus(i, params);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // RGB_MATRIX_CUSTOM_EFFECT_IMPLS
|
1
keyboards/mechlovin/infinity875/keymaps/default/rules.mk
Normal file
1
keyboards/mechlovin/infinity875/keymaps/default/rules.mk
Normal file
|
@ -0,0 +1 @@
|
||||||
|
RGB_MATRIX_CUSTOM_USER = no
|
24
keyboards/mechlovin/infinity875/keymaps/via/config.h
Normal file
24
keyboards/mechlovin/infinity875/keymaps/via/config.h
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
/*
|
||||||
|
Copyright 2021 Mechlovin' Studio
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
#ifdef RGB_MATRIX_ENABLE
|
||||||
|
|
||||||
|
#define VIA_QMK_RGBLIGHT_ENABLE
|
||||||
|
|
||||||
|
#endif
|
51
keyboards/mechlovin/infinity875/keymaps/via/keymap.c
Normal file
51
keyboards/mechlovin/infinity875/keymaps/via/keymap.c
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
/* Copyright 2021 Mechlovin' Studio
|
||||||
|
*
|
||||||
|
* 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
|
||||||
|
|
||||||
|
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
|
[0] = LAYOUT_all(
|
||||||
|
KC_ESC, 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_F13, KC_PSCR, KC_SLCK, KC_PAUS,
|
||||||
|
KC_GRV, 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_DEL, KC_INS, KC_HOME, KC_PGUP,
|
||||||
|
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_DEL, KC_END, KC_PGDN,
|
||||||
|
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,
|
||||||
|
KC_LSFT, KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_LSFT, KC_LSFT, KC_UP,
|
||||||
|
KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_LALT, KC_LGUI,MO(1), KC_LCTL, KC_LEFT, KC_DOWN, KC_RGHT
|
||||||
|
),
|
||||||
|
[1] = LAYOUT_all(
|
||||||
|
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_TRNS, 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_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, RGB_SAI, RGB_HUI,
|
||||||
|
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_TRNS, KC_TRNS, KC_TRNS, RGB_SAD, RGB_HUD,
|
||||||
|
KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, RGB_TOG,
|
||||||
|
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_TRNS, KC_TRNS, RGB_VAI,
|
||||||
|
KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, RGB_RMOD, RGB_VAD, RGB_MOD
|
||||||
|
),
|
||||||
|
[2] = LAYOUT_all(
|
||||||
|
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_TRNS, 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_TRNS, 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_TRNS, 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_TRNS,
|
||||||
|
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_TRNS,
|
||||||
|
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_TRNS, 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_TRNS
|
||||||
|
),
|
||||||
|
[3] = LAYOUT_all(
|
||||||
|
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_TRNS, 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_TRNS, 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_TRNS, 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_TRNS,
|
||||||
|
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_TRNS,
|
||||||
|
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_TRNS, 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_TRNS
|
||||||
|
),
|
||||||
|
};
|
1
keyboards/mechlovin/infinity875/keymaps/via/readme.md
Normal file
1
keyboards/mechlovin/infinity875/keymaps/via/readme.md
Normal file
|
@ -0,0 +1 @@
|
||||||
|
# The VIA keymap for infinity87.5
|
764
keyboards/mechlovin/infinity875/keymaps/via/rgb_matrix_user.inc
Normal file
764
keyboards/mechlovin/infinity875/keymaps/via/rgb_matrix_user.inc
Normal file
|
@ -0,0 +1,764 @@
|
||||||
|
/*
|
||||||
|
Copyright 2020 Evy Dekkers
|
||||||
|
|
||||||
|
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(solid_esc)
|
||||||
|
RGB_MATRIX_EFFECT(solid_f13)
|
||||||
|
RGB_MATRIX_EFFECT(solid_clus)
|
||||||
|
RGB_MATRIX_EFFECT(breathing_all)
|
||||||
|
RGB_MATRIX_EFFECT(breathing_esc)
|
||||||
|
RGB_MATRIX_EFFECT(breathing_f13)
|
||||||
|
RGB_MATRIX_EFFECT(breathing_clus)
|
||||||
|
RGB_MATRIX_EFFECT(band_val_all)
|
||||||
|
RGB_MATRIX_EFFECT(band_val_esc)
|
||||||
|
RGB_MATRIX_EFFECT(band_val_f13)
|
||||||
|
RGB_MATRIX_EFFECT(band_val_clus)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_up_down_all)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_up_down_esc)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_up_down_f13)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_up_down_clus)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_out_in_dual_all)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_out_in_dual_esc)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_out_in_dual_f13)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_out_in_dual_clus)
|
||||||
|
RGB_MATRIX_EFFECT(rainbow_moving_chevron_all)
|
||||||
|
RGB_MATRIX_EFFECT(rainbow_moving_chevron_esc)
|
||||||
|
RGB_MATRIX_EFFECT(rainbow_moving_chevron_f13)
|
||||||
|
RGB_MATRIX_EFFECT(rainbow_moving_chevron_clus)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_pimwheel_all)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_pimwheel_esc)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_pimwheel_f13)
|
||||||
|
RGB_MATRIX_EFFECT(cycle_pimwheel_clus)
|
||||||
|
RGB_MATRIX_EFFECT(rainbow_beacon_all)
|
||||||
|
RGB_MATRIX_EFFECT(rainbow_beacon_esc)
|
||||||
|
RGB_MATRIX_EFFECT(rainbow_beacon_f13)
|
||||||
|
RGB_MATRIX_EFFECT(rainbow_beacon_clus)
|
||||||
|
RGB_MATRIX_EFFECT(raindrops_all)
|
||||||
|
RGB_MATRIX_EFFECT(raindrops_esc)
|
||||||
|
RGB_MATRIX_EFFECT(raindrops_f13)
|
||||||
|
RGB_MATRIX_EFFECT(raindrops_clus)
|
||||||
|
|
||||||
|
#ifdef RGB_MATRIX_CUSTOM_EFFECT_IMPLS
|
||||||
|
|
||||||
|
bool effect_runner_all(effect_params_t* params, i_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint8_t time = scale16by8(g_rgb_timer, qadd8(rgb_matrix_config.speed / 4, 1));
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, i, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_esc(effect_params_t* params, i_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint8_t time = scale16by8(g_rgb_timer, qadd8(rgb_matrix_config.speed / 4, 1));
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, i, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 1; i < 18; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_f13(effect_params_t* params, i_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
uint8_t time = scale16by8(g_rgb_timer, qadd8(rgb_matrix_config.speed / 4, 1));
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, i, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
rgb_matrix_set_color(15, 0x00, 0x00, 0x00);
|
||||||
|
rgb_matrix_set_color(16, 0x00, 0x00, 0x00);
|
||||||
|
rgb_matrix_set_color(17, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 0; i < 14; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_clus(effect_params_t* params, i_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint8_t time = scale16by8(g_rgb_timer, qadd8(rgb_matrix_config.speed / 4, 1));
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, i, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 0; i < 15; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_dx_dy_all(effect_params_t* params, dx_dy_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint8_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 2);
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
int16_t dx = g_led_config.point[i].x - k_rgb_matrix_center.x;
|
||||||
|
int16_t dy = g_led_config.point[i].y - k_rgb_matrix_center.y;
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, dx, dy, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_dx_dy_esc(effect_params_t* params, dx_dy_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint8_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 2);
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
int16_t dx = g_led_config.point[i].x - k_rgb_matrix_center.x;
|
||||||
|
int16_t dy = g_led_config.point[i].y - k_rgb_matrix_center.y;
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, dx, dy, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 1; i < 18; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_dx_dy_f13(effect_params_t* params, dx_dy_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint8_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 2);
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
int16_t dx = g_led_config.point[i].x - k_rgb_matrix_center.x;
|
||||||
|
int16_t dy = g_led_config.point[i].y - k_rgb_matrix_center.y;
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, dx, dy, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
rgb_matrix_set_color(15, 0x00, 0x00, 0x00);
|
||||||
|
rgb_matrix_set_color(16, 0x00, 0x00, 0x00);
|
||||||
|
rgb_matrix_set_color(17, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 0; i < 14; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_dx_dy_clus(effect_params_t* params, dx_dy_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint8_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 2);
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
int16_t dx = g_led_config.point[i].x - k_rgb_matrix_center.x;
|
||||||
|
int16_t dy = g_led_config.point[i].y - k_rgb_matrix_center.y;
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, dx, dy, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 0; i < 15; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_sin_cos_all(effect_params_t* params, sin_cos_i_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint16_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 4);
|
||||||
|
int8_t cos_value = cos8(time) - 128;
|
||||||
|
int8_t sin_value = sin8(time) - 128;
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, cos_value, sin_value, i, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_sin_cos_esc(effect_params_t* params, sin_cos_i_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint16_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 4);
|
||||||
|
int8_t cos_value = cos8(time) - 128;
|
||||||
|
int8_t sin_value = sin8(time) - 128;
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, cos_value, sin_value, i, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 1; i < 18; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_sin_cos_f13(effect_params_t* params, sin_cos_i_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint16_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 4);
|
||||||
|
int8_t cos_value = cos8(time) - 128;
|
||||||
|
int8_t sin_value = sin8(time) - 128;
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, cos_value, sin_value, i, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
rgb_matrix_set_color(15, 0x00, 0x00, 0x00);
|
||||||
|
rgb_matrix_set_color(16, 0x00, 0x00, 0x00);
|
||||||
|
rgb_matrix_set_color(17, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 0; i < 14; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool effect_runner_sin_cos_clus(effect_params_t* params, sin_cos_i_f effect_func) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
uint16_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 4);
|
||||||
|
int8_t cos_value = cos8(time) - 128;
|
||||||
|
int8_t sin_value = sin8(time) - 128;
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(effect_func(rgb_matrix_config.hsv, cos_value, sin_value, i, time));
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 0; i < 15; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void raindrops_set_color_all(int i, effect_params_t* params) {
|
||||||
|
if (!HAS_ANY_FLAGS(g_led_config.flags[i], params->flags)) return;
|
||||||
|
HSV hsv = {0, rgb_matrix_config.hsv.s, rgb_matrix_config.hsv.v};
|
||||||
|
|
||||||
|
// Take the shortest path between hues
|
||||||
|
int16_t deltaH = ((rgb_matrix_config.hsv.h + 180) % 360 - rgb_matrix_config.hsv.h) / 4;
|
||||||
|
if (deltaH > 127) {
|
||||||
|
deltaH -= 256;
|
||||||
|
} else if (deltaH < -127) {
|
||||||
|
deltaH += 256;
|
||||||
|
}
|
||||||
|
|
||||||
|
hsv.h = rgb_matrix_config.hsv.h + (deltaH * (rand() & 0x03));
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(hsv);
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void raindrops_set_color_esc(int i, effect_params_t* params) {
|
||||||
|
if (!HAS_ANY_FLAGS(g_led_config.flags[i], params->flags)) return;
|
||||||
|
HSV hsv = {0, rgb_matrix_config.hsv.s, rgb_matrix_config.hsv.v};
|
||||||
|
|
||||||
|
// Take the shortest path between hues
|
||||||
|
int16_t deltaH = ((rgb_matrix_config.hsv.h + 180) % 360 - rgb_matrix_config.hsv.h) / 4;
|
||||||
|
if (deltaH > 127) {
|
||||||
|
deltaH -= 256;
|
||||||
|
} else if (deltaH < -127) {
|
||||||
|
deltaH += 256;
|
||||||
|
}
|
||||||
|
|
||||||
|
hsv.h = rgb_matrix_config.hsv.h + (deltaH * (rand() & 0x03));
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(hsv);
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
for (uint8_t i = 1; i < 18; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void raindrops_set_color_f13(int i, effect_params_t* params) {
|
||||||
|
if (!HAS_ANY_FLAGS(g_led_config.flags[i], params->flags)) return;
|
||||||
|
HSV hsv = {0, rgb_matrix_config.hsv.s, rgb_matrix_config.hsv.v};
|
||||||
|
|
||||||
|
// Take the shortest path between hues
|
||||||
|
int16_t deltaH = ((rgb_matrix_config.hsv.h + 180) % 360 - rgb_matrix_config.hsv.h) / 4;
|
||||||
|
if (deltaH > 127) {
|
||||||
|
deltaH -= 256;
|
||||||
|
} else if (deltaH < -127) {
|
||||||
|
deltaH += 256;
|
||||||
|
}
|
||||||
|
|
||||||
|
hsv.h = rgb_matrix_config.hsv.h + (deltaH * (rand() & 0x03));
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(hsv);
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
rgb_matrix_set_color(15, 0x00, 0x00, 0x00);
|
||||||
|
rgb_matrix_set_color(16, 0x00, 0x00, 0x00);
|
||||||
|
rgb_matrix_set_color(17, 0x00, 0x00, 0x00);
|
||||||
|
for (uint8_t i = 0; i < 14; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void raindrops_set_color_clus(int i, effect_params_t* params) {
|
||||||
|
if (!HAS_ANY_FLAGS(g_led_config.flags[i], params->flags)) return;
|
||||||
|
HSV hsv = {0, rgb_matrix_config.hsv.s, rgb_matrix_config.hsv.v};
|
||||||
|
|
||||||
|
// Take the shortest path between hues
|
||||||
|
int16_t deltaH = ((rgb_matrix_config.hsv.h + 180) % 360 - rgb_matrix_config.hsv.h) / 4;
|
||||||
|
if (deltaH > 127) {
|
||||||
|
deltaH -= 256;
|
||||||
|
} else if (deltaH < -127) {
|
||||||
|
deltaH += 256;
|
||||||
|
}
|
||||||
|
|
||||||
|
hsv.h = rgb_matrix_config.hsv.h + (deltaH * (rand() & 0x03));
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(hsv);
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
for (uint8_t i = 0; i < 15; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static HSV BAND_VAL_CUSTOM(HSV hsv, uint8_t i, uint8_t time) {
|
||||||
|
int16_t v = hsv.v - abs(scale8(g_led_config.point[i].x, 228) + 28 - time) * 8;
|
||||||
|
hsv.v = scale8(v < 0 ? 0 : v, hsv.v);
|
||||||
|
return hsv;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HSV CYCLE_UP_DOWN_CUSTOM(HSV hsv, uint8_t i, uint8_t time) {
|
||||||
|
hsv.h = g_led_config.point[i].y - time;
|
||||||
|
return hsv;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HSV CYCLE_OUT_IN_DUAL_CUSTOM(HSV hsv, int16_t dx, int16_t dy, uint8_t time) {
|
||||||
|
dx = (k_rgb_matrix_center.x / 2) - abs8(dx);
|
||||||
|
uint8_t dist = sqrt16(dx * dx + dy * dy);
|
||||||
|
hsv.h = 3 * dist + time;
|
||||||
|
return hsv;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HSV RAINBOW_MOVING_CHEVRON_CUSTOM(HSV hsv, uint8_t i, uint8_t time) {
|
||||||
|
hsv.h += abs8(g_led_config.point[i].y - k_rgb_matrix_center.y) + (g_led_config.point[i].x - time);
|
||||||
|
return hsv;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HSV CYCLE_PINWHEEL_CUSTOM(HSV hsv, int16_t dx, int16_t dy, uint8_t time) {
|
||||||
|
hsv.h = atan2_8(dy, dx) + time;
|
||||||
|
return hsv;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HSV RAINBOW_BEACON_CUSTOM(HSV hsv, int8_t sin, int8_t cos, uint8_t i, uint8_t time) {
|
||||||
|
hsv.h += ((g_led_config.point[i].y - k_rgb_matrix_center.y) * 2 * cos + (g_led_config.point[i].x - k_rgb_matrix_center.x) * 2 * sin) / 128;
|
||||||
|
return hsv;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// Solid ESC
|
||||||
|
static bool solid_esc(effect_params_t* params) {
|
||||||
|
HSV hsv = rgb_matrix_config.hsv;
|
||||||
|
RGB rgb = hsv_to_rgb(hsv);
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 18 ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
rgb_matrix_set_color(0, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Solid F13
|
||||||
|
static bool solid_f13(effect_params_t* params) {
|
||||||
|
HSV hsv = rgb_matrix_config.hsv;
|
||||||
|
RGB rgb = hsv_to_rgb(hsv);
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 18 ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
rgb_matrix_set_color(14, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Solid cluster
|
||||||
|
static bool solid_clus(effect_params_t* params) {
|
||||||
|
HSV hsv = rgb_matrix_config.hsv;
|
||||||
|
RGB rgb = hsv_to_rgb(hsv);
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 15 ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Breathing all
|
||||||
|
|
||||||
|
bool breathing_all(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
HSV hsv = rgb_matrix_config.hsv;
|
||||||
|
uint16_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 8);
|
||||||
|
hsv.v = scale8(abs8(sin8(time) - 128) * 2, hsv.v);
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(hsv);
|
||||||
|
for (uint8_t i = led_min; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Breathing ESC
|
||||||
|
static bool breathing_esc(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
HSV hsv = rgb_matrix_config.hsv;
|
||||||
|
uint16_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 8);
|
||||||
|
hsv.v = scale8(abs8(sin8(time) - 128) * 2, hsv.v);
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(hsv);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 18; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
rgb_matrix_set_color(0, rgb.r, rgb.g, rgb.b);
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Breathing F13
|
||||||
|
static bool breathing_f13(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
HSV hsv = rgb_matrix_config.hsv;
|
||||||
|
uint16_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 8);
|
||||||
|
hsv.v = scale8(abs8(sin8(time) - 128) * 2, hsv.v);
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(hsv);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 18; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
rgb_matrix_set_color(14, rgb.r, rgb.g, rgb.b);
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Breathing cluster
|
||||||
|
static bool breathing_clus(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
|
||||||
|
HSV hsv = rgb_matrix_config.hsv;
|
||||||
|
uint16_t time = scale16by8(g_rgb_timer, rgb_matrix_config.speed / 8);
|
||||||
|
hsv.v = scale8(abs8(sin8(time) - 128) * 2, hsv.v);
|
||||||
|
RGB rgb = rgb_matrix_hsv_to_rgb(hsv);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
for (uint8_t i = 15; i < led_max; i++) {
|
||||||
|
RGB_MATRIX_TEST_LED_FLAGS();
|
||||||
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Band Val all
|
||||||
|
bool band_val_all(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_all(params, &BAND_VAL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Band Val ESC
|
||||||
|
bool band_val_esc(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_esc(params, &BAND_VAL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Band Val F13
|
||||||
|
bool band_val_f13(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_f13(params, &BAND_VAL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Band Val Cluster
|
||||||
|
bool band_val_clus(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_clus(params, &BAND_VAL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cycle Up Down All
|
||||||
|
static bool cycle_up_down_all(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_all(params, &CYCLE_UP_DOWN_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cycle Up Down ESC
|
||||||
|
static bool cycle_up_down_esc(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_esc(params, &CYCLE_UP_DOWN_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cycle up down F13
|
||||||
|
static bool cycle_up_down_f13(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_f13(params, &CYCLE_UP_DOWN_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cycle up down cluster
|
||||||
|
static bool cycle_up_down_clus(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_clus(params, &CYCLE_UP_DOWN_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cycle out in dual All
|
||||||
|
static bool cycle_out_in_dual_all(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_dx_dy_all(params, &CYCLE_OUT_IN_DUAL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cycle out in dual ESC
|
||||||
|
static bool cycle_out_in_dual_esc(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_dx_dy_esc(params, &CYCLE_OUT_IN_DUAL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cycle out in dual f13
|
||||||
|
static bool cycle_out_in_dual_f13(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_dx_dy_f13(params, &CYCLE_OUT_IN_DUAL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cycle out in dual cluster
|
||||||
|
static bool cycle_out_in_dual_clus(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_dx_dy_clus(params, &CYCLE_OUT_IN_DUAL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving chevron all
|
||||||
|
static bool rainbow_moving_chevron_all(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_all(params, &RAINBOW_MOVING_CHEVRON_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving chevron ESC
|
||||||
|
static bool rainbow_moving_chevron_esc(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_esc(params, &RAINBOW_MOVING_CHEVRON_CUSTOM);
|
||||||
|
}
|
||||||
|
// Moving chevron F13
|
||||||
|
static bool rainbow_moving_chevron_f13(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_f13(params, &RAINBOW_MOVING_CHEVRON_CUSTOM);
|
||||||
|
}
|
||||||
|
// Moving chevron cluster
|
||||||
|
static bool rainbow_moving_chevron_clus(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_clus(params, &RAINBOW_MOVING_CHEVRON_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving cycle pimwheel all
|
||||||
|
static bool cycle_pimwheel_all(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_dx_dy_all(params, &CYCLE_PINWHEEL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving cycle pimwheel esc
|
||||||
|
static bool cycle_pimwheel_esc(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_dx_dy_esc(params, &CYCLE_PINWHEEL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving cycle pimwheel f13
|
||||||
|
static bool cycle_pimwheel_f13(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_dx_dy_f13(params, &CYCLE_PINWHEEL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving cycle pimwheel cluster
|
||||||
|
static bool cycle_pimwheel_clus(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_dx_dy_clus(params, &CYCLE_PINWHEEL_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving rainbow beacon all
|
||||||
|
static bool rainbow_beacon_all(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_sin_cos_all(params, &RAINBOW_BEACON_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving rainbow beacon esc
|
||||||
|
static bool rainbow_beacon_esc(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_sin_cos_esc(params, &RAINBOW_BEACON_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving rainbow beacon f13
|
||||||
|
static bool rainbow_beacon_f13(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_sin_cos_f13(params, &RAINBOW_BEACON_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moving rainbow beacon cluster
|
||||||
|
static bool rainbow_beacon_clus(effect_params_t* params) {
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (uint8_t i = led_min ; i < led_max; i++) {
|
||||||
|
rgb_matrix_set_color(i, 0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
return effect_runner_sin_cos_clus(params, &RAINBOW_BEACON_CUSTOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Raindrops all
|
||||||
|
static bool raindrops_all(effect_params_t* params) {
|
||||||
|
if (!params->init) {
|
||||||
|
// Change one LED every tick, make sure speed is not 0
|
||||||
|
if (scale16by8(g_rgb_timer, qadd8(rgb_matrix_config.speed, 16)) % 10 == 0) {
|
||||||
|
raindrops_set_color_all(rand() % DRIVER_LED_TOTAL, params);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (int i = led_min; i < led_max; i++) {
|
||||||
|
raindrops_set_color_all(i, params);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Raindrops ESC
|
||||||
|
static bool raindrops_esc(effect_params_t* params) {
|
||||||
|
if (!params->init) {
|
||||||
|
// Change one LED every tick, make sure speed is not 0
|
||||||
|
if (scale16by8(g_rgb_timer, qadd8(rgb_matrix_config.speed, 16)) % 10 == 0) {
|
||||||
|
raindrops_set_color_esc(rand() % DRIVER_LED_TOTAL, params);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (int i = led_min; i < led_max; i++) {
|
||||||
|
raindrops_set_color_esc(i, params);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Raindrops F13
|
||||||
|
static bool raindrops_f13(effect_params_t* params) {
|
||||||
|
if (!params->init) {
|
||||||
|
// Change one LED every tick, make sure speed is not 0
|
||||||
|
if (scale16by8(g_rgb_timer, qadd8(rgb_matrix_config.speed, 16)) % 10 == 0) {
|
||||||
|
raindrops_set_color_f13(rand() % DRIVER_LED_TOTAL, params);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (int i = led_min; i < led_max; i++) {
|
||||||
|
raindrops_set_color_f13(i, params);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Raindrops Cluster
|
||||||
|
static bool raindrops_clus(effect_params_t* params) {
|
||||||
|
if (!params->init) {
|
||||||
|
// Change one LED every tick, make sure speed is not 0
|
||||||
|
if (scale16by8(g_rgb_timer, qadd8(rgb_matrix_config.speed, 16)) % 10 == 0) {
|
||||||
|
raindrops_set_color_clus(rand() % DRIVER_LED_TOTAL, params);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
||||||
|
for (int i = led_min; i < led_max; i++) {
|
||||||
|
raindrops_set_color_clus(i, params);
|
||||||
|
}
|
||||||
|
return led_max < DRIVER_LED_TOTAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // RGB_MATRIX_CUSTOM_EFFECT_IMPLS
|
3
keyboards/mechlovin/infinity875/keymaps/via/rules.mk
Normal file
3
keyboards/mechlovin/infinity875/keymaps/via/rules.mk
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
VIA_ENABLE = yes
|
||||||
|
|
||||||
|
RGB_MATRIX_CUSTOM_USER = yes
|
388
keyboards/mechlovin/infinity875/matrix.c
Normal file
388
keyboards/mechlovin/infinity875/matrix.c
Normal file
|
@ -0,0 +1,388 @@
|
||||||
|
/*
|
||||||
|
Copyright 2012-2018 Jun Wako, Jack Humbert, Yiancar
|
||||||
|
Copyright 2019 Evy Dekkers
|
||||||
|
|
||||||
|
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 <stdint.h>
|
||||||
|
#include <stdbool.h>
|
||||||
|
#include "wait.h"
|
||||||
|
#include "util.h"
|
||||||
|
#include "matrix.h"
|
||||||
|
#include "debounce.h"
|
||||||
|
#include "quantum.h"
|
||||||
|
|
||||||
|
#ifdef DIRECT_PINS
|
||||||
|
static pin_t direct_pins[MATRIX_ROWS][MATRIX_COLS] = DIRECT_PINS;
|
||||||
|
#elif (DIODE_DIRECTION == ROW2COL) || (DIODE_DIRECTION == COL2ROW)
|
||||||
|
static const pin_t row_pins[MATRIX_ROWS] = MATRIX_ROW_PINS;
|
||||||
|
//static const pin_t col_pins[MATRIX_COLS] = MATRIX_COL_PINS;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// matrix code
|
||||||
|
|
||||||
|
#ifdef DIRECT_PINS
|
||||||
|
|
||||||
|
static void init_pins(void) {
|
||||||
|
for (int row = 0; row < MATRIX_ROWS; row++) {
|
||||||
|
for (int col = 0; col < MATRIX_COLS; col++) {
|
||||||
|
pin_t pin = direct_pins[row][col];
|
||||||
|
if (pin != NO_PIN) {
|
||||||
|
setPinInputHigh(pin);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool read_cols_on_row(matrix_row_t current_matrix[], uint8_t current_row) {
|
||||||
|
matrix_row_t last_row_value = current_matrix[current_row];
|
||||||
|
current_matrix[current_row] = 0;
|
||||||
|
|
||||||
|
for (uint8_t col_index = 0; col_index < MATRIX_COLS; col_index++) {
|
||||||
|
pin_t pin = direct_pins[current_row][col_index];
|
||||||
|
if (pin != NO_PIN) {
|
||||||
|
current_matrix[current_row] |= readPin(pin) ? 0 : (MATRIX_ROW_SHIFTER << col_index);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return (last_row_value != current_matrix[current_row]);
|
||||||
|
}
|
||||||
|
|
||||||
|
#elif (DIODE_DIRECTION == ROW2COL)
|
||||||
|
|
||||||
|
/* Cols 0 - 16
|
||||||
|
* These columns use two 74HC138 3 to 8 bit demultiplexer. B0, F1 is the enable pin, must be set high (1) to use it.
|
||||||
|
*
|
||||||
|
* col / pin: PB5 PB7 PF0 PB0 PF1 PE6
|
||||||
|
* 0: 0 ── 0 ── 0 1 ── 0 0
|
||||||
|
* ────────────────────────────────────────────
|
||||||
|
* 1: 0 ── 0 ── 1 1 ── 0 0
|
||||||
|
* ────────────────────────────────────────────
|
||||||
|
* 2: 0 ── 1 ── 0 1 ── 0 0
|
||||||
|
* ────────────────────────────────────────────
|
||||||
|
* 3: 0 ── 1 ── 1 1 ── 0 0
|
||||||
|
* ────────────────────────────────────────────
|
||||||
|
* 4: 1 ── 0 ── 0 1 ── 0 0
|
||||||
|
* ────────────────────────────────────────────
|
||||||
|
* 5: 1 ── 0 ── 1 1 ── 0 0
|
||||||
|
* ────────────────────────────────────────────
|
||||||
|
* 6: 1 ── 1 ── 0 1 ── 0 0
|
||||||
|
* ────────────────────────────────────────────
|
||||||
|
* 7: 1 ── 1 ── 1 1 ── 0 0
|
||||||
|
* ────────────────────────────────────────────
|
||||||
|
* 8: 0 ── 0 ── 0 0 ── 1 0
|
||||||
|
* ────────────────────────────────────────────
|
||||||
|
* 9: 0 ── 0 ── 1 0 ── 1 0
|
||||||
|
* ────────────────────────────────────────────
|
||||||
|
*10: 0 ── 1 ── 0 0 ── 1 0
|
||||||
|
* ────────────────────────────────────────────
|
||||||
|
*11: 0 ── 1 ── 1 0 ── 1 0
|
||||||
|
* ────────────────────────────────────────────
|
||||||
|
*12: 1 ── 0 ── 0 0 ── 1 0
|
||||||
|
* ────────────────────────────────────────────
|
||||||
|
*13: 1 ── 0 ── 1 0 ── 1 0
|
||||||
|
* ────────────────────────────────────────────
|
||||||
|
*14: 1 ── 1 ── 1 0 ── 1 0
|
||||||
|
* ────────────────────────────────────────────
|
||||||
|
*15: 1 ── 1 ── 0 0 ── 1 0
|
||||||
|
* ────────────────────────────────────────────
|
||||||
|
*16: 0 ── 0 ── 0 0 ── 0 1
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
static void select_col(uint8_t col) {
|
||||||
|
switch (col) {
|
||||||
|
case 0:
|
||||||
|
writePinLow(B5);
|
||||||
|
writePinLow(B7);
|
||||||
|
writePinLow(F0);
|
||||||
|
writePinHigh(B0);
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
writePinLow(B5);
|
||||||
|
writePinLow(B7);
|
||||||
|
writePinHigh(F0);
|
||||||
|
writePinHigh(B0);
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
writePinLow(B5);
|
||||||
|
writePinHigh(B7);
|
||||||
|
writePinLow(F0);
|
||||||
|
writePinHigh(B0);
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
writePinLow(B5);
|
||||||
|
writePinHigh(B7);
|
||||||
|
writePinHigh(F0);
|
||||||
|
writePinHigh(B0);
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
writePinHigh(B5);
|
||||||
|
writePinLow(B7);
|
||||||
|
writePinLow(F0);
|
||||||
|
writePinHigh(B0);
|
||||||
|
break;
|
||||||
|
case 5:
|
||||||
|
writePinHigh(B5);
|
||||||
|
writePinLow(B7);
|
||||||
|
writePinHigh(F0);
|
||||||
|
writePinHigh(B0);
|
||||||
|
break;
|
||||||
|
case 6:
|
||||||
|
writePinHigh(B5);
|
||||||
|
writePinHigh(B7);
|
||||||
|
writePinLow(F0);
|
||||||
|
writePinHigh(B0);
|
||||||
|
break;
|
||||||
|
case 7:
|
||||||
|
writePinHigh(B5);
|
||||||
|
writePinHigh(B7);
|
||||||
|
writePinHigh(F0);
|
||||||
|
writePinHigh(B0);
|
||||||
|
break;
|
||||||
|
case 8:
|
||||||
|
writePinLow(B5);
|
||||||
|
writePinLow(B7);
|
||||||
|
writePinLow(F0);
|
||||||
|
writePinHigh(F1);
|
||||||
|
break;
|
||||||
|
case 9:
|
||||||
|
writePinLow(B5);
|
||||||
|
writePinLow(B7);
|
||||||
|
writePinHigh(F0);
|
||||||
|
writePinHigh(F1);
|
||||||
|
break;
|
||||||
|
case 10:
|
||||||
|
writePinLow(B5);
|
||||||
|
writePinHigh(B7);
|
||||||
|
writePinLow(F0);
|
||||||
|
writePinHigh(F1);
|
||||||
|
break;
|
||||||
|
case 11:
|
||||||
|
writePinLow(B5);
|
||||||
|
writePinHigh(B7);
|
||||||
|
writePinHigh(F0);
|
||||||
|
writePinHigh(F1);
|
||||||
|
break;
|
||||||
|
case 12:
|
||||||
|
writePinHigh(B5);
|
||||||
|
writePinLow(B7);
|
||||||
|
writePinLow(F0);
|
||||||
|
writePinHigh(F1);
|
||||||
|
break;
|
||||||
|
case 13:
|
||||||
|
writePinHigh(B5);
|
||||||
|
writePinLow(B7);
|
||||||
|
writePinHigh(F0);
|
||||||
|
writePinHigh(F1);
|
||||||
|
break;
|
||||||
|
case 14:
|
||||||
|
writePinHigh(B5);
|
||||||
|
writePinHigh(B7);
|
||||||
|
writePinHigh(F0);
|
||||||
|
writePinHigh(F1);
|
||||||
|
break;
|
||||||
|
case 15:
|
||||||
|
writePinHigh(B5);
|
||||||
|
writePinHigh(B7);
|
||||||
|
writePinLow(F0);
|
||||||
|
writePinHigh(F1);
|
||||||
|
break;
|
||||||
|
case 16:
|
||||||
|
writePinLow(E6);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void unselect_col(uint8_t col) {
|
||||||
|
switch (col) {
|
||||||
|
case 0:
|
||||||
|
writePinHigh(B5);
|
||||||
|
writePinHigh(B7);
|
||||||
|
writePinHigh(F0);
|
||||||
|
writePinLow(B0);
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
writePinHigh(B5);
|
||||||
|
writePinHigh(B7);
|
||||||
|
writePinLow(F0);
|
||||||
|
writePinLow(B0);
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
writePinHigh(B5);
|
||||||
|
writePinLow(B7);
|
||||||
|
writePinHigh(F0);
|
||||||
|
writePinLow(B0);
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
writePinHigh(B5);
|
||||||
|
writePinLow(B7);
|
||||||
|
writePinLow(F0);
|
||||||
|
writePinLow(B0);
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
writePinLow(B5);
|
||||||
|
writePinHigh(B7);
|
||||||
|
writePinHigh(F0);
|
||||||
|
writePinLow(B0);
|
||||||
|
break;
|
||||||
|
case 5:
|
||||||
|
writePinLow(B5);
|
||||||
|
writePinHigh(B7);
|
||||||
|
writePinLow(F0);
|
||||||
|
writePinLow(B0);
|
||||||
|
break;
|
||||||
|
case 6:
|
||||||
|
writePinLow(B5);
|
||||||
|
writePinLow(B7);
|
||||||
|
writePinHigh(F0);
|
||||||
|
writePinLow(B0);
|
||||||
|
break;
|
||||||
|
case 7:
|
||||||
|
writePinLow(B5);
|
||||||
|
writePinLow(B7);
|
||||||
|
writePinLow(F0);
|
||||||
|
writePinLow(B0);
|
||||||
|
break;
|
||||||
|
case 8:
|
||||||
|
writePinHigh(B5);
|
||||||
|
writePinHigh(B7);
|
||||||
|
writePinHigh(F0);
|
||||||
|
writePinLow(F1);
|
||||||
|
break;
|
||||||
|
case 9:
|
||||||
|
writePinHigh(B5);
|
||||||
|
writePinHigh(B7);
|
||||||
|
writePinLow(F0);
|
||||||
|
writePinLow(F1);
|
||||||
|
break;
|
||||||
|
case 10:
|
||||||
|
writePinHigh(B5);
|
||||||
|
writePinLow(B7);
|
||||||
|
writePinHigh(F0);
|
||||||
|
writePinLow(F1);
|
||||||
|
break;
|
||||||
|
case 11:
|
||||||
|
writePinHigh(B5);
|
||||||
|
writePinLow(B7);
|
||||||
|
writePinLow(F0);
|
||||||
|
writePinLow(F1);
|
||||||
|
break;
|
||||||
|
case 12:
|
||||||
|
writePinLow(B5);
|
||||||
|
writePinHigh(B7);
|
||||||
|
writePinHigh(F0);
|
||||||
|
writePinLow(F1);
|
||||||
|
break;
|
||||||
|
case 13:
|
||||||
|
writePinLow(B5);
|
||||||
|
writePinHigh(B7);
|
||||||
|
writePinLow(F0);
|
||||||
|
writePinLow(F1);
|
||||||
|
break;
|
||||||
|
case 14:
|
||||||
|
writePinLow(B5);
|
||||||
|
writePinLow(B7);
|
||||||
|
writePinLow(F0);
|
||||||
|
writePinLow(F1);
|
||||||
|
break;
|
||||||
|
case 15:
|
||||||
|
writePinLow(B5);
|
||||||
|
writePinLow(B7);
|
||||||
|
writePinHigh(F0);
|
||||||
|
writePinLow(F1);
|
||||||
|
break;
|
||||||
|
case 16:
|
||||||
|
writePinHigh(E6);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void unselect_cols(void) {
|
||||||
|
//Native
|
||||||
|
writePinHigh(E6);
|
||||||
|
|
||||||
|
//Demultiplexer
|
||||||
|
writePinLow(B0);
|
||||||
|
writePinLow(F1);
|
||||||
|
writePinHigh(B5);
|
||||||
|
writePinHigh(B7);
|
||||||
|
writePinHigh(F0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void init_pins(void) {
|
||||||
|
unselect_cols();
|
||||||
|
for (uint8_t x = 0; x < MATRIX_ROWS; x++) {
|
||||||
|
setPinInputHigh(row_pins[x]);
|
||||||
|
}
|
||||||
|
setPinOutput(B5);
|
||||||
|
setPinOutput(B7);
|
||||||
|
setPinOutput(F0);
|
||||||
|
setPinOutput(B0);
|
||||||
|
setPinOutput(F1);
|
||||||
|
setPinOutput(E6);
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool read_rows_on_col(matrix_row_t current_matrix[], uint8_t current_col) {
|
||||||
|
bool matrix_changed = false;
|
||||||
|
|
||||||
|
// Select col and wait for col selecton to stabilize
|
||||||
|
select_col(current_col);
|
||||||
|
wait_us(30);
|
||||||
|
|
||||||
|
// For each row...
|
||||||
|
for (uint8_t row_index = 0; row_index < MATRIX_ROWS; row_index++) {
|
||||||
|
// Store last value of row prior to reading
|
||||||
|
matrix_row_t last_row_value = current_matrix[row_index];
|
||||||
|
|
||||||
|
// Check row pin state
|
||||||
|
if (readPin(row_pins[row_index]) == 0) {
|
||||||
|
// Pin LO, set col bit
|
||||||
|
current_matrix[row_index] |= (MATRIX_ROW_SHIFTER << current_col);
|
||||||
|
} else {
|
||||||
|
// Pin HI, clear col bit
|
||||||
|
current_matrix[row_index] &= ~(MATRIX_ROW_SHIFTER << current_col);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Determine if the matrix changed state
|
||||||
|
if ((last_row_value != current_matrix[row_index]) && !(matrix_changed)) {
|
||||||
|
matrix_changed = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Unselect col
|
||||||
|
unselect_col(current_col);
|
||||||
|
|
||||||
|
return matrix_changed;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void matrix_init_custom(void) {
|
||||||
|
// initialize key pins
|
||||||
|
init_pins();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool matrix_scan_custom(matrix_row_t current_matrix[]) {
|
||||||
|
bool changed = false;
|
||||||
|
|
||||||
|
#if defined(DIRECT_PINS) || (DIODE_DIRECTION == ROW2COL)
|
||||||
|
// Set col, read rows
|
||||||
|
for (uint8_t current_col = 0; current_col < MATRIX_COLS; current_col++) {
|
||||||
|
changed |= read_rows_on_col(current_matrix, current_col);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return changed;
|
||||||
|
}
|
24
keyboards/mechlovin/infinity875/readme.md
Normal file
24
keyboards/mechlovin/infinity875/readme.md
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
# infinity875
|
||||||
|
|
||||||
|
![infinity875](https://i.imgur.com/qt4YBwSl.jpeg)
|
||||||
|
|
||||||
|
The Infinity 87.5 is in the popular A87 form factor with Top-sided USB Type-C and supports BOTH the F12 and F13 footprints, so it’s compatible with a number of TKL boards like Geonworks Frog/F1-8x; KFE-CE; Singa Jaguar, among others.
|
||||||
|
|
||||||
|
* Keyboard Maintainer: [Mechlovin' Studio](https://github.com/mechlovin)
|
||||||
|
* Hardware Supported: Infinity87.5, Atmega32u4
|
||||||
|
* Hardware Availability: [GB](https://geekhack.org/index.php?topic=115251.0), [CBB Planet](https://cbbplanet.com/products/infinity-87-5-pcb), [Mechlovin' Studio](https://mechlovin.studio)
|
||||||
|
|
||||||
|
Make example for this keyboard (after setting up your build environment):
|
||||||
|
|
||||||
|
make mechlovin/infinity875:default
|
||||||
|
|
||||||
|
Flashing example for this keyboard:
|
||||||
|
|
||||||
|
make mechlovin/infinity875:default:flash
|
||||||
|
|
||||||
|
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).
|
||||||
|
|
||||||
|
**Reset Key:** 3 ways to put the IF87.5 into bootloader:
|
||||||
|
- By keycode: Tap RESET keycode.
|
||||||
|
- By bootmagic: hold ESC key while plugging in.
|
||||||
|
- By hardware: Push reset button on bottom of the PCB while the PCB is plugged in.
|
23
keyboards/mechlovin/infinity875/rules.mk
Normal file
23
keyboards/mechlovin/infinity875/rules.mk
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
# MCU name
|
||||||
|
MCU = atmega32u4
|
||||||
|
|
||||||
|
# Bootloader selection
|
||||||
|
BOOTLOADER = atmel-dfu
|
||||||
|
|
||||||
|
# Build Options
|
||||||
|
# change yes to no to disable
|
||||||
|
#
|
||||||
|
BOOTMAGIC_ENABLE = yes # Enable Bootmagic Lite
|
||||||
|
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
|
||||||
|
NKRO_ENABLE = no # Enable N-Key Rollover
|
||||||
|
BACKLIGHT_ENABLE = no # Enable keyboard backlight functionality
|
||||||
|
RGBLIGHT_ENABLE = no # Enable keyboard RGB underglow
|
||||||
|
AUDIO_ENABLE = no # Audio output
|
||||||
|
CUSTOM_MATRIX = lite
|
||||||
|
RGB_MATRIX_ENABLE = yes
|
||||||
|
RGB_MATRIX_DRIVER = WS2812
|
||||||
|
|
||||||
|
SRC += matrix.c
|
Loading…
Reference in a new issue