1
0
Fork 0

Add USB-BLE manual output switching and indicator

This commit is contained in:
Priyadi Iman Nurcahyo 2017-02-09 01:40:22 +07:00
parent 3f2c0bfa86
commit 4be4ed3397
1 changed files with 44 additions and 12 deletions

View File

@ -13,6 +13,7 @@
#include "rgbsps.h" #include "rgbsps.h"
#include "ps2_mouse.h" #include "ps2_mouse.h"
#include "ps2.h" #include "ps2.h"
#include "outputselect.h"
#define COUNT(x) (sizeof (x) / sizeof (*(x))) #define COUNT(x) (sizeof (x) / sizeof (*(x)))
// #define RGBLED_NUM 5 // #define RGBLED_NUM 5
@ -496,6 +497,24 @@ void led_layer_gui(void) {
rgbsps_send(); rgbsps_send();
} }
void led_set_output_ble(void) {
rgbsps_set(LED_IND_BLUETOOTH, 0, 0, 15);
rgbsps_set(LED_IND_USB, 0, 0, 0);
rgbsps_send();
}
void led_set_output_usb(void) {
rgbsps_set(LED_IND_BLUETOOTH, 0, 0, 0);
rgbsps_set(LED_IND_USB, 15, 15, 15);
rgbsps_send();
}
void led_set_output_none(void) {
rgbsps_set(LED_IND_BLUETOOTH, 0, 0, 0);
rgbsps_set(LED_IND_USB, 0, 0, 0);
rgbsps_send();
}
void led_init(void) { void led_init(void) {
// turn off all // turn off all
rgbsps_turnoff(); rgbsps_turnoff();
@ -693,8 +712,8 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
*/ */
[_GUI] = KEYMAP( [_GUI] = KEYMAP(
_______, LGUI(KC_1),LGUI(KC_2),LGUI(KC_3),LGUI(KC_4),LGUI(KC_5),LGUI(KC_6),LGUI(KC_7),LGUI(KC_8),LGUI(KC_9),LGUI(KC_0), _______, _______, LGUI(KC_1),LGUI(KC_2),LGUI(KC_3),LGUI(KC_4),LGUI(KC_5),LGUI(KC_6),LGUI(KC_7),LGUI(KC_8),LGUI(KC_9),LGUI(KC_0), _______,
LINUX, _______, KC_VOLD, KC_MUTE, KC_VOLU,_______,_______,KC_WWW_BACK,_______,KC_WWW_FORWARD,KC_PAUS, QWERTY, LINUX, OUT_USB, KC_VOLD, KC_MUTE, KC_VOLU,_______,_______,KC_WWW_BACK,_______,KC_WWW_FORWARD,KC_PAUS, QWERTY,
WIN, _______, KC_MPRV, KC_MPLY, KC_MNXT, RGB_TOG, RGB_MOD, RGB_HUI, RGB_HUD, RGB_SAI, RGB_SAD, COLEMAK, WIN, OUT_BLE, KC_MPRV, KC_MPLY, KC_MNXT, RGB_TOG, RGB_MOD, RGB_HUI, RGB_HUD, RGB_SAI, RGB_SAD, COLEMAK,
OSX, _______, _______, _______, _______, BL_DEC, BL_INC, _______, _______, RGB_VAI, RGB_VAD, WORKMAN OSX, _______, _______, _______, _______, BL_DEC, BL_INC, _______, _______, RGB_VAI, RGB_VAD, WORKMAN
), ),
@ -908,24 +927,37 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) {
return true; return true;
} }
void set_output_user(uint8_t output) {
switch(output) {
case OUTPUT_USB:
led_set_output_usb();
break;
case OUTPUT_ADAFRUIT_BLE:
led_set_output_ble();
break;
default:
led_set_output_none();
}
}
void matrix_init_user(void) { void matrix_init_user(void) {
_delay_ms(500); // give time for usb to initialize
#ifdef AUDIO_ENABLE #ifdef AUDIO_ENABLE
startup_user(); startup_user();
#endif #endif
set_unicode_input_mode(UC_LNX); set_unicode_input_mode(UC_LNX);
led_init(); led_init();
// auto detect output on init
uint8_t output = auto_detect_output();
if (output == OUTPUT_USB) {
set_output(OUTPUT_USB);
} else {
set_output(OUTPUT_ADAFRUIT_BLE);
}
} }
// void init_rgblight(void) {
// for (uint8_t i = 0; i < RGBLED_NUM; i++) {
// led[i].r = 255;
// led[i].g = 85;
// led[i].b = 0;
// }
// ws2812_setleds(led, RGBLED_NUM);
// }
#ifdef AUDIO_ENABLE #ifdef AUDIO_ENABLE
void startup_user() void startup_user()