|
@@ -0,0 +1,144 @@
|
|
|
+
|
|
|
+Copyright 2018 Cole Markham
|
|
|
+
|
|
|
+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:
|
|
|
+*/
|
|
|
+
|
|
|
+#include "../../bigseries.h"
|
|
|
+
|
|
|
+static const char * const ANSWERS[] = {
|
|
|
+
|
|
|
+"It is certain\n",
|
|
|
+"It is decidedly so\n",
|
|
|
+"Without a doubt\n",
|
|
|
+"Yes definitely\n",
|
|
|
+"You may rely on it\n",
|
|
|
+"As I see it, yes\n",
|
|
|
+"Most likely\n",
|
|
|
+"Outlook good\n",
|
|
|
+"Yes\n",
|
|
|
+"Signs point to yes\n",
|
|
|
+
|
|
|
+"Reply hazy try again\n",
|
|
|
+"Ask again later\n",
|
|
|
+"Better not tell you now\n",
|
|
|
+"Cannot predict now\n",
|
|
|
+"Concentrate and ask again\n",
|
|
|
+
|
|
|
+"Don't count on it\n",
|
|
|
+"My reply is no\n",
|
|
|
+"My sources say no\n",
|
|
|
+"Outlook not so good\n",
|
|
|
+"Very doubtful\n"
|
|
|
+};
|
|
|
+
|
|
|
+#define UNCERTAIN_BREAK 10
|
|
|
+#define NO_BREAK 15
|
|
|
+#define NUM_ANSWERS 20
|
|
|
+
|
|
|
+#define ANSWER_TIMEOUT 3000
|
|
|
+
|
|
|
+const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
|
|
+
|
|
|
+KEYMAP(
|
|
|
+ KC_A),
|
|
|
+};
|
|
|
+
|
|
|
+
|
|
|
+void reset_rgb(void);
|
|
|
+
|
|
|
+bool initialized = 0;
|
|
|
+uint32_t lastTime = 0;
|
|
|
+
|
|
|
+const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) {
|
|
|
+ return MACRO_NONE ;
|
|
|
+}
|
|
|
+
|
|
|
+void matrix_init_user(void) {
|
|
|
+ if (!initialized){
|
|
|
+ dprintf("Initializing in matrix_scan_user");
|
|
|
+ rgblight_enable();
|
|
|
+ reset_rgb();
|
|
|
+ initialized = 1;
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+void matrix_scan_user(void) {
|
|
|
+ if (lastTime > 0 && timer_elapsed32(lastTime) > ANSWER_TIMEOUT) {
|
|
|
+ lastTime = 0;
|
|
|
+ reset_rgb();
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
|
|
+ switch (keycode) {
|
|
|
+ case KC_A:
|
|
|
+ if (record->event.pressed) {
|
|
|
+ uint8_t num = rand() / (RAND_MAX / NUM_ANSWERS + 1);
|
|
|
+ rgblight_mode(1);
|
|
|
+ if (num < UNCERTAIN_BREAK) {
|
|
|
+ rgblight_setrgb_green();
|
|
|
+ } else if (num < NO_BREAK) {
|
|
|
+ rgblight_setrgb_yellow();
|
|
|
+ } else {
|
|
|
+ rgblight_setrgb_red();
|
|
|
+ }
|
|
|
+ send_string(ANSWERS[num]);
|
|
|
+ lastTime = timer_read32();
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return true;
|
|
|
+}
|
|
|
+
|
|
|
+void led_set_user(uint8_t usb_led) {
|
|
|
+
|
|
|
+ if (usb_led & (1 << USB_LED_NUM_LOCK)) {
|
|
|
+
|
|
|
+ } else {
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ if (usb_led & (1 << USB_LED_CAPS_LOCK)) {
|
|
|
+
|
|
|
+ } else {
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ if (usb_led & (1 << USB_LED_SCROLL_LOCK)) {
|
|
|
+
|
|
|
+ } else {
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ if (usb_led & (1 << USB_LED_COMPOSE)) {
|
|
|
+
|
|
|
+ } else {
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ if (usb_led & (1 << USB_LED_KANA)) {
|
|
|
+
|
|
|
+ } else {
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+}
|
|
|
+
|
|
|
+void reset_rgb(void) {
|
|
|
+
|
|
|
+
|
|
|
+ rgblight_sethsv_blue();
|
|
|
+ rgblight_mode(7);
|
|
|
+}
|