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, |   _GREEKL, | ||||||
| 
 | 
 | ||||||
|   _NUM, |   _NUM, | ||||||
|   _FUNC, |   _FUN, | ||||||
|   _PUNC, |   _PUNC, | ||||||
| 
 | 
 | ||||||
|   _EMOJI, |   _EMOJI, | ||||||
| @ -76,9 +76,9 @@ enum planck_keycodes { | |||||||
|   NORMAN, |   NORMAN, | ||||||
| 
 | 
 | ||||||
|   // layer switchers
 |   // layer switchers
 | ||||||
|   PUNC, |   // PUNC,
 | ||||||
|   NUM, |   // NUM,
 | ||||||
|   FUNC, |   // FUN,
 | ||||||
|   EMOJI, |   EMOJI, | ||||||
|   GUI, |   GUI, | ||||||
|   GREEK, |   GREEK, | ||||||
| @ -92,11 +92,16 @@ enum planck_keycodes { | |||||||
|   LSPACE, |   LSPACE, | ||||||
|   RSPACE, |   RSPACE, | ||||||
|   GLOW, |   GLOW, | ||||||
|  |   FOR0, | ||||||
| 
 | 
 | ||||||
|   // stub
 |   // stub
 | ||||||
|   AUDIO |   AUDIO | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | #define NUM MO(_NUM) | ||||||
|  | #define FUN MO(_FUN) | ||||||
|  | #define FUN0 LT(_FUN, KC_0) | ||||||
|  | 
 | ||||||
| // unicode map
 | // unicode map
 | ||||||
| 
 | 
 | ||||||
| enum unicode_name { | enum unicode_name { | ||||||
| @ -369,14 +374,14 @@ const uint8_t PROGMEM LED_MODS[] = { | |||||||
| const uint8_t PROGMEM LED_FN[] = { | const uint8_t PROGMEM LED_FN[] = { | ||||||
|   LED_PUNC, |   LED_PUNC, | ||||||
|   LED_NUM, |   LED_NUM, | ||||||
|   LED_FUNC, |   LED_FUN, | ||||||
|   LED_EMOJI |   LED_EMOJI | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| const uint8_t PROGMEM LED_INDICATORS[] = { | const uint8_t PROGMEM LED_INDICATORS[] = { | ||||||
|   LED_IND_EMOJI, |   LED_IND_EMOJI, | ||||||
|   LED_IND_NUM, |   LED_IND_NUM, | ||||||
|   LED_IND_FUNC, |   LED_IND_FUN, | ||||||
|   LED_IND_BATTERY, |   LED_IND_BATTERY, | ||||||
|   LED_IND_USB, |   LED_IND_USB, | ||||||
|   LED_IND_BLUETOOTH, |   LED_IND_BLUETOOTH, | ||||||
| @ -435,7 +440,7 @@ void led_reset(void) { | |||||||
| void led_set_layer_indicator(void) { | void led_set_layer_indicator(void) { | ||||||
|   static uint8_t oldlayer = 255; |   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_NUM, 0, 0, 0);
 | ||||||
|   rgbsps_set(LED_IND_EMOJI, 0, 0, 0); |   rgbsps_set(LED_IND_EMOJI, 0, 0, 0); | ||||||
| 
 | 
 | ||||||
| @ -454,8 +459,8 @@ void led_set_layer_indicator(void) { | |||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   switch(layer) { |   switch(layer) { | ||||||
|     case _FUNC: |     case _FUN: | ||||||
|       rgbsps_set(LED_IND_FUNC, 15, 0, 0); |       rgbsps_set(LED_IND_FUN, 15, 0, 0); | ||||||
|       break; |       break; | ||||||
|     // case _NUM:
 |     // case _NUM:
 | ||||||
|     //   rgbsps_set(LED_IND_NUM, 0, 0, 15);
 |     //   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); |       rgbsps_set(LED_IND_EMOJI, 15, 15, 0); | ||||||
|       break; |       break; | ||||||
|     default: |     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_NUM, 3, 3, 3);
 | ||||||
|       rgbsps_set(LED_IND_EMOJI, 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_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_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_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
 | /* Dvorak
 | ||||||
| @ -636,10 +641,10 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||||||
|  * `-----------------------------------------------------------------------------------' |  * `-----------------------------------------------------------------------------------' | ||||||
|  */ |  */ | ||||||
| [_NUM] = KEYMAP( | [_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_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_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, |   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,    _______ |   _______, _______, _______, _______, _______, _______, _______,  FUN0 ,   KC_COMM, KC_DOT, KC_X,    _______ | ||||||
| ), | ), | ||||||
| 
 | 
 | ||||||
| /* Func
 | /* Func
 | ||||||
| @ -653,11 +658,11 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||||||
|  * |      |      |      |      |      |             |      |      |      |      |      | |  * |      |      |      |      |      |             |      |      |      |      |      | | ||||||
|  * `-----------------------------------------------------------------------------------' |  * `-----------------------------------------------------------------------------------' | ||||||
|  */ |  */ | ||||||
| [_FUNC] = KEYMAP( | [_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_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, |   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, _______, |   _______,   KC_F9,  KC_F10,  KC_F11,  KC_F12,  XXXXXXX, XXXXXXX, XXXXXXX, KC_HOME,  KC_END, XXXXXXX, _______, | ||||||
|   _______, _______, _______, _______,   PUNC,   _______, _______, _______, _______, _______, _______, _______ |   _______, _______, _______, _______,  _______, _______, _______, _______, _______, _______, _______, _______ | ||||||
| ), | ), | ||||||
| 
 | 
 | ||||||
| /* Uppercase Greek
 | /* Uppercase Greek
 | ||||||
| @ -785,10 +790,25 @@ void process_doublespace(bool pressed, bool *isactive, bool *otheractive, bool * | |||||||
| } | } | ||||||
| #endif | #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 process_record_user(uint16_t keycode, keyrecord_t *record) { | ||||||
|   bool lshift = keyboard_report->mods & MOD_BIT(KC_LSFT); |   static bool lshift = false; | ||||||
|   bool rshift = keyboard_report->mods & MOD_BIT(KC_RSFT); |   static bool rshift = false; | ||||||
|   uint8_t layer = biton32(layer_state); |   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 | #ifdef DOUBLESPACE_LAYER_ENABLE | ||||||
|   // double-space: send space immediately if any other key depressed before space is released
 |   // 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 | #endif | ||||||
| 
 | 
 | ||||||
|     // layer switcher
 |     // 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: |     case GREEK: | ||||||
|       if (record->event.pressed) { |       if (record->event.pressed) { | ||||||
|         if (lshift || rshift) { |         if (lshift || rshift) { | ||||||
| @ -968,31 +978,10 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||||||
|         } else { |         } else { | ||||||
|           layer_on(_GREEKL); |           layer_on(_GREEKL); | ||||||
|           layer_off(_GREEKU); |           layer_off(_GREEKU); | ||||||
|           update_tri_layer(_PUNC, _GREEKL, _EMOJI); |  | ||||||
|         } |         } | ||||||
|       } else { |       } else { | ||||||
|         layer_off(_GREEKU); |         layer_off(_GREEKU); | ||||||
|         layer_off(_GREEKL); |         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; |       return false; | ||||||
|       break; |       break; | ||||||
|  | |||||||
| @ -33,7 +33,7 @@ enum led_sequence { | |||||||
|   LED_IND_USB, |   LED_IND_USB, | ||||||
|   LED_IND_BATTERY, |   LED_IND_BATTERY, | ||||||
| 
 | 
 | ||||||
|   LED_IND_FUNC, |   LED_IND_FUN, | ||||||
|   LED_IND_NUM, |   LED_IND_NUM, | ||||||
|   LED_IND_EMOJI, |   LED_IND_EMOJI, | ||||||
| 
 | 
 | ||||||
| @ -60,7 +60,7 @@ enum led_sequence { | |||||||
|   LED_U, |   LED_U, | ||||||
|   LED_J, |   LED_J, | ||||||
|   LED_M, |   LED_M, | ||||||
|   LED_FUNC, |   LED_FUN, | ||||||
| 
 | 
 | ||||||
|   LED_RSPC, |   LED_RSPC, | ||||||
|   LED_N, |   LED_N, | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Priyadi Iman Nurcahyo
						Priyadi Iman Nurcahyo