summaryrefslogtreecommitdiff
path: root/keyboards/dekunukem/duckypad/keymaps/m4cs/keymap.c
diff options
context:
space:
mode:
Diffstat (limited to 'keyboards/dekunukem/duckypad/keymaps/m4cs/keymap.c')
-rw-r--r--keyboards/dekunukem/duckypad/keymaps/m4cs/keymap.c186
1 files changed, 142 insertions, 44 deletions
diff --git a/keyboards/dekunukem/duckypad/keymaps/m4cs/keymap.c b/keyboards/dekunukem/duckypad/keymaps/m4cs/keymap.c
index 2ce15d7e77..80b188a480 100644
--- a/keyboards/dekunukem/duckypad/keymaps/m4cs/keymap.c
+++ b/keyboards/dekunukem/duckypad/keymaps/m4cs/keymap.c
@@ -21,25 +21,22 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
#include QMK_KEYBOARD_H
#include "stdio.h"
-#include <unistd.h>
+#include "raw_hid.h"
#include <string.h>
+#include <stdlib.h>
+#include <math.h>
#define LOGO_SIZE 384
bool rgbToggled = false;
bool altToggled = false;
+bool sysToggled = false;
enum layer_codes {
RGB_LAYER = SAFE_RANGE,
- ALT_LAYER
-};
-
-enum my_keycodes {
- Z0 = SAFE_RANGE, Z1, Z2,
- Z3, Z4, Z5,
- Z6, Z7, Z8,
- Z9, Z10, Z11,
- Z12, Z13, Z14
+ ALT_LAYER,
+ SYS_LAYER,
+ CLOCK_TOGGLE
};
#define MAC_1 LCTL(LALT(KC_MINS))
@@ -65,6 +62,14 @@ enum my_keycodes {
#define _DEFAULT 0
#define _RGB 1
#define _ALT 2
+#define _SYS 3
+
+float cpuFreq = 0;
+int memPerc = 0;
+int gpuLoad = 0;
+int temp = 0;
+int hour = 0;
+int minute = 0;
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
@@ -78,7 +83,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|=========================================|
| Macro 4 | Macro 5 | Macro 6 |
|=========================================| ,---------------------.
- | Macro 7 | Macro 8 | Macro 9 | | RGB Menu | Alt Menu |
+ | Macro 7 | Macro 8 | Sys. Info | | RGB Menu | Alt Menu |
`=========================================' `--------------------'
*/
[_DEFAULT] = LAYOUT(
@@ -86,7 +91,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
KC_AUDIO_MUTE, KC_AUDIO_VOL_DOWN, KC_AUDIO_VOL_UP,
MAC_1, MAC_2, MAC_3,
MAC_4, MAC_5, MAC_6,
- MAC_7, MAC_8, MAC_9,
+ CLOCK_TOGGLE, MAC_8, SYS_LAYER,
RGB_LAYER, ALT_LAYER
),
/*
@@ -120,7 +125,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|=========================================|
| Macro 13 | Macro 14 | Macro 15 |
|=========================================| ,----------------------.
- | Macro 16 | Macro 17 | Macro 18 | | Norm Menu | Alt Menu |
+ | Macro 16 | Macro 17 | Sys. Info | | Norm Menu | Alt Menu |
`=========================================' `---------------------'
*/
[_ALT] = LAYOUT(
@@ -128,24 +133,32 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
KC_UNDO, KC_CUT, KC_COPY,
KC_PASTE, KC_FIND, KC_PSCR,
MAC_13, MAC_14, MAC_15,
- MAC_16, MAC_17, MAC_18,
+ CLOCK_TOGGLE, MAC_17, SYS_LAYER,
+ RGB_LAYER, ALT_LAYER
+ ),
+ [_SYS] = LAYOUT(
+ KC_NO, KC_NO, KC_NO,
+ KC_NO, KC_NO, KC_NO,
+ KC_NO, KC_NO, KC_NO,
+ KC_NO, KC_NO, KC_NO,
+ CLOCK_TOGGLE, KC_NO, SYS_LAYER,
RGB_LAYER, ALT_LAYER
)
};
static void render_logo(void) {
- static const char PROGMEM ducky_logo[LOGO_SIZE] = {
- 0, 0, 0, 0,128,128,128,128,128, 0, 0,252,252,252, 0, 0, 0,128,128,128, 0, 0, 0, 0, 0,128,128,128, 0, 0, 0, 0, 0,128,128,128,128,128, 0, 0, 0, 0, 0,252,252,252, 0, 0, 0, 0, 0,128,128,128,128,128,128, 0, 0, 0, 0, 0, 0,128,128,128,128, 0,248,248,248, 56, 56, 56, 56, 56, 56,120,240,224,192, 0, 0,128,128,128,128,128,128, 0, 0, 0, 0, 0, 0, 0, 0,128,128,128,128,128, 0, 0,252,252,252, 0, 0, 0, 0, 0,232, 24, 24,232, 0, 24, 48, 48, 24, 0,232, 24, 24,232, 0, 0,
- 0,248,254,255,143, 7, 3, 3, 3, 7,142,255,255,255, 0, 0, 0,255,255,255, 0, 0, 0, 0, 0,255,255,255, 0,248,254,255,143, 7, 3, 3, 3, 3,143, 7, 2, 0, 0,255,255,255,240,120,252,254,231,131, 1, 0, 1, 7, 63,254,240,192, 0,224,252,127, 31, 3, 0, 0,255,255,255,112,112,112,112,112,112, 56, 63, 31, 15,193,231,243,115, 51, 51, 51, 55,255,255,252, 0, 0,248,254,255,143, 7, 3, 3, 3, 7,142,255,255,255, 0, 0, 0, 0, 0, 21,127,127,252,252,252,253,253,252,252,252,255,255,255, 0, 0,
- 0, 0, 3, 7, 15, 15, 14, 14, 14, 7, 3, 15, 15, 15, 0, 0, 0, 3, 7, 15, 15, 14, 14, 6, 3, 15, 15, 15, 0, 0, 3, 7, 7, 15, 14, 14, 14, 14, 7, 7, 2, 0, 0, 15, 15, 15, 0, 0, 0, 1, 3, 15, 15, 12,136,224,224,224,247,127,127, 31, 3, 0, 0, 0, 0, 0, 15, 15, 15, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 7, 15, 14, 14, 14, 6, 3, 15, 15, 15, 0, 0, 0, 3, 7, 15, 15, 14, 14, 14, 7, 3, 15, 15, 15, 0, 0, 0, 0, 0, 0, 0, 0, 0, 8, 7, 11, 3, 11, 7, 11, 7, 7, 31, 0, 0
- };
- oled_write_raw_P(ducky_logo, LOGO_SIZE);
+ static const char PROGMEM raw_logo[] = {
+ 0, 0, 0, 0,128,128,128,128,128, 0, 0,252,252,252, 0, 0, 0,128,128,128, 0, 0, 0, 0, 0,128,128,128, 0, 0, 0, 0, 0,128,128,128,128,128, 0, 0, 0, 0, 0,252,252,252, 0, 0, 0, 0, 0,128,128,128,128,128,128, 0, 0, 0, 0, 0, 0,128,128,128,128, 0,248,248,248, 56, 56, 56, 56, 56, 56,120,240,224,192, 0, 0,128,128,128,128,128,128, 0, 0, 0, 0, 0, 0, 0, 0,128,128,128,128,128, 0, 0,252,252,252, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0,248,254,255,143, 7, 3, 3, 3, 7,142,255,255,255, 0, 0, 0,255,255,255, 0, 0, 0, 0, 0,255,255,255, 0,248,254,255,143, 7, 3, 3, 3, 3,143, 7, 2, 0, 0,255,255,255,240,120,252,254,231,131, 1, 0, 1, 7, 63,254,240,192, 0,224,252,127, 31, 3, 0, 0,255,255,255,112,112,112,112,112,112, 56, 63, 31, 15,193,231,243,115, 51, 51, 51, 55,255,255,252, 0, 0,248,254,255,143, 7, 3, 3, 3, 7,142,255,255,255, 0, 0, 0, 0,192,240,240, 96, 48, 48, 0, 12, 12,134,198,230,126, 60, 0, 0, 0,
+ 0, 0, 3, 7, 15, 15, 14, 14, 14, 7, 3, 15, 15, 15, 0, 0, 0, 3, 7, 15, 15, 14, 14, 6, 3, 15, 15, 15, 0, 0, 3, 7, 7, 15, 14, 14, 14, 14, 7, 7, 2, 0, 0, 15, 15, 15, 0, 0, 0, 1, 3, 15, 15, 12,136,224,224,224,247,127,127, 31, 3, 0, 0, 0, 0, 0, 15, 15, 15, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 7, 15, 14, 14, 14, 6, 3, 15, 15, 15, 0, 0, 0, 3, 7, 15, 15, 14, 14, 14, 7, 3, 15, 15, 15, 0, 0, 0, 12, 15, 7, 0, 0, 0, 12, 14, 15, 15, 13, 13, 12, 12, 0, 0, 0, 0,
+ };
+ oled_write_raw_P(raw_logo, sizeof(raw_logo));
}
char* make_menu_text(void){
- char *s = malloc((30 * 3) * sizeof(*s));
+ char *s = malloc((30 * 4) * sizeof(*s));
int width = 3;
- sprintf(s, "%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s",
+ snprintf(s, 120, "%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s",
width, MT_0_0, width, MT_0_1, width, MT_0_2,
width, MT_0_3, width, MT_0_4, width, MT_0_5,
width, MT_0_6, width, MT_0_7, width, MT_0_8,
@@ -156,10 +169,10 @@ char* make_menu_text(void){
};
char* make_rgb_text(void){
- char *s = malloc((30 * 3) * sizeof(*s));
+ char *s = malloc((30 * 4) * sizeof(*s));
int width = 3;
- sprintf(
- s, "%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s",
+ snprintf(
+ s, 120, "%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s",
width, MT_1_0, width, MT_1_1, width, MT_1_2,
width, MT_1_3, width, MT_1_4, width, MT_1_5,
width, MT_1_6, width, MT_1_7, width, MT_1_8,
@@ -170,10 +183,10 @@ char* make_rgb_text(void){
};
char* make_alt_text(void){
- char *s = malloc((30 * 3) * sizeof(*s));
+ char *s = malloc((30 * 4) * sizeof(*s));
int width = 3;
- sprintf(
- s, "%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s",
+ snprintf(
+ s, 120, "%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s\n%-*s %-*s %-*s",
width, MT_2_0, width, MT_2_1, width, MT_2_2,
width, MT_2_3, width, MT_2_4, width, MT_2_5,
width, MT_2_6, width, MT_2_7, width, MT_2_8,
@@ -183,23 +196,87 @@ char* make_alt_text(void){
return s;
};
+char* make_sys_info_text(void) {
+ char *s = malloc((30 * 5) * sizeof(*s));
+ snprintf(s, 150, " cpu: %.1fGHz\n mem: %d%%\n gpu: %d%%\n temp: %dC\n time: %d:%d", cpuFreq, memPerc, gpuLoad, temp, hour, minute);
+ return s;
+};
+
+
void oled_task_user(void) {
- render_logo();
- oled_set_cursor(0,3);
- if (rgbToggled) {
- char *s = make_rgb_text();
- oled_write_ln_P(s, false);
- free(s);
- } else if (altToggled) {
- char *s = make_alt_text();
- oled_write_ln_P(s, false);
- free(s);
- } else {
- char *s = make_menu_text();
- oled_write_ln_P(s, false);
- free(s);
+ if (!sysToggled) {
+ render_logo();
+ oled_set_cursor(0,3);
+ if (rgbToggled) {
+ char *s = make_rgb_text();
+ oled_write_ln(s, false);
+ free(s);
+ } else if (altToggled) {
+ char *s = make_alt_text();
+ oled_write_ln(s, false);
+ free(s);
+ } else {
+ char *s = make_menu_text();
+ oled_write_ln(s, false);
+ free(s);
+ }
}
-}
+};
+
+int concat(int a, int b) {
+ char s1[20];
+ char s2[20];
+ sprintf(s1, "%d", a);
+ sprintf(s2, "%d", b);
+ strcat(s1, s2);
+ int c = atoi(s1);
+
+ return c;
+};
+
+void raw_hid_receive(uint8_t *data, uint8_t length) {
+ if (sysToggled) {
+ oled_clear();
+ render_logo();
+ int i;
+ int stepper = 0;
+ int toWrite;
+ for (i=0; i < length; i++) {
+ if (data[i] != 13) {
+ toWrite = concat(toWrite, data[i]);
+ } else {
+ switch (stepper) {
+ case 0:
+ cpuFreq = floor(100*toWrite)/10000;
+ break;
+ case 1:
+ memPerc = toWrite / 10;
+ break;
+ case 2:
+ gpuLoad = toWrite;
+ break;
+ case 3:
+ temp = toWrite;
+ break;
+ case 4:
+ hour = toWrite;
+ break;
+ case 5:
+ minute = toWrite;
+ break;
+ default:
+ break;
+ }
+ toWrite = 0;
+ stepper++;
+ }
+ }
+ oled_set_cursor(0,3);
+ char *s = make_sys_info_text();
+ oled_write_ln(s, false);
+ free(s);
+ }
+};
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
switch (keycode) {
@@ -208,10 +285,13 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) {
if (rgbToggled) {
rgbToggled = false;
altToggled = false;
+ sysToggled = false;
+ oled_clear();
layer_clear();
} else {
rgbToggled = true;
altToggled = false;
+ sysToggled = false;
layer_on(_RGB);
}
}
@@ -221,16 +301,34 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) {
if (altToggled) {
rgbToggled = false;
altToggled = false;
+ sysToggled = false;
+ oled_clear();
layer_clear();
} else {
rgbToggled = false;
+ sysToggled = false;
altToggled = true;
layer_on(_ALT);
}
}
return false;
+ case SYS_LAYER:
+ if (record->event.pressed) {
+ if (sysToggled) {
+ rgbToggled = false;
+ altToggled = false;
+ sysToggled = false;
+ oled_clear();
+ layer_clear();
+ } else {
+ rgbToggled = false;
+ sysToggled = true;
+ altToggled = false;
+ layer_on(_SYS);
+ }
+ }
default:
return true;
}
return false;
-}
+};