mirror of
				https://github.com/mfulz/qmk_firmware.git
				synced 2025-10-31 13:22:31 +01:00 
			
		
		
		
	num, func, punc 3state layer done right
This commit is contained in:
		
							parent
							
								
									3758cfd95f
								
							
						
					
					
						commit
						df311c7b40
					
				| @ -56,7 +56,7 @@ enum layers { | ||||
|   _GREEKL, | ||||
| 
 | ||||
|   _NUM, | ||||
|   _FUNC, | ||||
|   _FUN, | ||||
|   _PUNC, | ||||
| 
 | ||||
|   _EMOJI, | ||||
| @ -76,9 +76,9 @@ enum planck_keycodes { | ||||
|   NORMAN, | ||||
| 
 | ||||
|   // layer switchers
 | ||||
|   PUNC, | ||||
|   NUM, | ||||
|   FUNC, | ||||
|   // PUNC,
 | ||||
|   // NUM,
 | ||||
|   // FUN,
 | ||||
|   EMOJI, | ||||
|   GUI, | ||||
|   GREEK, | ||||
| @ -92,11 +92,16 @@ enum planck_keycodes { | ||||
|   LSPACE, | ||||
|   RSPACE, | ||||
|   GLOW, | ||||
|   FOR0, | ||||
| 
 | ||||
|   // stub
 | ||||
|   AUDIO | ||||
| }; | ||||
| 
 | ||||
| #define NUM MO(_NUM) | ||||
| #define FUN MO(_FUN) | ||||
| #define FUN0 LT(_FUN, KC_0) | ||||
| 
 | ||||
| // unicode map
 | ||||
| 
 | ||||
| enum unicode_name { | ||||
| @ -369,14 +374,14 @@ const uint8_t PROGMEM LED_MODS[] = { | ||||
| const uint8_t PROGMEM LED_FN[] = { | ||||
|   LED_PUNC, | ||||
|   LED_NUM, | ||||
|   LED_FUNC, | ||||
|   LED_FUN, | ||||
|   LED_EMOJI | ||||
| }; | ||||
| 
 | ||||
| const uint8_t PROGMEM LED_INDICATORS[] = { | ||||
|   LED_IND_EMOJI, | ||||
|   LED_IND_NUM, | ||||
|   LED_IND_FUNC, | ||||
|   LED_IND_FUN, | ||||
|   LED_IND_BATTERY, | ||||
|   LED_IND_USB, | ||||
|   LED_IND_BLUETOOTH, | ||||
| @ -435,7 +440,7 @@ void led_reset(void) { | ||||
| void led_set_layer_indicator(void) { | ||||
|   static uint8_t oldlayer = 255; | ||||
| 
 | ||||
|   rgbsps_set(LED_IND_FUNC, 0, 0, 0); | ||||
|   rgbsps_set(LED_IND_FUN, 0, 0, 0); | ||||
|   // rgbsps_set(LED_IND_NUM, 0, 0, 0);
 | ||||
|   rgbsps_set(LED_IND_EMOJI, 0, 0, 0); | ||||
| 
 | ||||
| @ -454,8 +459,8 @@ void led_set_layer_indicator(void) { | ||||
|   } | ||||
| 
 | ||||
|   switch(layer) { | ||||
|     case _FUNC: | ||||
|       rgbsps_set(LED_IND_FUNC, 15, 0, 0); | ||||
|     case _FUN: | ||||
|       rgbsps_set(LED_IND_FUN, 15, 0, 0); | ||||
|       break; | ||||
|     // case _NUM:
 | ||||
|     //   rgbsps_set(LED_IND_NUM, 0, 0, 15);
 | ||||
| @ -464,7 +469,7 @@ void led_set_layer_indicator(void) { | ||||
|       rgbsps_set(LED_IND_EMOJI, 15, 15, 0); | ||||
|       break; | ||||
|     default: | ||||
|       rgbsps_set(LED_IND_FUNC, 3, 3, 3); | ||||
|       rgbsps_set(LED_IND_FUN, 3, 3, 3); | ||||
|       // rgbsps_set(LED_IND_NUM, 3, 3, 3);
 | ||||
|       rgbsps_set(LED_IND_EMOJI, 3, 3, 3); | ||||
|   } | ||||
| @ -520,7 +525,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|   KC_TAB,  KC_Q,    KC_W,    KC_E,    KC_R,    KC_T,    KC_Y,    KC_U,    KC_I,    KC_O,    KC_P,    KC_BSPC, | ||||
|   KC_ESC,  KC_A,    KC_S,    KC_D,    KC_F,    KC_G,    KC_H,    KC_J,    KC_K,    KC_L,    KC_QUOT, KC_ENT , | ||||
|   KC_LSFT, KC_Z,    KC_X,    KC_C,    KC_V,    KC_B,    KC_N,    KC_M,    KC_COMM, KC_DOT,  KC_SLSH, KC_RSFT, | ||||
|   KC_LCTL, KC_LALT, KC_LGUI, XXXXXXX, NUM,     LSPACE,  RSPACE,  FUNC,    GREEK,   KC_RGUI, KC_RALT, KC_RCTL | ||||
|   KC_LCTL, KC_LALT, KC_LGUI, XXXXXXX, NUM,     LSPACE,  RSPACE,  FUN,     GREEK,   KC_RGUI, KC_RALT, KC_RCTL | ||||
| ), | ||||
| 
 | ||||
| /* Dvorak
 | ||||
| @ -636,10 +641,10 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|  * `-----------------------------------------------------------------------------------' | ||||
|  */ | ||||
| [_NUM] = KEYMAP( | ||||
|   KC_TILD, KC_EXLM, KC_AT,   KC_HASH, KC_DLR,  KC_PERC, S(KC_A),    KC_7,    KC_8,    KC_9, S(KC_D), _______, | ||||
|   KC_GRV,  KC_ASTR, KC_BSLS, KC_MINS,  KC_EQL, KC_SLSH, S(KC_B),    KC_4,    KC_5,    KC_6, S(KC_E), _______, | ||||
|   KC_AMPR, KC_CIRC, KC_PIPE, KC_UNDS, KC_PLUS, KC_QUES, S(KC_C),    KC_1,    KC_2,    KC_3, S(KC_F), KC_COLN, | ||||
|   _______, _______, _______, _______, _______, _______, _______,    LT(_PUNC, KC_0), KC_COMM,  KC_DOT, KC_X,    _______ | ||||
|   KC_TILD, KC_EXLM, KC_AT,   KC_HASH, KC_DLR,  KC_PERC, S(KC_A),  KC_7,    KC_8,    KC_9,   S(KC_D), _______, | ||||
|   KC_GRV,  KC_ASTR, KC_BSLS, KC_MINS,  KC_EQL, KC_SLSH, S(KC_B),  KC_4,    KC_5,    KC_6,   S(KC_E), _______, | ||||
|   KC_AMPR, KC_CIRC, KC_PIPE, KC_UNDS, KC_PLUS, KC_QUES, S(KC_C),  KC_1,    KC_2,    KC_3,   S(KC_F), KC_COLN, | ||||
|   _______, _______, _______, _______, _______, _______, _______,  FUN0 ,   KC_COMM, KC_DOT, KC_X,    _______ | ||||
| ), | ||||
| 
 | ||||
| /* Func
 | ||||
| @ -653,11 +658,11 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|  * |      |      |      |      |      |             |      |      |      |      |      | | ||||
|  * `-----------------------------------------------------------------------------------' | ||||
|  */ | ||||
| [_FUNC] = KEYMAP( | ||||
|   XXXXXXX,   KC_F1,   KC_F2,   KC_F3,   KC_F4,  XXXXXXX, XXXXXXX, KC_PGUP,   KC_UP, KC_PGDN, KC_PGUP,  KC_DEL, | ||||
|   XXXXXXX,   KC_F5,   KC_F6,   KC_F7,   KC_F8,  KC_PSCR, XXXXXXX, KC_LEFT, KC_DOWN, KC_RGHT, KC_PGDN,  KC_INS, | ||||
|   _______,   KC_F9,  KC_F10,  KC_F11,   KC_F12, XXXXXXX, XXXXXXX, XXXXXXX, KC_HOME,  KC_END, XXXXXXX, _______, | ||||
|   _______, _______, _______, _______,   PUNC,   _______, _______, _______, _______, _______, _______, _______ | ||||
| [_FUN] = KEYMAP( | ||||
|   XXXXXXX,   KC_F1,   KC_F2,   KC_F3,  KC_F4,   XXXXXXX, XXXXXXX, KC_PGUP,   KC_UP, KC_PGDN, KC_PGUP,  KC_DEL, | ||||
|   XXXXXXX,   KC_F5,   KC_F6,   KC_F7,  KC_F8,   KC_PSCR, XXXXXXX, KC_LEFT, KC_DOWN, KC_RGHT, KC_PGDN,  KC_INS, | ||||
|   _______,   KC_F9,  KC_F10,  KC_F11,  KC_F12,  XXXXXXX, XXXXXXX, XXXXXXX, KC_HOME,  KC_END, XXXXXXX, _______, | ||||
|   _______, _______, _______, _______,  _______, _______, _______, _______, _______, _______, _______, _______ | ||||
| ), | ||||
| 
 | ||||
| /* Uppercase Greek
 | ||||
| @ -785,10 +790,25 @@ void process_doublespace(bool pressed, bool *isactive, bool *otheractive, bool * | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| uint32_t layer_state_set_kb(uint32_t state) | ||||
| { | ||||
|   // turn on punc layer if both fun & num are on
 | ||||
|   if ((state & ((1UL<<_NUM) | (1UL<<_FUN))) == ((1UL<<_NUM) | (1UL<<_FUN))) { | ||||
|     state |= (1UL<<_PUNC); | ||||
|   } else { | ||||
|     state &= ~(1UL<<_PUNC); | ||||
|   } | ||||
|   return state; | ||||
| } | ||||
| 
 | ||||
| bool process_record_user(uint16_t keycode, keyrecord_t *record) { | ||||
|   bool lshift = keyboard_report->mods & MOD_BIT(KC_LSFT); | ||||
|   bool rshift = keyboard_report->mods & MOD_BIT(KC_RSFT); | ||||
|   uint8_t layer = biton32(layer_state); | ||||
|   static bool lshift = false; | ||||
|   static bool rshift = false; | ||||
|   static uint8_t layer = 0; | ||||
| 
 | ||||
|   lshift = keyboard_report->mods & MOD_BIT(KC_LSFT); | ||||
|   rshift = keyboard_report->mods & MOD_BIT(KC_RSFT); | ||||
|   layer = biton32(layer_state); | ||||
| 
 | ||||
| #ifdef DOUBLESPACE_LAYER_ENABLE | ||||
|   // double-space: send space immediately if any other key depressed before space is released
 | ||||
| @ -949,17 +969,7 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | ||||
| #endif | ||||
| 
 | ||||
|     // layer switcher
 | ||||
|     case PUNC: | ||||
|       if (record->event.pressed) { | ||||
|         layer_on(_PUNC); | ||||
|         update_tri_layer(_PUNC, _GREEKL, _EMOJI); | ||||
|       } else { | ||||
|         layer_off(_PUNC); | ||||
|         update_tri_layer(_PUNC, _GREEKL, _EMOJI); | ||||
|       } | ||||
|       return false; | ||||
|       break; | ||||
| 
 | ||||
|     //
 | ||||
|     case GREEK: | ||||
|       if (record->event.pressed) { | ||||
|         if (lshift || rshift) { | ||||
| @ -968,31 +978,10 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | ||||
|         } else { | ||||
|           layer_on(_GREEKL); | ||||
|           layer_off(_GREEKU); | ||||
|           update_tri_layer(_PUNC, _GREEKL, _EMOJI); | ||||
|         } | ||||
|       } else { | ||||
|         layer_off(_GREEKU); | ||||
|         layer_off(_GREEKL); | ||||
|         update_tri_layer(_PUNC, _GREEKL, _EMOJI); | ||||
|       } | ||||
|       return false; | ||||
|       break; | ||||
| 
 | ||||
|     case NUM: | ||||
|       if (record->event.pressed) { | ||||
|         turn_off_capslock(); | ||||
|         layer_on(_NUM); | ||||
|       } else { | ||||
|         layer_off(_NUM); | ||||
|       } | ||||
|       return false; | ||||
|       break; | ||||
| 
 | ||||
|     case FUNC: | ||||
|       if (record->event.pressed) { | ||||
|         layer_on(_FUNC); | ||||
|       } else { | ||||
|         layer_off(_FUNC); | ||||
|       } | ||||
|       return false; | ||||
|       break; | ||||
|  | ||||
| @ -33,7 +33,7 @@ enum led_sequence { | ||||
|   LED_IND_USB, | ||||
|   LED_IND_BATTERY, | ||||
| 
 | ||||
|   LED_IND_FUNC, | ||||
|   LED_IND_FUN, | ||||
|   LED_IND_NUM, | ||||
|   LED_IND_EMOJI, | ||||
| 
 | ||||
| @ -60,7 +60,7 @@ enum led_sequence { | ||||
|   LED_U, | ||||
|   LED_J, | ||||
|   LED_M, | ||||
|   LED_FUNC, | ||||
|   LED_FUN, | ||||
| 
 | ||||
|   LED_RSPC, | ||||
|   LED_N, | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Priyadi Iman Nurcahyo
						Priyadi Iman Nurcahyo