Mercurial > public > mk2
changeset 84:0f4c175ef824
FIX flickering in new CF menus
author | JeanDo |
---|---|
date | Wed, 08 Dec 2010 02:03:11 +0100 |
parents | 3e351e25f5d1 |
children | 8b813f67220f |
files | code_part1/OSTC_code_asm_part1/menu_custom.asm code_part1/OSTC_code_asm_part1/pled_outputs.asm |
diffstat | 2 files changed, 44 insertions(+), 60 deletions(-) [+] |
line wrap: on
line diff
--- a/code_part1/OSTC_code_asm_part1/menu_custom.asm Tue Dec 07 22:36:19 2010 +0100 +++ b/code_part1/OSTC_code_asm_part1/menu_custom.asm Wed Dec 08 02:03:11 2010 +0100 @@ -163,23 +163,6 @@ WIN_INVERT .0 ; Init new Wordprocessor menu_custom_functions1: - -#ifndef NO_CF_TYPES - ;---- Clear color swatches area ------------------------------------------ - ; BEWARE: PLED_box reset the EEADRH register, so t should be - ; be done before setting CF page I/II... - clrf WREG ; Black background - movff WREG,box_temp+0 ; Set color - movlw .125 - movff WREG,box_temp+1 ; row top (0-239) - movlw .178 - movff WREG,box_temp+2 ; row bottom (0-239) - movlw .75 - movff WREG,box_temp+3 ; column left (0-159) - movlw .150 - movff WREG,box_temp+4 ; column right (0-159) - call PLED_box -#endif call PLED_standard_color movlw d'1' @@ -262,19 +245,12 @@ WIN_LEFT .20 WIN_TOP .65 lfsr FSR2,letter ; Make a string of 8 spaces - movlw ' ' - movwf POSTINC2 - movwf POSTINC2 - movwf POSTINC2 - movwf POSTINC2 - movwf POSTINC2 - movwf POSTINC2 - movwf POSTINC2 - movwf POSTINC2 + call cf_fill_line call word_processor ; Clear +/- line WIN_TOP .95 call word_processor ; Clear 1/10 line + bra menu_custom_functions10b menu_custom_functions10a: @@ -393,6 +369,14 @@ customfunctions2: incf menupos,F + btfss apnoe_mins,0 ; Are we editing a boolean value ? + bra customfunctions2a ; NO : don't skip lines 2/3. + + movlw d'4' ; Just after increment, + cpfsgt menupos ; Is current position < 4 ? + movwf menupos ; NO: skip set to 4. + +customfunctions2a: movlw d'7' cpfseq menupos ; =7? bra customfunctions3 ; No @@ -444,28 +428,28 @@ output_16dp 0 ; NOTE : hi is already reseted... movlw '%' movwf POSTINC2 - bra cf_done + bra cf_do_wp cf_type_02: ; Type == 2 is deci mode. output_16dp 4 - bra cf_done + bra cf_do_wp cf_type_03: ; Type == 3 is centi mode. output_16dp 3 - bra cf_done + bra cf_do_wp cf_type_04: ; Type == 4 is mili mode output_16dp 2 - bra cf_done + bra cf_do_wp cf_type_05: ; Type == 5 is on/off mode. movf lo,W ; Get flag value... bz cf_type_off OUTPUTTEXT d'130' ; ON - bra cf_done + bra cf_do_wp cf_type_off: OUTPUTTEXT d'131' ; OFF - bra cf_done + bra cf_do_wp cf_type_06: ; Type == 6 is mm:ss mode (... or hh:mm) call convert_time ; Convert to min:sec into hi:low. @@ -476,11 +460,14 @@ movwf POSTINC2 movff wp_temp,lo ; Get back seconds output_99x ; lo in 2 digits with trailing zeros. - bra cf_done + bra cf_do_wp cf_type_07: ; Type == 7 is Color swatch. output_8 + call cf_fill_line ; it does less flickering when editing colors... + call word_processor + movf lo,W ; Get color. movff WREG,box_temp+0 ; Set color movff win_top,WREG ; BEWARE : this is a bank0 variable ! @@ -493,7 +480,7 @@ movff WREG,box_temp+4 ; column right (0-159) call PLED_box - bra cf_done ; W/o trailling spaces... + bra cf_done ; wp already done. Skip it... cf_type_99: ; 8bit mode. Or unrecognized type... clrf hi @@ -502,9 +489,24 @@ bcf hi,7 output_16 +cf_do_wp: ; Process by calling wordprocessor + call cf_fill_line + call word_processor + cf_done: - movff FSR1L, hi ; Restore saved registers... + movff FSR1L, hi ; And restore saved registers before return. movff FSR1H, EEADRH + return + +cf_fill_line: ; Mattias: No flicker if u clear just what you need... + movf FSR2L,W ; How many chars lefts ? + sublw (LOW letter) + .17 ; Remaining chars to fill: (letter + 21) - PTR + btfsc STATUS,N ; Add chars until none left... + return + movlw ' ' + movwf POSTINC2 + bra cf_fill_line + #else bcf hi,7 ; clear Bit 7 of value output_16 @@ -534,8 +536,8 @@ movwf POSTINC2 movwf POSTINC2 movwf POSTINC2 + goto word_processor #endif - goto word_processor ;----------------------------------------------------------------------------- @@ -555,6 +557,7 @@ bra restore_cfn_value dcfsnz menupos,F bra adjust_cfn_value + exit_customfunctions: movlw d'2' ; Return to correct list entry btfss customfunction_page @@ -563,7 +566,6 @@ clrf EEADRH ; Clear EEADRH ! goto setup_menu2 ; exit... - next_customfunction: incf decodata+0 btfsc decodata+0,5 ;>31?
--- a/code_part1/OSTC_code_asm_part1/pled_outputs.asm Tue Dec 07 22:36:19 2010 +0100 +++ b/code_part1/OSTC_code_asm_part1/pled_outputs.asm Wed Dec 08 02:03:11 2010 +0100 @@ -894,9 +894,6 @@ DISPLAYTEXT .11 ; Exit return - - - PLED_temp_surfmode: ostc_debug 'e' movff temperature+0,last_temperature+0 @@ -2854,42 +2851,31 @@ WIN_FONT FT_SMALL WIN_INVERT .0 ; Init new Wordprocessor call PLED_standard_color + lfsr FSR2,letter movlw 0xB8 movwf POSTINC2 call word_processor + WIN_TOP .25 - WIN_LEFT .85 - WIN_FONT FT_SMALL - WIN_INVERT .0 ; Init new Wordprocessor - call PLED_standard_color lfsr FSR2,letter movlw 0xB8 movwf POSTINC2 call word_processor + WIN_TOP .50 - WIN_LEFT .85 - WIN_FONT FT_SMALL - WIN_INVERT .0 ; Init new Wordprocessor - call PLED_standard_color lfsr FSR2,letter movlw 0xB8 movwf POSTINC2 call word_processor + WIN_TOP .75 - WIN_LEFT .85 - WIN_FONT FT_SMALL - WIN_INVERT .0 ; Init new Wordprocessor - call PLED_standard_color lfsr FSR2,letter movlw 0xB8 movwf POSTINC2 call word_processor + WIN_TOP .100 - WIN_LEFT .85 - WIN_FONT FT_SMALL - WIN_INVERT .0 ; Init new Wordprocessor - call PLED_standard_color lfsr FSR2,letter movlw 0xB8 movwf POSTINC2 @@ -2908,10 +2894,6 @@ dcfsnz temp1,F movlw d'100' movff WREG,win_top - WIN_LEFT .85 - WIN_FONT FT_SMALL - WIN_INVERT .0 ; Init new Wordprocessor - call PLED_standard_color lfsr FSR2,letter movlw 0xB7 ; Arrow for menu