From ac33dc12dacee480eba67462d985cb4dc7589c7f Mon Sep 17 00:00:00 2001 From: Max Bridgland <34947910+M4cs@users.noreply.github.com> Date: Tue, 16 Feb 2021 13:10:07 -0500 Subject: [Keyboard] Add VIA keymap to duckyPad, update M4cs keymap for duckyPad (#11703) Co-authored-by: M4cs --- keyboards/dekunukem/duckypad/keymaps/m4cs/keymap.c | 186 ++++++++++++++++----- .../dekunukem/duckypad/keymaps/m4cs/readme.md | 4 +- .../dekunukem/duckypad/keymaps/m4cs/sysinfo.py | 78 +++++++++ 3 files changed, 223 insertions(+), 45 deletions(-) create mode 100644 keyboards/dekunukem/duckypad/keymaps/m4cs/sysinfo.py (limited to 'keyboards/dekunukem/duckypad/keymaps/m4cs') 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 . #include QMK_KEYBOARD_H #include "stdio.h" -#include +#include "raw_hid.h" #include +#include +#include #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; -} +}; diff --git a/keyboards/dekunukem/duckypad/keymaps/m4cs/readme.md b/keyboards/dekunukem/duckypad/keymaps/m4cs/readme.md index 42fae00440..50c06cf42f 100644 --- a/keyboards/dekunukem/duckypad/keymaps/m4cs/readme.md +++ b/keyboards/dekunukem/duckypad/keymaps/m4cs/readme.md @@ -16,10 +16,12 @@ To change the menu, edit the `MT_X_XX` values in `config.h`. The sytax is as fol The macros currently just map to Ctrl + Alt + (Different Keys) right now. I have them launching certain shortcuts. I recommend you change these and add your shortcuts to match your shortcut manager. +To get sysinfo working, run `pip3 install psutil GPUtil` and then `python sysinfo.py`. Now when pressing the bottom right key, you will get an info screen with your updated system info. + ### Need Help? Contact me on discord: macs#0420 or join the duckyPad Discord and find me in there :) -https://discord.gg/ADtrCjf \ No newline at end of file +https://discord.gg/ADtrCjf diff --git a/keyboards/dekunukem/duckypad/keymaps/m4cs/sysinfo.py b/keyboards/dekunukem/duckypad/keymaps/m4cs/sysinfo.py new file mode 100644 index 0000000000..04cf343ea6 --- /dev/null +++ b/keyboards/dekunukem/duckypad/keymaps/m4cs/sysinfo.py @@ -0,0 +1,78 @@ + +### +# M4cs Keymap for dekuNukem/duckyPad QMK firmware + +# Copyright (C) 2020 Max Bridgland + +# 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 3 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 . +### + + +import hid +import time +import string +import psutil +import GPUtil +import datetime + +vendor_id = 0x444E +product_id = 0x4450 + +usage_page = 0xFF60 +usage = 0x61 + +device_interfaces = hid.enumerate(vendor_id, product_id) +raw_hid_interfaces = [i for i in device_interfaces if i['usage_page'] == usage_page and i['usage'] == usage] + +if len(raw_hid_interfaces) == 0: + print('Couldnt find any interfaces') + exit() + +interface = hid.device() +interface.open_path(raw_hid_interfaces[0]['path']) +print("Manufacturer: %s" % interface.get_manufacturer_string()) +print("Product: %s" % interface.get_product_string()) +time.sleep(0.05) +while True: + time.sleep(0.75) + cpufreq = psutil.cpu_freq() + currFreq = int(cpufreq.current) + svmem = psutil.virtual_memory() + memPerc = int(svmem.percent * 10) + gpus = GPUtil.getGPUs() + gpu = gpus[0] + load = int(gpu.load*100) + temp = int(gpu.temperature) + data = [0] + for x in str(currFreq): + data.append(int(x)) + data.append(13) + for x in str(memPerc): + data.append(int(x)) + data.append(13) + for x in str(load): + data.append(int(x)) + data.append(13) + for x in str(temp): + data.append(int(x)) + data.append(13) + now_hour = datetime.datetime.now().strftime("%I") + now_min = datetime.datetime.now().strftime("%M") + data.append(int(now_hour[0])) + data.append(int(now_hour[1])) + data.append(13) + data.append(int(now_min[0])) + data.append(int(now_min[1])) + data.append(13) + interface.write(data) -- cgit v1.2.3