Meira updates for bluetooth and audio (#2731)
* Add audio output * Update Miera to fix bluetooth issues, bootloader definition. * Added keymap with audio example * Cleanup Meira audio code
This commit is contained in:
		
							parent
							
								
									3d3c093173
								
							
						
					
					
						commit
						b4bdebab9a
					
				
					 13 changed files with 347 additions and 44 deletions
				
			
		| 
						 | 
					@ -35,11 +35,15 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
/* COL2ROW, ROW2COL, or CUSTOM_MATRIX */
 | 
					/* COL2ROW, ROW2COL, or CUSTOM_MATRIX */
 | 
				
			||||||
#define DIODE_DIRECTION CUSTOM_MATRIX
 | 
					#define DIODE_DIRECTION CUSTOM_MATRIX
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef BACKLIGHT_ENABLE
 | 
				
			||||||
#define BACKLIGHT_LEVELS 10
 | 
					#define BACKLIGHT_LEVELS 10
 | 
				
			||||||
#define BACKLIGHT_PWM_MAP {2, 4, 8, 16, 40, 55, 70, 128, 200, 255}
 | 
					#define BACKLIGHT_PWM_MAP {2, 4, 8, 16, 40, 55, 70, 128, 200, 255}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef RGBLIGHT_ENABLE
 | 
				
			||||||
#define RGB_DI_PIN D3
 | 
					#define RGB_DI_PIN D3
 | 
				
			||||||
#define RGBLIGHT_TIMER
 | 
					#define RGBLIGHT_TIMER
 | 
				
			||||||
#define RGBLED_NUM 15    // Number of LEDs
 | 
					#define RGBLED_NUM 15    // Number of LEDs
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -36,6 +36,10 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
#define LED_EN_PIN D2
 | 
					#define LED_EN_PIN D2
 | 
				
			||||||
#define UNUSED_PINS
 | 
					#define UNUSED_PINS
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define QMK_SPEAKER B5
 | 
				
			||||||
 | 
					#define B5_AUDIO
 | 
				
			||||||
 | 
					#define AUDIO_VOICES
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define CATERINA_BOOTLOADER
 | 
					#define CATERINA_BOOTLOADER
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
					 
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,3 +1,3 @@
 | 
				
			||||||
BLUETOOTH_ENABLE = yes
 | 
					BLUETOOTH_ENABLE = yes
 | 
				
			||||||
F_CPU = 8000000
 | 
					F_CPU = 8000000
 | 
				
			||||||
 | 
					BLUETOOTH = AdafruitBLE
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										31
									
								
								keyboards/meira/keymaps/cole/config.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								keyboards/meira/keymaps/cole/config.h
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,31 @@
 | 
				
			||||||
 | 
					/* Copyright 2017 Cole Markham, WoodKeys.click
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * 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/>.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef CONFIG_USER_H
 | 
				
			||||||
 | 
					#define CONFIG_USER_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "../../config.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// place overrides here
 | 
				
			||||||
 | 
					#define MUSIC_MASK (keycode != KC_NO)
 | 
				
			||||||
 | 
					#ifdef AUDIO_ENABLE
 | 
				
			||||||
 | 
					   #define STARTUP_SONG SONG(IMPERIAL_MARCH)
 | 
				
			||||||
 | 
					   // Disable music mode to keep the firmware size down
 | 
				
			||||||
 | 
					   #define NO_MUSIC_MODE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
							
								
								
									
										253
									
								
								keyboards/meira/keymaps/cole/keymap.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										253
									
								
								keyboards/meira/keymaps/cole/keymap.c
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,253 @@
 | 
				
			||||||
 | 
					/* Copyright 2017 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 "meira.h"
 | 
				
			||||||
 | 
					#include "lighting.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef RGBLIGHT_ENABLE
 | 
				
			||||||
 | 
					//Following line allows macro to read current RGB settings
 | 
				
			||||||
 | 
					extern rgblight_config_t rgblight_config;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define _QWERTY 0
 | 
				
			||||||
 | 
					#define _COLEMAK 1
 | 
				
			||||||
 | 
					#define _DVORAK 2
 | 
				
			||||||
 | 
					#define _LOWER 3
 | 
				
			||||||
 | 
					#define _RAISE 4
 | 
				
			||||||
 | 
					#define _ADJUST 16
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef BLUETOOTH_ENABLE
 | 
				
			||||||
 | 
					#define OUT_BT KC_TRNS
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					enum custom_keycodes {
 | 
				
			||||||
 | 
					  QWERTY = SAFE_RANGE,
 | 
				
			||||||
 | 
					  LOWER,
 | 
				
			||||||
 | 
					  RAISE,
 | 
				
			||||||
 | 
					  ADJUST,
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// define variables for reactive RGB
 | 
				
			||||||
 | 
					bool TOG_STATUS = false;
 | 
				
			||||||
 | 
					int RGB_current_mode;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
 | 
				
			||||||
 | 
					        /* Qwerty
 | 
				
			||||||
 | 
					         * ,-----------------------------------------------------------------------------------.
 | 
				
			||||||
 | 
					         * | Esc  |   Q  |   W  |   E  |   R  |   T  |   Y  |   U  |   I  |   O  |   P  | Bksp |
 | 
				
			||||||
 | 
					         * |------+------+------+------+------+-------------+------+------+------+------+------|
 | 
				
			||||||
 | 
					         * | Tab  |   A  |   S  |   D  |   F  |   G  |   H  |   J  |   K  |   L  |   ;  |  '   |
 | 
				
			||||||
 | 
					         * |------+------+------+------+------+------|------+------+------+------+------+------|
 | 
				
			||||||
 | 
					         * | Shift|   Z  |   X  |   C  |   V  |   B  |   N  |   M  |   ,  |   .  |   /  |Enter |
 | 
				
			||||||
 | 
					         * |------+------+------+------+------+------+------+------+------+------+------+------|
 | 
				
			||||||
 | 
					         * |Adjust| Ctrl | Ctrl  | Alt  |Lower | Cmd  |Space |Raise | Left | Down |  Up  |Right |
 | 
				
			||||||
 | 
					         * `-----------------------------------------------------------------------------------'
 | 
				
			||||||
 | 
					         */
 | 
				
			||||||
 | 
					        [_QWERTY] = KEYMAP( \
 | 
				
			||||||
 | 
					                KC_ESC,  KC_Q,    KC_W,    KC_E,    KC_R,    KC_T,    KC_Y,    KC_U,    KC_I,    KC_O,    KC_P,    KC_BSPC, \
 | 
				
			||||||
 | 
					                KC_TAB,  KC_A,    KC_S,    KC_D,    KC_F,    KC_G,    KC_H,    KC_J,    KC_K,    KC_L,    KC_SCLN, KC_QUOT, \
 | 
				
			||||||
 | 
					                KC_LSFT, KC_Z,    KC_X,    KC_C,    KC_V,    KC_B,    KC_N,    KC_M,    KC_COMM, KC_DOT,  KC_SLSH,  KC_ENT, \
 | 
				
			||||||
 | 
					                ADJUST,  KC_LCTL, KC_LALT, KC_LALT, LOWER,   KC_LGUI,  KC_SPC,  RAISE,   KC_LEFT, KC_DOWN, KC_UP,   KC_RGHT \
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        /* Lower
 | 
				
			||||||
 | 
					         * ,-----------------------------------------------------------------------------------.
 | 
				
			||||||
 | 
					         * |      |   !  |   @  |   #  |   $  |   %  |   ^  |   &  |   *  |   (  |   )  | Bksp |
 | 
				
			||||||
 | 
					         * |------+------+------+------+------+-------------+------+------+------+------+------|
 | 
				
			||||||
 | 
					         * |   ~  |  F1  |  F2  |  F3  |  F4  |  F5  |  F6  |   _  |   +  |     |    \  |  |   |
 | 
				
			||||||
 | 
					         * |------+------+------+------+------+------|------+------+------+------+------+------|
 | 
				
			||||||
 | 
					         * |      |  F7  |  F8  |  F9  |  F10 |  F11 |  F12 |ISO ~ |ISO | |      |      |Enter |
 | 
				
			||||||
 | 
					         * |------+------+------+------+------+------+------+------+------+------+------+------|
 | 
				
			||||||
 | 
					         * |      |      |      |      |      |             |      | Next | Vol- | Vol+ | Play |
 | 
				
			||||||
 | 
					         * `-----------------------------------------------------------------------------------'
 | 
				
			||||||
 | 
					         */
 | 
				
			||||||
 | 
					        [_LOWER] = KEYMAP( \
 | 
				
			||||||
 | 
					                _______, KC_EXLM, KC_AT,   KC_HASH, KC_DLR,  KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN, KC_DEL, \
 | 
				
			||||||
 | 
					                KC_TILD,  KC_F1,   KC_F2,   KC_F3,   KC_F4,   KC_F5,   KC_F6,   KC_UNDS, KC_PLUS, KC_LCBR, KC_RCBR, KC_PIPE, \
 | 
				
			||||||
 | 
					                _______, KC_F7,   KC_F8,   KC_F9,   KC_F10,  KC_F11,  KC_F12,S(KC_NUHS),S(KC_NUBS),_______, _______, KC_QUOT, \
 | 
				
			||||||
 | 
					                _______, _______, _______, _______, _______, _______, _______, _______, KC_HOME, KC_PGDN, KC_PGUP, KC_END \
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        /* Raise
 | 
				
			||||||
 | 
					         * ,-----------------------------------------------------------------------------------.
 | 
				
			||||||
 | 
					         * |      |   1  |   2  |   3  |   4  |   5  |   6  |   7  |   8  |   9  |   0  | Bksp |
 | 
				
			||||||
 | 
					         * |------+------+------+------+------+-------------+------+------+------+------+------|
 | 
				
			||||||
 | 
					         * |   `  |  F1  |  F2  |  F3  |  F4  |  F5  |  F6  |   -  |   =  |   [  |   ]  |  \   |
 | 
				
			||||||
 | 
					         * |------+------+------+------+------+------|------+------+------+------+------+------|
 | 
				
			||||||
 | 
					         * |      |  F7  |  F8  |  F9  |  F10 |  F11 |  F12 |ISO # |ISO / |      |      |Enter |
 | 
				
			||||||
 | 
					         * |------+------+------+------+------+------+------+------+------+------+------+------|
 | 
				
			||||||
 | 
					         * |      |      |      |      |      |             |      | Home | PgUp | PgDn | End  |
 | 
				
			||||||
 | 
					         * `-----------------------------------------------------------------------------------'
 | 
				
			||||||
 | 
					         */
 | 
				
			||||||
 | 
					        [_RAISE] = KEYMAP( \
 | 
				
			||||||
 | 
					                _______,  KC_1,    KC_2,    KC_3,    KC_4,    KC_5,    KC_6,    KC_7,    KC_8,    KC_9,    KC_0,    KC_DEL, \
 | 
				
			||||||
 | 
					                KC_GRV,  KC_F1,   KC_F2,   KC_F3,   KC_F4,   KC_F5,   KC_F6,   KC_MINS, KC_EQL,  KC_LBRC, KC_RBRC, KC_BSLS, \
 | 
				
			||||||
 | 
					                _______, KC_F7,   KC_F8,   KC_F9,   KC_F10,  KC_F11,  KC_F12,  KC_NUHS, KC_NUBS, _______, _______, _______, \
 | 
				
			||||||
 | 
					                _______, _______, _______, _______, _______, _______, _______, _______, KC_HOME, KC_PGDN, KC_PGUP, KC_END \
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        /* Adjust (Lower + Raise)
 | 
				
			||||||
 | 
					         * ,-----------------------------------------------------------------------------------.
 | 
				
			||||||
 | 
					         * |      | Reset|      |      |      |      |      |      |      |      |      |  Del |
 | 
				
			||||||
 | 
					         * |------+------+------+------+------+-------------+------+------+------+------+------|
 | 
				
			||||||
 | 
					         * |      |      |      |Aud on|Audoff|AGnorm|AGswap|Qwerty|Colemk|Dvorak|      |      |
 | 
				
			||||||
 | 
					         * |------+------+------+------+------+------|------+------+------+------+------+------|
 | 
				
			||||||
 | 
					         * |      |      |      |      |      |      |      |      |      |      |      |      |
 | 
				
			||||||
 | 
					         * |------+------+------+------+------+------+------+------+------+------+------+------|
 | 
				
			||||||
 | 
					         * |      |      |      |      |      |             |      |      |      |      |      |
 | 
				
			||||||
 | 
					         * `-----------------------------------------------------------------------------------'
 | 
				
			||||||
 | 
					         */
 | 
				
			||||||
 | 
					        [_ADJUST] =  KEYMAP( \
 | 
				
			||||||
 | 
					                RESET, _______,   _______, KC_MRWD, KC_MPLY, KC_MFFD, KC_PSCR, _______, KC_MUTE, KC_VOLD, KC_VOLU, KC_DEL, \
 | 
				
			||||||
 | 
					                BL_STEP, RGB_MOD, _______, AU_ON,   AU_OFF,  _______, _______, _______,  _______, _______,  _______, _______, \
 | 
				
			||||||
 | 
					                BL_TOGG, RGB_TOG, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, \
 | 
				
			||||||
 | 
					                _______, KC_PSCR, _______, _______, _______, _______, _______, _______, _______, OUT_AUTO, OUT_USB, OUT_BT \
 | 
				
			||||||
 | 
					        )
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const uint16_t PROGMEM fn_actions[] = {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// Setting ADJUST layer RGB back to default
 | 
				
			||||||
 | 
					void update_tri_layer_RGB(uint8_t layer1, uint8_t layer2, uint8_t layer3) {
 | 
				
			||||||
 | 
					  if (IS_LAYER_ON(layer1) && IS_LAYER_ON(layer2)) {
 | 
				
			||||||
 | 
					#ifdef RGBLIGHT_ENABLE
 | 
				
			||||||
 | 
					    rgblight_mode(RGB_current_mode);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					    layer_on(layer3);
 | 
				
			||||||
 | 
					  } else {
 | 
				
			||||||
 | 
					    layer_off(layer3);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					  // MACRODOWN only works in this function
 | 
				
			||||||
 | 
					      switch(id) {
 | 
				
			||||||
 | 
					        case 0:
 | 
				
			||||||
 | 
					          if (record->event.pressed) {
 | 
				
			||||||
 | 
					            register_code(KC_RSFT);
 | 
				
			||||||
 | 
					          } else {
 | 
				
			||||||
 | 
					            unregister_code(KC_RSFT);
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    return MACRO_NONE;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void matrix_init_user(void) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void matrix_scan_user(void) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					bool process_record_user(uint16_t keycode, keyrecord_t *record) {
 | 
				
			||||||
 | 
					  switch (keycode) {
 | 
				
			||||||
 | 
					    case LOWER:
 | 
				
			||||||
 | 
					        if (record->event.pressed) {
 | 
				
			||||||
 | 
					            //not sure how to have keyboard check mode and set it to a variable, so my work around
 | 
				
			||||||
 | 
					            //uses another variable that would be set to true after the first time a reactive key is pressed.
 | 
				
			||||||
 | 
					            if (TOG_STATUS) { //TOG_STATUS checks is another reactive key currently pressed, only changes RGB mode if returns false
 | 
				
			||||||
 | 
					            } else {
 | 
				
			||||||
 | 
					                TOG_STATUS = !TOG_STATUS;
 | 
				
			||||||
 | 
					#ifdef RGBLIGHT_ENABLE
 | 
				
			||||||
 | 
					                rgblight_mode(16);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            layer_on(_LOWER);
 | 
				
			||||||
 | 
					            update_tri_layer_RGB(_LOWER, _RAISE, _ADJUST);
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					#ifdef RGBLIGHT_ENABLE
 | 
				
			||||||
 | 
					            rgblight_mode(RGB_current_mode);   // revert RGB to initial mode prior to RGB mode change
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					            TOG_STATUS = false;
 | 
				
			||||||
 | 
					            layer_off(_LOWER);
 | 
				
			||||||
 | 
					            update_tri_layer_RGB(_LOWER, _RAISE, _ADJUST);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return false;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    case RAISE:
 | 
				
			||||||
 | 
					        if (record->event.pressed) {
 | 
				
			||||||
 | 
					            //not sure how to have keyboard check mode and set it to a variable, so my work around
 | 
				
			||||||
 | 
					            //uses another variable that would be set to true after the first time a reactive key is pressed.
 | 
				
			||||||
 | 
					            if (TOG_STATUS) { //TOG_STATUS checks is another reactive key currently pressed, only changes RGB mode if returns false
 | 
				
			||||||
 | 
					            } else {
 | 
				
			||||||
 | 
					                TOG_STATUS = !TOG_STATUS;
 | 
				
			||||||
 | 
					#ifdef RGBLIGHT_ENABLE
 | 
				
			||||||
 | 
					                rgblight_mode(15);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            layer_on(_RAISE);
 | 
				
			||||||
 | 
					            update_tri_layer_RGB(_LOWER, _RAISE, _ADJUST);
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					#ifdef RGBLIGHT_ENABLE
 | 
				
			||||||
 | 
					            rgblight_mode(RGB_current_mode);  // revert RGB to initial mode prior to RGB mode change
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					            layer_off(_RAISE);
 | 
				
			||||||
 | 
					            TOG_STATUS = false;
 | 
				
			||||||
 | 
					            update_tri_layer_RGB(_LOWER, _RAISE, _ADJUST);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return false;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    case ADJUST:
 | 
				
			||||||
 | 
					        // FIXME add RGB feedback
 | 
				
			||||||
 | 
					        if (record->event.pressed) {
 | 
				
			||||||
 | 
					            layer_on(_ADJUST);
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					            layer_off(_ADJUST);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return false;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    case BL_TOGG:
 | 
				
			||||||
 | 
					#ifdef BACKLIGHT_ENABLE
 | 
				
			||||||
 | 
					        if (record->event.pressed) {
 | 
				
			||||||
 | 
					            print("Enabling backlight\n");
 | 
				
			||||||
 | 
					            backlight_init_ports();
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					        return false;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    case BL_STEP:
 | 
				
			||||||
 | 
					        if (record->event.pressed) {
 | 
				
			||||||
 | 
					#ifdef BACKLIGHT_ENABLE
 | 
				
			||||||
 | 
					            backlight_step();
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return false;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					        //led operations - RGB mode change now updates the RGB_current_mode to allow the right RGB mode to be set after reactive keys are released
 | 
				
			||||||
 | 
					#ifdef RGBLIGHT_ENABLE
 | 
				
			||||||
 | 
					    case RGB_MOD:
 | 
				
			||||||
 | 
					        if (record->event.pressed) {
 | 
				
			||||||
 | 
					            rgblight_mode(RGB_current_mode);
 | 
				
			||||||
 | 
					            rgblight_step();
 | 
				
			||||||
 | 
					            RGB_current_mode = rgblight_config.mode;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return false;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  return true;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void led_set_user(uint8_t usb_led) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										1
									
								
								keyboards/meira/keymaps/cole/readme.md
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								keyboards/meira/keymaps/cole/readme.md
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					# The default keymap for meira
 | 
				
			||||||
							
								
								
									
										2
									
								
								keyboards/meira/keymaps/cole/rules.mk
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								keyboards/meira/keymaps/cole/rules.mk
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,2 @@
 | 
				
			||||||
 | 
					AUDIO_ENABLE = yes           # Audio output on port C6
 | 
				
			||||||
 | 
					EXTRAFLAGS+=-flto # -4-7k
 | 
				
			||||||
| 
						 | 
					@ -20,5 +20,15 @@
 | 
				
			||||||
#include "../../config.h"
 | 
					#include "../../config.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// place overrides here
 | 
					// place overrides here
 | 
				
			||||||
 | 
					#define MUSIC_MASK (keycode != KC_NO)
 | 
				
			||||||
 | 
					#ifdef AUDIO_ENABLE
 | 
				
			||||||
 | 
					    #define STARTUP_SONG SONG(PLANCK_SOUND)
 | 
				
			||||||
 | 
					    // #define STARTUP_SONG SONG(NO_SOUND)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    #define DEFAULT_LAYER_SONGS { SONG(QWERTY_SOUND), \
 | 
				
			||||||
 | 
					                                  SONG(COLEMAK_SOUND), \
 | 
				
			||||||
 | 
					                                  SONG(DVORAK_SOUND) \
 | 
				
			||||||
 | 
					                                }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -37,6 +37,17 @@ enum custom_keycodes {
 | 
				
			||||||
  ADJUST,
 | 
					  ADJUST,
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef AUDIO_ENABLE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					float tone_my_startup[][2] = SONG(ODE_TO_JOY);
 | 
				
			||||||
 | 
					float tone_my_goodbye[][2] = SONG(ROCK_A_BYE_BABY);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					float tone_qwerty[][2]     = SONG(QWERTY_SOUND);
 | 
				
			||||||
 | 
					float tone_dvorak[][2]     = SONG(DVORAK_SOUND);
 | 
				
			||||||
 | 
					float tone_colemak[][2]    = SONG(COLEMAK_SOUND);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif /* AUDIO_ENABLE */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// define variables for reactive RGB
 | 
					// define variables for reactive RGB
 | 
				
			||||||
bool TOG_STATUS = false;
 | 
					bool TOG_STATUS = false;
 | 
				
			||||||
int RGB_current_mode;
 | 
					int RGB_current_mode;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -22,30 +22,10 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
extern void backlight_set(uint8_t level);
 | 
					extern void backlight_set(uint8_t level);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef AUDIO_ENABLE
 | 
					 | 
				
			||||||
    float tone_startup[][2] = SONG(STARTUP_SOUND);
 | 
					 | 
				
			||||||
    float tone_goodbye[][2] = SONG(GOODBYE_SOUND);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
void shutdown_user(void) {
 | 
					 | 
				
			||||||
    #ifdef AUDIO_ENABLE
 | 
					 | 
				
			||||||
        PLAY_NOTE_ARRAY(tone_goodbye, false, 0);
 | 
					 | 
				
			||||||
    _delay_ms(150);
 | 
					 | 
				
			||||||
    stop_all_notes();
 | 
					 | 
				
			||||||
    #endif
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
void matrix_init_kb(void)
 | 
					void matrix_init_kb(void)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    debug_enable=true;
 | 
					    debug_enable=true;
 | 
				
			||||||
    print("meira matrix_init_kb\n");
 | 
					    print("meira matrix_init_kb\n");
 | 
				
			||||||
#ifdef AUDIO_ENABLE
 | 
					 | 
				
			||||||
    _delay_ms(20); // gets rid of tick
 | 
					 | 
				
			||||||
    PLAY_NOTE_ARRAY(tone_startup, false, 0);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef ISSI_ENABLE
 | 
					#ifdef ISSI_ENABLE
 | 
				
			||||||
    issi_init();
 | 
					    issi_init();
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -54,6 +54,7 @@ void reset_keyboard_kb(void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define LAYOUT_ortho_4x12 KEYMAP
 | 
					#define LAYOUT_ortho_4x12 KEYMAP
 | 
				
			||||||
#define KC_LAYOUT_ortho_4x12 KC_KEYMAP
 | 
					#define KC_LAYOUT_ortho_4x12 KC_KEYMAP
 | 
				
			||||||
 | 
					#define LAYOUT_kc_ortho_4x12 KC_KEYMAP
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1 +1,14 @@
 | 
				
			||||||
 | 
					# Processor frequency.
 | 
				
			||||||
 | 
					#     This will define a symbol, F_CPU, in all source code files equal to the
 | 
				
			||||||
 | 
					#     processor frequency in Hz. You can then use this symbol in your source code to
 | 
				
			||||||
 | 
					#     calculate timings. Do NOT tack on a 'UL' at the end, this will be done
 | 
				
			||||||
 | 
					#     automatically to create a 32-bit value in your source code.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					#     This will be an integer division of F_USB below, as it is sourced by
 | 
				
			||||||
 | 
					#     F_USB after it has run through any CPU prescalers. Note that this value
 | 
				
			||||||
 | 
					#     does not *change* the processor frequency - it should merely be updated to
 | 
				
			||||||
 | 
					#     reflect the processor speed set externally so that the code can use accurate
 | 
				
			||||||
 | 
					#     software delays.
 | 
				
			||||||
 | 
					F_CPU = 16000000
 | 
				
			||||||
 | 
					
 | 
				
			||||||
BLUETOOTH_ENABLE = no
 | 
					BLUETOOTH_ENABLE = no
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -4,19 +4,6 @@ SRC += matrix.c TWIlib.c issi.c lighting.c
 | 
				
			||||||
#MCU = at90usb1286
 | 
					#MCU = at90usb1286
 | 
				
			||||||
MCU = atmega32u4
 | 
					MCU = atmega32u4
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Processor frequency.
 | 
					 | 
				
			||||||
#     This will define a symbol, F_CPU, in all source code files equal to the
 | 
					 | 
				
			||||||
#     processor frequency in Hz. You can then use this symbol in your source code to
 | 
					 | 
				
			||||||
#     calculate timings. Do NOT tack on a 'UL' at the end, this will be done
 | 
					 | 
				
			||||||
#     automatically to create a 32-bit value in your source code.
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
#     This will be an integer division of F_USB below, as it is sourced by
 | 
					 | 
				
			||||||
#     F_USB after it has run through any CPU prescalers. Note that this value
 | 
					 | 
				
			||||||
#     does not *change* the processor frequency - it should merely be updated to
 | 
					 | 
				
			||||||
#     reflect the processor speed set externally so that the code can use accurate
 | 
					 | 
				
			||||||
#     software delays.
 | 
					 | 
				
			||||||
F_CPU = 16000000
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# LUFA specific
 | 
					# LUFA specific
 | 
				
			||||||
| 
						 | 
					@ -37,6 +24,12 @@ ARCH = AVR8
 | 
				
			||||||
#     CPU clock adjust registers or the clock division fuses), this will be equal to F_CPU.
 | 
					#     CPU clock adjust registers or the clock division fuses), this will be equal to F_CPU.
 | 
				
			||||||
F_USB = $(F_CPU)
 | 
					F_USB = $(F_CPU)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Bootloader
 | 
				
			||||||
 | 
					#     This definition is optional, and if your keyboard supports multiple bootloaders of
 | 
				
			||||||
 | 
					#     different sizes, comment this out, and the correct address will be loaded 
 | 
				
			||||||
 | 
					#     automatically (+60). See bootloader.mk for all options.
 | 
				
			||||||
 | 
					BOOTLOADER = caterina
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Interrupt driven control endpoint task(+60)
 | 
					# Interrupt driven control endpoint task(+60)
 | 
				
			||||||
OPT_DEFS += -DINTERRUPT_CONTROL_ENDPOINT
 | 
					OPT_DEFS += -DINTERRUPT_CONTROL_ENDPOINT
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -54,10 +47,10 @@ OPT_DEFS += -DBOOTLOADER_SIZE=4096
 | 
				
			||||||
#   change yes to no to disable
 | 
					#   change yes to no to disable
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
BOOTMAGIC_ENABLE = no      # Virtual DIP switch configuration(+1000)
 | 
					BOOTMAGIC_ENABLE = no      # Virtual DIP switch configuration(+1000)
 | 
				
			||||||
MOUSEKEY_ENABLE = yes       # Mouse keys(+4700)
 | 
					MOUSEKEY_ENABLE = no       # Mouse keys(+4700)
 | 
				
			||||||
EXTRAKEY_ENABLE = yes       # Audio control and System control(+450)
 | 
					EXTRAKEY_ENABLE = yes       # Audio control and System control(+450)
 | 
				
			||||||
CONSOLE_ENABLE = yes        # Console for debug(+400)
 | 
					CONSOLE_ENABLE = no        # Console for debug(+400)
 | 
				
			||||||
COMMAND_ENABLE = yes        # Commands for debug and configuration
 | 
					COMMAND_ENABLE = no        # Commands for debug and configuration
 | 
				
			||||||
# Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE
 | 
					# Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE
 | 
				
			||||||
SLEEP_LED_ENABLE = no       # Breathing sleep LED during USB suspend
 | 
					SLEEP_LED_ENABLE = no       # Breathing sleep LED during USB suspend
 | 
				
			||||||
# if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work
 | 
					# if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work
 | 
				
			||||||
| 
						 | 
					@ -74,13 +67,13 @@ ISSI_ENABLE = yes			# If the I2C pullup resistors aren't install this must be di
 | 
				
			||||||
 | 
					
 | 
				
			||||||
CUSTOM_MATRIX = yes
 | 
					CUSTOM_MATRIX = yes
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ifeq ($(strip $(ISSI_ENABLE)), yes)
 | 
					#ifeq ($(strip $(ISSI_ENABLE)), yes)
 | 
				
			||||||
    TMK_COMMON_DEFS += -DISSI_ENABLE
 | 
					#    TMK_COMMON_DEFS += -DISSI_ENABLE
 | 
				
			||||||
endif
 | 
					#endif
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
ifeq ($(strip $(WATCHDOG_ENABLE)), yes)
 | 
					#ifeq ($(strip $(WATCHDOG_ENABLE)), yes)
 | 
				
			||||||
    TMK_COMMON_DEFS += -DWATCHDOG_ENABLE
 | 
					#    TMK_COMMON_DEFS += -DWATCHDOG_ENABLE
 | 
				
			||||||
endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
DEFAULT_FOLDER = meira/promicro
 | 
					DEFAULT_FOLDER = meira/promicro
 | 
				
			||||||
LAYOUTS = ortho_4x12
 | 
					LAYOUTS = ortho_4x12
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue