summaryrefslogtreecommitdiff
path: root/keyboards/woodkeys/bigseries/1key/keymaps/8ball/keymap.c
blob: b72b1a0d9aae4c03495cb1002965e93cd398b4b6 (plain)
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/*
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://www.gnu.org/licenses/>.
*/

#include QMK_KEYBOARD_H

static const char * const ANSWERS[] = {
// "Yes" 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",
// Uncertain answers, index 10
"Reply hazy try again\n",
"Ask again later\n",
"Better not tell you now\n",
"Cannot predict now\n",
"Concentrate and ask again\n",
// "No" answers, index 15
"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
// Timeout of answer color in ms
#define ANSWER_TIMEOUT 3000

const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {

LAYOUT(
    KC_A),
};


void reset_rgb(void);

bool initialized = 0;
uint32_t lastTime = 0;

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(RGB_GREEN);
      } else if (num < NO_BREAK) {
        rgblight_setrgb(RGB_YELLOW);
      } else {
        rgblight_setrgb(RGB_RED);
      }
      send_string(ANSWERS[num]);
      lastTime = timer_read32();
      return false;
    }
  }
  return true;
}

void reset_rgb(void) {
  // This gets called on init and after the timeout for the answer color
  // If you want to change the default color/mode, do it here
  rgblight_sethsv(HSV_BLUE);
  rgblight_mode(7);
}