2022-05-02 21:34:44 +02:00
|
|
|
// Copyright 2021 Ryan Skidmore (@ryanskidmore, rskeys@ryanskidmore.co.uk)
|
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "config_common.h"
|
|
|
|
|
|
|
|
/* Key Matrix Sizes */
|
|
|
|
#define MATRIX_ROWS 6
|
|
|
|
#define MATRIX_COLS 24
|
|
|
|
|
|
|
|
/* Rows */
|
|
|
|
#define ROW_A D4
|
|
|
|
#define ROW_B C6
|
|
|
|
#define ROW_C D7
|
|
|
|
#define ROW_D E6
|
|
|
|
#define ROW_E B4
|
|
|
|
#define ROW_F B5
|
|
|
|
|
|
|
|
/* Columns 0 - 20 (24 with dummy columns for shift registers) */
|
|
|
|
#define SHR_LATCH B2
|
|
|
|
#define SHR_CLOCK B3
|
|
|
|
#define SHR_DATA B1
|
|
|
|
#define SHR_COLS { 0x000001, 0x000002, 0x000004, 0x000008, 0x000010, 0x000020, 0x000040, 0x000080, 0x000100, 0x000200, 0x000400, 0x000800, 0x001000, 0x002000, 0x004000, 0x008000, 0x010000, 0x020000, 0x040000, 0x080000, 0x100000, 0x200000, 0x400000, 0x800000 }
|
|
|
|
|
|
|
|
/* The shift registers on the matrix PCB output a signal on each column, which passes through the
|
|
|
|
* switch and a diode towards the row. The row is then connected to the AVR as an input. This means
|
|
|
|
* the diode direction is COL(umn) to ROW */
|
|
|
|
#define DIODE_DIRECTION COL2ROW
|
|
|
|
|
|
|
|
/* RGB Data Pin */
|
|
|
|
#define RGB_DI_PIN C7
|
|
|
|
/* The number of RGB LEDs connected */
|
2022-11-11 02:15:19 +01:00
|
|
|
#define RGB_MATRIX_LED_COUNT 105
|
2022-05-02 21:34:44 +02:00
|
|
|
/* Set the maximum brightness to 110 to avoid going over 500 mA.
|
|
|
|
* At full brightness with all three indicator LEDs on, the power draw is about 450 mA. */
|
|
|
|
#define RGB_MATRIX_MAXIMUM_BRIGHTNESS 110
|
|
|
|
/* Enable framebuffer effects */
|
|
|
|
#define RGB_MATRIX_FRAMEBUFFER_EFFECTS
|
|
|
|
/* Enable the cycle left right animation and set it as the startup mode */
|
|
|
|
#define ENABLE_RGB_MATRIX_CYCLE_LEFT_RIGHT
|
|
|
|
#define RGB_MATRIX_STARTUP_MODE RGB_MATRIX_CYCLE_LEFT_RIGHT
|
|
|
|
|
|
|
|
/* Debounce reduces chatter (unintended double-presses) - set 0 if debouncing is not needed */
|
|
|
|
#define DEBOUNCE 5
|
|
|
|
|
|
|
|
/* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */
|
|
|
|
#define LOCKING_SUPPORT_ENABLE
|
|
|
|
/* Locking resynchronize hack */
|
|
|
|
#define LOCKING_RESYNC_ENABLE
|
|
|
|
|
|
|
|
/* Set the max power consumption for the keyboard, which is 500 mA. */
|
|
|
|
#define USB_MAX_POWER_CONSUMPTION 500
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Force NKRO
|
|
|
|
*
|
|
|
|
* Force NKRO (nKey Rollover) to be enabled by default, regardless of the saved
|
|
|
|
* state in the bootmagic EEPROM settings. (Note that NKRO must be enabled in the
|
|
|
|
* makefile for this to work.)
|
|
|
|
*
|
|
|
|
* If forced on, NKRO can be disabled via magic key (default = LShift+RShift+N)
|
|
|
|
* until the next keyboard reset.
|
|
|
|
*
|
|
|
|
* NKRO may prevent your keystrokes from being detected in the BIOS, but it is
|
|
|
|
* fully operational during normal computer usage.
|
|
|
|
*
|
|
|
|
* For a less heavy-handed approach, enable NKRO via magic key (LShift+RShift+N)
|
|
|
|
* or via bootmagic (hold SPACE+N while plugging in the keyboard). Once set by
|
|
|
|
* bootmagic, NKRO mode will always be enabled until it is toggled again during a
|
|
|
|
* power-up.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
#define FORCE_NKRO
|