Browse Source

Improvements for TentaPad

- Proximity feature
- Reduce strength of vibration
- Change number of layers to 32
old_master
Kai Ryu 9 years ago
parent
commit
49cd99e5ae

+ 6
- 5
keyboard/tentapad/backlight.c View File

@@ -26,7 +26,8 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
#ifdef BACKLIGHT_ENABLE

uint8_t backlight_mode;
const uint8_t backlight_brightness = 0xFF;
const uint8_t backlight_brightness_mid = 64;
const uint8_t backlight_brightness_high = 255;

void backlight_set(uint8_t level)
{
@@ -44,14 +45,14 @@ void backlight_set(uint8_t level)
softpwm_led_on(LED_BOARD_SIDE);
break;
case 1:
softpwm_led_set(LED_BOARD_SIDE, backlight_brightness);
softpwm_led_set(LED_BOARD_SIDE, backlight_brightness_mid);
fading_led_disable_all();
fading_led_enable(LED_KEY_SIDE);
breathing_led_disable_all();
softpwm_led_enable();
break;
case 2:
softpwm_led_set(LED_KEY_SIDE, backlight_brightness);
softpwm_led_set(LED_KEY_SIDE, backlight_brightness_mid);
fading_led_disable_all();
fading_led_enable(LED_BOARD_SIDE);
breathing_led_disable_all();
@@ -65,14 +66,14 @@ void backlight_set(uint8_t level)
softpwm_led_enable();
break;
case 4:
softpwm_led_set(LED_KEY_SIDE, backlight_brightness);
softpwm_led_set(LED_KEY_SIDE, backlight_brightness_mid);
breathing_led_disable_all();
breathing_led_enable(LED_BOARD_SIDE);
fading_led_disable_all();
softpwm_led_enable();
break;
case 5:
softpwm_led_set(LED_BOARD_SIDE, backlight_brightness);
softpwm_led_set(LED_BOARD_SIDE, backlight_brightness_mid);
breathing_led_disable_all();
breathing_led_enable(LED_KEY_SIDE);
fading_led_disable_all();

+ 1
- 1
keyboard/tentapad/config.h View File

@@ -33,7 +33,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.

/* keymap in eeprom */
#define FN_ACTIONS_COUNT 32
#define KEYMAPS_COUNT 8
#define KEYMAPS_COUNT 32

/* define if matrix has ghost */
//#define MATRIX_HAS_GHOST

+ 42
- 12
keyboard/tentapad/tentapad.c View File

@@ -41,7 +41,8 @@ static uint8_t backlight = 0;
static uint8_t layer_modified = 0;
static uint8_t backlight_modified = 0;
extern uint8_t backlight_mode;
extern const uint8_t backlight_brightness;
extern const uint8_t backlight_brightness_mid;
extern const uint8_t backlight_brightness_high;

void action_keyevent(keyevent_t event)
{
@@ -79,7 +80,7 @@ void action_keyevent(keyevent_t event)
case 1: case 2:
softpwm_led_increase(LED_KEY_SIDE - 1 + backlight_mode, 32);
case 3 ... 5:
softpwm_led_set(key, backlight_brightness);
softpwm_led_set(key, backlight_brightness_high);
break;
}
}
@@ -97,7 +98,7 @@ void action_keyevent(keyevent_t event)
break;
case KEY_TT:
if (event.pressed) {
vibration(64);
vibration(32);
switch (backlight_mode) {
case 1: case 2:
softpwm_led_increase(LED_KEY_SIDE - 1 + backlight_mode, 32);
@@ -105,6 +106,26 @@ void action_keyevent(keyevent_t event)
}
}
break;
case KEY_TP:
switch (backlight_mode) {
case 1: case 5:
if (event.pressed) {
softpwm_led_set(LED_BOARD_SIDE, backlight_brightness_high);
}
else {
softpwm_led_set(LED_BOARD_SIDE, backlight_brightness_mid);
}
break;
case 2: case 4:
if (event.pressed) {
softpwm_led_set(LED_KEY_SIDE, backlight_brightness_high);
}
else {
softpwm_led_set(LED_KEY_SIDE, backlight_brightness_mid);
}
break;
}
break;
case KEY_CFG:
if (event.pressed) {
enter_config_mode();
@@ -121,7 +142,6 @@ void enter_config_mode(void)
backlight_modified = 0;
backlight = backlight_mode;
backlight_level(8);
layer_on(CONFIG_LAYER);
softpwm_led_set(0, 32 * (layer + 1));
softpwm_led_set(1, 32 * (backlight + 1));
buzzer(pgm_read_word(&tones[0]), 50);
@@ -133,7 +153,6 @@ void exit_config_mode(void)
{
config_mode = 0;
backlight_level(backlight);
layer_off(CONFIG_LAYER);
if (layer_modified) {
default_layer_set(1UL<<layer);
eeconfig_write_default_layer(1UL<<layer);
@@ -154,12 +173,7 @@ void switch_layout(void)
}
dprintf("layer: %d\n", layer);
dprintf("last layer: %d\n", last_layer());
softpwm_led_set(0, 32 * (layer + 1));
buzzer(pgm_read_word(&tones[layer]), 50);
if (layer == 0) {
_delay_ms(10);
buzzer(pgm_read_word(&tones[layer]), 50);
}
set_layer_indicator(layer);
}

void switch_backlight(void)
@@ -172,7 +186,23 @@ void switch_backlight(void)
backlight = (backlight + 1) % (BACKLIGHT_LEVELS);
}
dprintf("backlight: %d\n", backlight);
softpwm_led_set(1, 32 * (backlight + 1));
set_backlight_indicator(backlight);
}

void set_layer_indicator(uint8_t layer)
{
layer = (layer < 7) ? layer : 7;
softpwm_led_set(0, 32 * (layer + 1) - 1);
buzzer(pgm_read_word(&tones[layer]), 50);
if (layer == 0) {
_delay_ms(10);
buzzer(pgm_read_word(&tones[layer]), 50);
}
}

void set_backlight_indicator(uint8_t backlight)
{
softpwm_led_set(1, 32 * (backlight + 1) - 1);
buzzer(pgm_read_word(&tones[7 + backlight]), 50);
if (backlight == 0) {
_delay_ms(10);

+ 2
- 2
keyboard/tentapad/tentapad.h View File

@@ -33,12 +33,12 @@ enum {
LED_BOARD_SIDE
};

#define CONFIG_LAYER 31

void enter_config_mode(void);
void exit_config_mode(void);
void switch_layout(void);
void switch_backlight(void);
void set_layer_indicator(uint8_t layer);
void set_backlight_indicator(uint8_t backlight);

#endif