summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorlokher <lokher@gmail.com>2023-07-10 15:51:39 +0800
committerGitHub <noreply@github.com>2023-07-10 15:51:39 +0800
commit8ff8ad4c05783ebb2d8e308e1f5a1df66931c2f9 (patch)
tree1f5185b46ab695f06b45b32a84f3cf8fc0c1d8c0
parent0e22694fe0973c1974f370f2b635fc1dbb2f858e (diff)
parent602cc6f3a47305d003e7b127eefc2cbc224b03d2 (diff)
Merge pull request #141 from lalalademaxiya1/keychron-q2_pro
Update Q2 Pro
-rw-r--r--keyboards/keychron/q2_pro/ansi_encoder/ansi_encoder.c32
-rw-r--r--keyboards/keychron/q2_pro/ansi_encoder/config.h19
-rw-r--r--keyboards/keychron/q2_pro/ansi_encoder/info.json75
-rw-r--r--keyboards/keychron/q2_pro/ansi_encoder/keymaps/default/keymap.c18
-rw-r--r--keyboards/keychron/q2_pro/ansi_encoder/keymaps/via/keymap.c18
-rw-r--r--keyboards/keychron/q2_pro/ansi_encoder/keymaps/via/rules.mk1
-rw-r--r--keyboards/keychron/q2_pro/config.h4
-rw-r--r--keyboards/keychron/q2_pro/info.json7
-rwxr-xr-xkeyboards/keychron/q2_pro/iso_encoder/config.h55
-rwxr-xr-xkeyboards/keychron/q2_pro/iso_encoder/info.json160
-rwxr-xr-xkeyboards/keychron/q2_pro/iso_encoder/iso_encoder.c99
-rwxr-xr-xkeyboards/keychron/q2_pro/iso_encoder/keymaps/default/keymap.c73
-rwxr-xr-xkeyboards/keychron/q2_pro/iso_encoder/keymaps/default/rules.mk1
-rwxr-xr-xkeyboards/keychron/q2_pro/iso_encoder/keymaps/via/keymap.c73
-rwxr-xr-xkeyboards/keychron/q2_pro/iso_encoder/keymaps/via/rules.mk2
-rwxr-xr-xkeyboards/keychron/q2_pro/iso_encoder/rules.mk1
-rw-r--r--keyboards/keychron/q2_pro/matrix.c147
-rw-r--r--keyboards/keychron/q2_pro/q2_pro.c40
-rw-r--r--keyboards/keychron/q2_pro/readme.md6
-rwxr-xr-xkeyboards/keychron/q2_pro/via_json/q2_pro_ansi_encoder.json250
-rwxr-xr-xkeyboards/keychron/q2_pro/via_json/q2_pro_iso_encoder.json254
21 files changed, 1165 insertions, 170 deletions
diff --git a/keyboards/keychron/q2_pro/ansi_encoder/ansi_encoder.c b/keyboards/keychron/q2_pro/ansi_encoder/ansi_encoder.c
index ca92d5e5f1..9a04acfffd 100644
--- a/keyboards/keychron/q2_pro/ansi_encoder/ansi_encoder.c
+++ b/keyboards/keychron/q2_pro/ansi_encoder/ansi_encoder.c
@@ -38,7 +38,6 @@ const ckled2001_led g_ckled2001_leds[RGB_MATRIX_LED_COUNT] = {
{0, C_5, A_5, B_5},
{0, C_4, A_4, B_4},
{0, C_3, A_3, B_3},
- {0, C_1, A_1, B_1},
{0, F_16, D_16, E_16},
{0, F_15, D_15, E_15},
@@ -94,35 +93,6 @@ const ckled2001_led g_ckled2001_leds[RGB_MATRIX_LED_COUNT] = {
{1, F_4, D_4, E_4},
{1, F_3, D_3, E_3},
{1, F_2, D_2, E_2},
- {1, F_1, D_1, E_1}
-};
-
-#define __ NO_LED
-
-led_config_t g_led_config = {
- {
- // Key Matrix to LED Index
- { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, __, 14 },
- { 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, __, 29 },
- { 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, __, 42, __, 43 },
- { 44, __, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, __, 55, 56, __ },
- { 57, 58, 59, __, __, __, 60, __, __, __, 61, 62, 63, 64, 65, 66 }
- },
- {
- // LED Index to Physical Position
- {0, 3}, {14, 3}, {29, 3}, {43, 3}, {58, 3}, {73, 3}, {87, 3}, {102, 3}, {117, 3}, {131, 3}, {146, 3}, {161, 3}, {175, 3}, {197, 3}, {223, 3},
- {3,17}, {21,17}, {36,17}, {51,17}, {65,17}, {80,17}, {95,17}, {109, 17}, {124, 17}, {139, 17}, {153, 17}, {168, 17}, {183, 17}, {201, 17}, {223, 17},
- {5,32}, {25,32}, {40,32}, {54,32}, {69,32}, {84,32}, {98,32}, {113, 32}, {128, 32}, {142, 32}, {157, 32}, {172, 32}, {195, 32}, {223, 32},
- {9,47}, {32,47}, {47,47}, {62,47}, {76,47}, {91,47}, {106, 47}, {120, 47}, {135, 47}, {150, 47}, {164, 47}, {185, 47}, {209, 47},
- {1,62}, {20,62}, {38,62}, {93,62}, {146, 62}, {161, 62}, {176, 62}, {194, 62}, {209, 62}, {223, 62}
- },
- {
- // RGB LED Index to Flag
- 1, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 1, 1,
- 1, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 1,
- 8, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 1, 1,
- 1, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 1, 1,
- 1, 1, 1, 4, 1, 1, 1, 1, 1, 1
- }
+ {1, F_1, D_1, E_1},
};
#endif
diff --git a/keyboards/keychron/q2_pro/ansi_encoder/config.h b/keyboards/keychron/q2_pro/ansi_encoder/config.h
index 3fb1c48a04..79c6b6a986 100644
--- a/keyboards/keychron/q2_pro/ansi_encoder/config.h
+++ b/keyboards/keychron/q2_pro/ansi_encoder/config.h
@@ -24,7 +24,9 @@
# define DRIVER_COUNT 2
# define DRIVER_ADDR_1 0b1110111
# define DRIVER_ADDR_2 0b1110100
-# define DRIVER_1_LED_TOTAL 30
+
+/* RGB Matrix Configuration */
+# define DRIVER_1_LED_TOTAL 29
# define DRIVER_2_LED_TOTAL 37
# define RGB_MATRIX_LED_COUNT (DRIVER_1_LED_TOTAL + DRIVER_2_LED_TOTAL)
@@ -37,22 +39,17 @@
/* Turn off backllit if brightness value is low */
# define RGB_MATRIX_BRIGHTNESS_TURN_OFF_VAL 48
-# define CAPS_LOCK_INDEX 30
-
-# define LOW_BAT_IND_INDEX 60
-
-// RGB Matrix Animation modes. Explicitly enabled
-// For full list of effects, see:
-// https://docs.qmk.fm/#/feature_rgb_matrix?id=rgb-matrix-effects
+/* Indication led index */
+# define CAPS_LOCK_INDEX 29
+# define LOW_BAT_IND_INDEX 59
# define RGB_MATRIX_KEYPRESSES
# define RGB_MATRIX_FRAMEBUFFER_EFFECTS
-/* Scan phase of led driver set as MSKPHASE_9CHANNEL(defined as 0x03 in CKLED2001.h) */
+/* Use the first 9 channels of led driver */
# define PHASE_CHANNEL MSKPHASE_9CHANNEL
/* Set LED driver current */
# define CKLED2001_CURRENT_TUNE \
- { 0x30, 0x30, 0x30, 0x30, 0x30, 0x30, 0x30, 0x30, 0x30, 0x30, 0x30, 0x30 }
-
+ { 0x40, 0x40, 0x40, 0x40, 0x40, 0x40, 0x40, 0x40, 0x40, 0x40, 0x40, 0x40 }
#endif
diff --git a/keyboards/keychron/q2_pro/ansi_encoder/info.json b/keyboards/keychron/q2_pro/ansi_encoder/info.json
index 98b0c077fb..0353c9eaed 100644
--- a/keyboards/keychron/q2_pro/ansi_encoder/info.json
+++ b/keyboards/keychron/q2_pro/ansi_encoder/info.json
@@ -20,7 +20,6 @@
{"matrix":[0,11], "x":11, "y":0.25},
{"matrix":[0,12], "x":12, "y":0.25},
{"matrix":[0,13], "x":13, "y":0.25, "w":2},
-
{"matrix":[0,15], "x":15.25, "y":0},
{"matrix":[1,0], "x":0, "y":1.25, "w":1.5},
@@ -80,5 +79,79 @@
{"matrix":[4,15], "x":15.25, "y":4.5}
]
}
+ },
+ "rgb_matrix": {
+ "layout": [
+ {"matrix":[0, 0], "flags":1, "x":0, "y":3},
+ {"matrix":[0, 1], "flags":1, "x":14, "y":3},
+ {"matrix":[0, 2], "flags":4, "x":29, "y":3},
+ {"matrix":[0, 3], "flags":4, "x":43, "y":3},
+ {"matrix":[0, 4], "flags":4, "x":58, "y":3},
+ {"matrix":[0, 5], "flags":4, "x":73, "y":3},
+ {"matrix":[0, 6], "flags":4, "x":87, "y":3},
+ {"matrix":[0, 7], "flags":4, "x":102, "y":3},
+ {"matrix":[0, 8], "flags":4, "x":117, "y":3},
+ {"matrix":[0, 9], "flags":4, "x":131, "y":3},
+ {"matrix":[0, 10], "flags":4, "x":146, "y":3},
+ {"matrix":[0, 11], "flags":4, "x":161, "y":3},
+ {"matrix":[0, 12], "flags":4, "x":175, "y":3},
+ {"matrix":[0, 13], "flags":1, "x":197, "y":3},
+
+ {"matrix":[1, 0], "flags":1, "x":3, "y":17},
+ {"matrix":[1, 1], "flags":8, "x":21, "y":17},
+ {"matrix":[1, 2], "flags":8, "x":36, "y":17},
+ {"matrix":[1, 3], "flags":8, "x":51, "y":17},
+ {"matrix":[1, 4], "flags":4, "x":65, "y":17},
+ {"matrix":[1, 5], "flags":4, "x":80, "y":17},
+ {"matrix":[1, 6], "flags":4, "x":95, "y":17},
+ {"matrix":[1, 7], "flags":4, "x":109, "y":17},
+ {"matrix":[1, 8], "flags":4, "x":124, "y":17},
+ {"matrix":[1, 9], "flags":4, "x":139, "y":17},
+ {"matrix":[1, 10], "flags":4, "x":153, "y":17},
+ {"matrix":[1, 11], "flags":4, "x":168, "y":17},
+ {"matrix":[1, 12], "flags":4, "x":183, "y":17},
+ {"matrix":[1, 13], "flags":1, "x":201, "y":17},
+ {"matrix":[1, 15], "flags":1, "x":223, "y":17},
+
+ {"matrix":[2, 0], "flags":8, "x":5, "y":32},
+ {"matrix":[2, 1], "flags":4, "x":25, "y":32},
+ {"matrix":[2, 2], "flags":4, "x":40, "y":32},
+ {"matrix":[2, 3], "flags":4, "x":54, "y":32},
+ {"matrix":[2, 4], "flags":4, "x":69, "y":32},
+ {"matrix":[2, 5], "flags":4, "x":84, "y":32},
+ {"matrix":[2, 6], "flags":4, "x":98, "y":32},
+ {"matrix":[2, 7], "flags":4, "x":113, "y":32},
+ {"matrix":[2, 8], "flags":4, "x":128, "y":32},
+ {"matrix":[2, 9], "flags":4, "x":142, "y":32},
+ {"matrix":[2, 10], "flags":4, "x":157, "y":32},
+ {"matrix":[2, 11], "flags":4, "x":172, "y":32},
+ {"matrix":[2, 13], "flags":1, "x":195, "y":32},
+ {"matrix":[2, 15], "flags":1, "x":223, "y":32},
+
+ {"matrix":[3, 0], "flags":1, "x":9, "y":47},
+ {"matrix":[3, 2], "flags":4, "x":32, "y":47},
+ {"matrix":[3, 3], "flags":4, "x":47, "y":47},
+ {"matrix":[3, 4], "flags":4, "x":62, "y":47},
+ {"matrix":[3, 5], "flags":4, "x":76, "y":47},
+ {"matrix":[3, 6], "flags":4, "x":91, "y":47},
+ {"matrix":[3, 7], "flags":4, "x":106, "y":47},
+ {"matrix":[3, 8], "flags":4, "x":120, "y":47},
+ {"matrix":[3, 9], "flags":4, "x":135, "y":47},
+ {"matrix":[3, 10], "flags":4, "x":150, "y":47},
+ {"matrix":[3, 11], "flags":4, "x":164, "y":47},
+ {"matrix":[3, 13], "flags":1, "x":185, "y":47},
+ {"matrix":[3, 14], "flags":1, "x":209, "y":49},
+
+ {"matrix":[4, 0], "flags":1, "x":1, "y":62},
+ {"matrix":[4, 1], "flags":1, "x":20, "y":62},
+ {"matrix":[4, 2], "flags":1, "x":38, "y":62},
+ {"matrix":[4, 6], "flags":4, "x":93, "y":62},
+ {"matrix":[4, 10], "flags":1, "x":146, "y":62},
+ {"matrix":[4, 11], "flags":1, "x":161, "y":62},
+ {"matrix":[4, 12], "flags":1, "x":176, "y":62},
+ {"matrix":[4, 13], "flags":1, "x":194, "y":64},
+ {"matrix":[4, 14], "flags":1, "x":209, "y":64},
+ {"matrix":[4, 15], "flags":1, "x":223, "y":64}
+ ]
}
}
diff --git a/keyboards/keychron/q2_pro/ansi_encoder/keymaps/default/keymap.c b/keyboards/keychron/q2_pro/ansi_encoder/keymaps/default/keymap.c
index f8ad9414fb..30ccf36a45 100644
--- a/keyboards/keychron/q2_pro/ansi_encoder/keymaps/default/keymap.c
+++ b/keyboards/keychron/q2_pro/ansi_encoder/keymaps/default/keymap.c
@@ -16,15 +16,15 @@
#include QMK_KEYBOARD_H
-// clang-format off
-enum layers{
- MAC_BASE,
- WIN_BASE,
- MAC_FN1,
- WIN_FN1,
- FN2
+enum layers {
+ MAC_BASE,
+ WIN_BASE,
+ MAC_FN1,
+ WIN_FN1,
+ FN2,
};
+// clang-format off
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
[MAC_BASE] = LAYOUT_ansi_knob_67(
KC_ESC, 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_MUTE,
@@ -62,10 +62,8 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______),
};
-// clang-format on
-
#if defined(ENCODER_MAP_ENABLE)
-const uint16_t PROGMEM encoder_map[][1][2] = {
+const uint16_t PROGMEM encoder_map[][NUM_ENCODERS][2] = {
[MAC_BASE] = {ENCODER_CCW_CW(KC_VOLD, KC_VOLU) },
[WIN_BASE] = {ENCODER_CCW_CW(KC_VOLD, KC_VOLU) },
[MAC_FN1] = {ENCODER_CCW_CW(RGB_VAD, RGB_VAI) },
diff --git a/keyboards/keychron/q2_pro/ansi_encoder/keymaps/via/keymap.c b/keyboards/keychron/q2_pro/ansi_encoder/keymaps/via/keymap.c
index 7dbd727462..2d94a88fe5 100644
--- a/keyboards/keychron/q2_pro/ansi_encoder/keymaps/via/keymap.c
+++ b/keyboards/keychron/q2_pro/ansi_encoder/keymaps/via/keymap.c
@@ -16,15 +16,15 @@
#include QMK_KEYBOARD_H
-// clang-format off
-enum layers{
- MAC_BASE,
- WIN_BASE,
- MAC_FN1,
- WIN_FN1,
- FN2
+enum layers {
+ MAC_BASE,
+ WIN_BASE,
+ MAC_FN1,
+ WIN_FN1,
+ FN2,
};
+// clang-format off
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
[MAC_BASE] = LAYOUT_ansi_knob_67(
KC_ESC, 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_MUTE,
@@ -62,10 +62,8 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______),
};
-// clang-format on
-
#if defined(ENCODER_MAP_ENABLE)
-const uint16_t PROGMEM encoder_map[][1][2] = {
+const uint16_t PROGMEM encoder_map[][NUM_ENCODERS][2] = {
[MAC_BASE] = {ENCODER_CCW_CW(KC_VOLD, KC_VOLU) },
[WIN_BASE] = {ENCODER_CCW_CW(KC_VOLD, KC_VOLU) },
[MAC_FN1] = {ENCODER_CCW_CW(RGB_VAD, RGB_VAI) },
diff --git a/keyboards/keychron/q2_pro/ansi_encoder/keymaps/via/rules.mk b/keyboards/keychron/q2_pro/ansi_encoder/keymaps/via/rules.mk
index b8562c8f4e..f1adcab005 100644
--- a/keyboards/keychron/q2_pro/ansi_encoder/keymaps/via/rules.mk
+++ b/keyboards/keychron/q2_pro/ansi_encoder/keymaps/via/rules.mk
@@ -1,3 +1,2 @@
VIA_ENABLE = yes
ENCODER_MAP_ENABLE = yes
-OPT_DEFS += -DDYNAMIC_KEYMAP_LAYER_COUNT=5
diff --git a/keyboards/keychron/q2_pro/config.h b/keyboards/keychron/q2_pro/config.h
index d2f32e4617..601a23d454 100644
--- a/keyboards/keychron/q2_pro/config.h
+++ b/keyboards/keychron/q2_pro/config.h
@@ -18,7 +18,6 @@
/* turn off effects when suspended */
#define RGB_DISABLE_WHEN_USB_SUSPENDED
-#define LED_DISABLE_WHEN_USB_SUSPENDED
/* DIP switch */
#define DIP_SWITCH_PINS \
@@ -78,5 +77,8 @@
#define FEE_DENSITY_BYTES FEE_PAGE_SIZE
#define DYNAMIC_KEYMAP_EEPROM_MAX_ADDR 2047
+/* Old default behavior of mod-taps */
+#define HOLD_ON_OTHER_KEY_PRESS
+
/* Factory test keys */
#define FN_KEY2 MO(4)
diff --git a/keyboards/keychron/q2_pro/info.json b/keyboards/keychron/q2_pro/info.json
index cbe501f42e..e2e9fede3e 100644
--- a/keyboards/keychron/q2_pro/info.json
+++ b/keyboards/keychron/q2_pro/info.json
@@ -14,9 +14,9 @@
"extrakey": true,
"nkro": true,
"dip_switch": true,
- "raw": true,
"encoder": true,
- "rgb_matrix": true
+ "rgb_matrix": true,
+ "raw": true
},
"diode_direction": "ROW2COL",
"matrix_size": {
@@ -34,6 +34,9 @@
{"pin_a": "A10", "pin_b": "A0", "resolution": 4}
]
},
+ "dynamic_keymap": {
+ "layer_count": 5
+ },
"rgb_matrix": {
"driver": "CKLED2001",
"animations": {
diff --git a/keyboards/keychron/q2_pro/iso_encoder/config.h b/keyboards/keychron/q2_pro/iso_encoder/config.h
new file mode 100755
index 0000000000..0433be75c5
--- /dev/null
+++ b/keyboards/keychron/q2_pro/iso_encoder/config.h
@@ -0,0 +1,55 @@
+/* Copyright 2023 @ Keychron (https://www.keychron.com)
+ *
+ * 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
+
+/* Encoder Configuration */
+#define ENCODER_DEFAULT_POS 0x3
+
+#ifdef RGB_MATRIX_ENABLE
+/* RGB Matrix Driver Configuration */
+# define DRIVER_COUNT 2
+# define DRIVER_ADDR_1 0b1110111
+# define DRIVER_ADDR_2 0b1110100
+
+/* RGB Matrix Configuration */
+# define DRIVER_1_LED_TOTAL 29
+# define DRIVER_2_LED_TOTAL 38
+# define RGB_MATRIX_LED_COUNT (DRIVER_1_LED_TOTAL + DRIVER_2_LED_TOTAL)
+
+/* Set to infinit, which is use in USB mode by default */
+# define RGB_MATRIX_TIMEOUT RGB_MATRIX_TIMEOUT_INFINITE
+
+/* Allow to shutdown driver to save power */
+# define RGB_MATRIX_DRIVER_SHUTDOWN_ENABLE
+
+/* Turn off backllit if brightness value is low */
+# define RGB_MATRIX_BRIGHTNESS_TURN_OFF_VAL 48
+
+/* Indication led index */
+# define CAPS_LOCK_INDEX 28
+# define LOW_BAT_IND_INDEX 60
+
+# define RGB_MATRIX_KEYPRESSES
+# define RGB_MATRIX_FRAMEBUFFER_EFFECTS
+
+/* Use the first 9 channels of led driver */
+# define PHASE_CHANNEL MSKPHASE_9CHANNEL
+
+/* Set LED driver current */
+# define CKLED2001_CURRENT_TUNE \
+ { 0x40, 0x40, 0x40, 0x40, 0x40, 0x40, 0x40, 0x40, 0x40, 0x40, 0x40, 0x40 }
+#endif
diff --git a/keyboards/keychron/q2_pro/iso_encoder/info.json b/keyboards/keychron/q2_pro/iso_encoder/info.json
new file mode 100755
index 0000000000..6d44e9db90
--- /dev/null
+++ b/keyboards/keychron/q2_pro/iso_encoder/info.json
@@ -0,0 +1,160 @@
+{
+ "usb": {
+ "pid": "0x0621",
+ "device_version": "1.0.0"
+ },
+ "layouts": {
+ "LAYOUT_iso_68": {
+ "layout": [
+ {"matrix":[0,0], "x":0, "y":0.25},
+ {"matrix":[0,1], "x":1, "y":0.25},
+ {"matrix":[0,2], "x":2, "y":0.25},
+ {"matrix":[0,3], "x":3, "y":0.25},
+ {"matrix":[0,4], "x":4, "y":0.25},
+ {"matrix":[0,5], "x":5, "y":0.25},
+ {"matrix":[0,6], "x":6, "y":0.25},
+ {"matrix":[0,7], "x":7, "y":0.25},
+ {"matrix":[0,8], "x":8, "y":0.25},
+ {"matrix":[0,9], "x":9, "y":0.25},
+ {"matrix":[0,10], "x":10, "y":0.25},
+ {"matrix":[0,11], "x":11, "y":0.25},
+ {"matrix":[0,12], "x":12, "y":0.25},
+ {"matrix":[0,13], "x":13, "y":0.25, "w":2},
+ {"matrix":[0,15], "x":15.25, "y":0},
+
+ {"matrix":[1,0], "x":0, "y":1.25, "w":1.5},
+ {"matrix":[1,1], "x":1.5, "y":1.25},
+ {"matrix":[1,2], "x":2.5, "y":1.25},
+ {"matrix":[1,3], "x":3.5, "y":1.25},
+ {"matrix":[1,4], "x":4.5, "y":1.25},
+ {"matrix":[1,5], "x":5.5, "y":1.25},
+ {"matrix":[1,6], "x":6.5, "y":1.25},
+ {"matrix":[1,7], "x":7.5, "y":1.25},
+ {"matrix":[1,8], "x":8.5, "y":1.25},
+ {"matrix":[1,9], "x":9.5, "y":1.25},
+ {"matrix":[1,10], "x":10.5, "y":1.25},
+ {"matrix":[1,11], "x":11.5, "y":1.25},
+ {"matrix":[1,12], "x":12.5, "y":1.25},
+ {"matrix":[1,15], "x":15.25, "y":1.25},
+
+ {"matrix":[2,0], "x":0, "y":2.25, "w":1.75},
+ {"matrix":[2,1], "x":1.75, "y":2.25},
+ {"matrix":[2,2], "x":2.75, "y":2.25},
+ {"matrix":[2,3], "x":3.75, "y":2.25},
+ {"matrix":[2,4], "x":4.75, "y":2.25},
+ {"matrix":[2,5], "x":5.75, "y":2.25},
+ {"matrix":[2,6], "x":6.75, "y":2.25},
+ {"matrix":[2,7], "x":7.75, "y":2.25},
+ {"matrix":[2,8], "x":8.75, "y":2.25},
+ {"matrix":[2,9], "x":9.75, "y":2.25},
+ {"matrix":[2,10], "x":10.75, "y":2.25},
+ {"matrix":[2,11], "x":11.75, "y":2.25},
+ {"matrix":[2,13], "x":12.75, "y":2.25},
+ {"matrix":[1,13], "x":13.75, "y":1.25, "w":1.25, "h":2},
+ {"matrix":[2,15], "x":15.25, "y":2.25},
+
+ {"matrix":[3,0], "x":0, "y":3.25, "w":1.25},
+ {"matrix":[3,1], "x":1.25, "y":3.25},
+ {"matrix":[3,2], "x":2.25, "y":3.25},
+ {"matrix":[3,3], "x":3.25, "y":3.25},
+ {"matrix":[3,4], "x":4.25, "y":3.25},
+ {"matrix":[3,5], "x":5.25, "y":3.25},
+ {"matrix":[3,6], "x":6.25, "y":3.25},
+ {"matrix":[3,7], "x":7.25, "y":3.25},
+ {"matrix":[3,8], "x":8.25, "y":3.25},
+ {"matrix":[3,9], "x":9.25, "y":3.25},
+ {"matrix":[3,10], "x":10.25, "y":3.25},
+ {"matrix":[3,11], "x":11.25, "y":3.25},
+ {"matrix":[3,13], "x":12.25, "y":3.25, "w":1.75},
+ {"matrix":[3,14], "x":14.25, "y":3.5},
+
+ {"matrix":[4,0], "x":0, "y":4.25, "w":1.24},
+ {"matrix":[4,1], "x":1.24, "y":4.25, "w":1.25},
+ {"matrix":[4,2], "x":2.49, "y":4.25, "w":1.25},
+ {"matrix":[4,6], "x":3.74, "y":4.25, "w":6.25},
+ {"matrix":[4,10], "x":9.99, "y":4.25},
+ {"matrix":[4,11], "x":10.99, "y":4.25},
+ {"matrix":[4,12], "x":11.99, "y":4.25},
+ {"matrix":[4,13], "x":13.25, "y":4.5},
+ {"matrix":[4,14], "x":14.25, "y":4.5},
+ {"matrix":[4,15], "x":15.25, "y":4.5}
+ ]
+ }
+ },
+ "rgb_matrix": {
+ "layout": [
+ {"matrix":[0, 0], "flags":1, "x":0, "y":4},
+ {"matrix":[0, 1], "flags":4, "x":15, "y":4},
+ {"matrix":[0, 2], "flags":4, "x":29, "y":4},
+ {"matrix":[0, 3], "flags":4, "x":44, "y":4},
+ {"matrix":[0, 4], "flags":4, "x":59, "y":4},
+ {"matrix":[0, 5], "flags":4, "x":73, "y":4},
+ {"matrix":[0, 6], "flags":4, "x":88, "y":4},
+ {"matrix":[0, 7], "flags":4, "x":103, "y":4},
+ {"matrix":[0, 8], "flags":4, "x":117, "y":4},
+ {"matrix":[0, 9], "flags":4, "x":132, "y":4},
+ {"matrix":[0, 10], "flags":4, "x":146, "y":4},
+ {"matrix":[0, 11], "flags":4, "x":161, "y":4},
+ {"matrix":[0, 12], "flags":4, "x":176, "y":4},
+ {"matrix":[0, 13], "flags":1, "x":198, "y":4},
+
+ {"matrix":[1, 0], "flags":1, "x":4, "y":15},
+ {"matrix":[1, 1], "flags":8, "x":22, "y":15},
+ {"matrix":[1, 2], "flags":8, "x":37, "y":15},
+ {"matrix":[1, 3], "flags":8, "x":51, "y":15},
+ {"matrix":[1, 4], "flags":4, "x":66, "y":15},
+ {"matrix":[1, 5], "flags":4, "x":81, "y":15},
+ {"matrix":[1, 6], "flags":4, "x":95, "y":15},
+ {"matrix":[1, 7], "flags":4, "x":110, "y":15},
+ {"matrix":[1, 8], "flags":4, "x":125, "y":15},
+ {"matrix":[1, 9], "flags":4, "x":139, "y":15},
+ {"matrix":[1, 10], "flags":4, "x":154, "y":15},
+ {"matrix":[1, 11], "flags":4, "x":168, "y":15},
+ {"matrix":[1, 12], "flags":4, "x":183, "y":15},
+ {"matrix":[1, 15], "flags":1, "x":224, "y":15},
+
+ {"matrix":[2, 0], "flags":8, "x":5, "y":30},
+ {"matrix":[2, 1], "flags":4, "x":26, "y":30},
+ {"matrix":[2, 2], "flags":4, "x":40, "y":30},
+ {"matrix":[2, 3], "flags":4, "x":55, "y":30},
+ {"matrix":[2, 4], "flags":4, "x":70, "y":30},
+ {"matrix":[2, 5], "flags":4, "x":84, "y":30},
+ {"matrix":[2, 6], "flags":4, "x":99, "y":30},
+ {"matrix":[2, 7], "flags":4, "x":114, "y":30},
+ {"matrix":[2, 8], "flags":4, "x":128, "y":30},
+ {"matrix":[2, 9], "flags":4, "x":143, "y":30},
+ {"matrix":[2, 10], "flags":4, "x":158, "y":30},
+ {"matrix":[2, 11], "flags":4, "x":172, "y":30},
+ {"matrix":[2, 13], "flags":1, "x":187, "y":30},
+ {"matrix":[1, 13], "flags":1, "x":207, "y":25},
+ {"matrix":[2, 15], "flags":1, "x":224, "y":30},
+
+ {"matrix":[3, 0], "flags":1, "x":2, "y":45},
+ {"matrix":[3, 1], "flags":1, "x":18, "y":45},
+ {"matrix":[3, 2], "flags":4, "x":33, "y":45},
+ {"matrix":[3, 3], "flags":4, "x":48, "y":45},
+ {"matrix":[3, 4], "flags":4, "x":62, "y":45},
+ {"matrix":[3, 5], "flags":4, "x":77, "y":45},
+ {"matrix":[3, 6], "flags":4, "x":92, "y":45},
+ {"matrix":[3, 7], "flags":4, "x":106, "y":45},
+ {"matrix":[3, 8], "flags":4, "x":121, "y":45},
+ {"matrix":[3, 9], "flags":4, "x":136, "y":45},
+ {"matrix":[3, 10], "flags":4, "x":150, "y":45},
+ {"matrix":[3, 11], "flags":4, "x":165, "y":45},
+ {"matrix":[3, 13], "flags":1, "x":185, "y":45},
+ {"matrix":[3, 14], "flags":1, "x":209, "y":49},
+
+ {"matrix":[4, 0], "flags":1, "x":2, "y":60},
+ {"matrix":[4, 1], "flags":1, "x":20, "y":60},
+ {"matrix":[4, 2], "flags":1, "x":38, "y":60},
+ {"matrix":[4, 6], "flags":4, "x":94, "y":60},
+ {"matrix":[4, 10], "flags":1, "x":147, "y":60},
+ {"matrix":[4, 11], "flags":1, "x":161, "y":60},
+ {"matrix":[4, 12], "flags":1, "x":176, "y":60},
+ {"matrix":[4, 13], "flags":1, "x":195, "y":64},
+ {"matrix":[4, 14], "flags":1, "x":209, "y":64},
+ {"matrix":[4, 15], "flags":1, "x":224, "y":64}
+ ]
+ }
+}
+
diff --git a/keyboards/keychron/q2_pro/iso_encoder/iso_encoder.c b/keyboards/keychron/q2_pro/iso_encoder/iso_encoder.c
new file mode 100755
index 0000000000..8cb542b0fb
--- /dev/null
+++ b/keyboards/keychron/q2_pro/iso_encoder/iso_encoder.c
@@ -0,0 +1,99 @@
+/* Copyright 2023 @ Keychron (https://www.keychron.com)
+ *
+ * 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 "quantum.h"
+
+#ifdef RGB_MATRIX_ENABLE
+const ckled2001_led g_ckled2001_leds[RGB_MATRIX_LED_COUNT] = {
+/* Refer to CKLED2001 manual for these locations
+ * driver
+ * | R location
+ * | | G location
+ * | | | B location
+ * | | | | */
+ {0, C_16, A_16, B_16},
+ {0, C_15, A_15, B_15},
+ {0, C_14, A_14, B_14},
+ {0, C_13, A_13, B_13},
+ {0, C_12, A_12, B_12},
+ {0, C_11, A_11, B_11},
+ {0, C_10, A_10, B_10},
+ {0, C_9, A_9, B_9},
+ {0, C_8, A_8, B_8},
+ {0, C_7, A_7, B_7},
+ {0, C_6, A_6, B_6},
+ {0, C_5, A_5, B_5},
+ {0, C_4, A_4, B_4},
+ {0, C_3, A_3, B_3},
+
+ {0, F_16, D_16, E_16},
+ {0, F_15, D_15, E_15},
+ {0, F_14, D_14, E_14},
+ {0, F_13, D_13, E_13},
+ {0, F_12, D_12, E_12},
+ {0, F_11, D_11, E_11},
+ {0, F_10, D_10, E_10},
+ {0, F_9, D_9, E_9},
+ {0, F_8, D_8, E_8},
+ {0, F_7, D_7, E_7},
+ {0, F_6, D_6, E_6},
+ {0, F_5, D_5, E_5},
+ {0, F_4, D_4, E_4},
+ {0, F_1, D_1, E_1},
+
+ {1, C_16, A_16, B_16},
+ {1, C_15, A_15, B_15},
+ {1, C_14, A_14, B_14},
+ {1, C_13, A_13, B_13},
+ {1, C_12, A_12, B_12},
+ {1, C_11, A_11, B_11},
+ {1, C_10, A_10, B_10},
+ {1, C_9, A_9, B_9},
+ {1, C_8, A_8, B_8},
+ {1, C_7, A_7, B_7},
+ {1, C_6, A_6, B_6},
+ {1, C_5, A_5, B_5},
+ {1, C_3, A_3, B_3},
+ {0, F_3, D_3, E_3},
+ {1, C_1, A_1, B_1},
+
+ {1, I_16, G_16, H_16},
+ {1, I_15, G_15, H_15},
+ {1, I_14, G_14, H_14},
+ {1, I_13, G_13, H_13},
+ {1, I_12, G_12, H_12},
+ {1, I_11, G_11, H_11},
+ {1, I_10, G_10, H_10},
+ {1, I_9, G_9, H_9},
+ {1, I_8, G_8, H_8},
+ {1, I_7, G_7, H_7},
+ {1, I_6, G_6, H_6},
+ {1, I_5, G_5, H_5},
+ {1, I_3, G_3, H_3},
+ {1, I_2, G_2, H_2},
+
+ {1, F_16, D_16, E_16},
+ {1, F_15, D_15, E_15},
+ {1, F_14, D_14, E_14},
+ {1, F_10, D_10, E_10},
+ {1, F_6, D_6, E_6},
+ {1, F_5, D_5, E_5},
+ {1, F_4, D_4, E_4},
+ {1, F_3, D_3, E_3},
+ {1, F_2, D_2, E_2},
+ {1, F_1, D_1, E_1}
+};
+#endif
diff --git a/keyboards/keychron/q2_pro/iso_encoder/keymaps/default/keymap.c b/keyboards/keychron/q2_pro/iso_encoder/keymaps/default/keymap.c
new file mode 100755
index 0000000000..d920ae8199
--- /dev/null
+++ b/keyboards/keychron/q2_pro/iso_encoder/keymaps/default/keymap.c
@@ -0,0 +1,73 @@
+/* Copyright 2023 @ Keychron (https://www.keychron.com)
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include QMK_KEYBOARD_H
+
+enum layers{
+ MAC_BASE,
+ WIN_BASE,
+ MAC_FN1,
+ WIN_FN1,
+ FN2,
+};
+
+// clang-format off
+const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
+ [MAC_BASE] = LAYOUT_iso_68(
+ KC_ESC, 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_MUTE,
+ 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_DEL,
+ 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_NUHS, KC_ENT, KC_HOME,
+ 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_RSFT, KC_UP,
+ KC_LCTL, KC_LOPTN, KC_LCMMD, KC_SPC, KC_RCMMD,MO(MAC_FN1),MO(FN2), KC_LEFT, KC_DOWN, KC_RGHT),
+
+ [WIN_BASE] = LAYOUT_iso_68(
+ KC_ESC, 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_MUTE,
+ 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_DEL,
+ 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_NUHS, KC_ENT, KC_HOME,
+ 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_RSFT, KC_UP,
+ KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_RALT, MO(WIN_FN1),MO(FN2), KC_LEFT, KC_DOWN, KC_RGHT),
+
+ [MAC_FN1] = LAYOUT_iso_68(
+ KC_GRV, KC_BRID, KC_BRIU, KC_MCTL, KC_LPAD, RGB_VAD, RGB_VAI, KC_MPRV, KC_MPLY, KC_MNXT, KC_MUTE, KC_VOLD, KC_VOLU, _______, RGB_TOG,
+ _______, BT_HST1, BT_HST2, BT_HST3, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ RGB_TOG, RGB_MOD, RGB_VAI, RGB_HUI, RGB_SAI, RGB_SPI, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, RGB_RMOD, RGB_VAD, RGB_HUD, RGB_SAD, RGB_SPD, NK_TOGG, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______),
+
+ [WIN_FN1] = LAYOUT_iso_68(
+ KC_GRV, KC_BRID, KC_BRIU, KC_TASK, KC_FILE, RGB_VAD, RGB_VAI, KC_MPRV, KC_MPLY, KC_MNXT, KC_MUTE, KC_VOLD, KC_VOLU, _______, RGB_TOG,
+ _______, BT_HST1, BT_HST2, BT_HST3, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ RGB_TOG, RGB_MOD, RGB_VAI, RGB_HUI, RGB_SAI, RGB_SPI, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, RGB_RMOD, RGB_VAD, RGB_HUD, RGB_SAD, RGB_SPD, NK_TOGG, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______),
+
+ [FN2] = LAYOUT_iso_68(
+ KC_TILD, KC_F1, KC_F2, KC_F3, KC_F4,