PictureFlow: Delay LCD Update until center slide is loaded

Eliminates flashing of slide right after launch or
when changing sorting on the M3K using the
volume buttons

Change-Id: Icd317e0b0d5b939269dc8dafd30d0c0f9daa5fd9
This commit is contained in:
Christian Soffke 2022-04-03 23:01:03 +02:00 committed by Aidan MacDonald
parent 3fcdadce24
commit e3bf6f08e3

View file

@ -531,6 +531,7 @@ static int itilt;
static PFreal offsetX; static PFreal offsetX;
static PFreal offsetY; static PFreal offsetY;
static int number_of_slides; static int number_of_slides;
static bool is_initial_slide = true;
static struct pf_slide_cache pf_sldcache; static struct pf_slide_cache pf_sldcache;
@ -2903,12 +2904,18 @@ static inline struct dim *surface(const int slide_index)
{ {
int j = 0; int j = 0;
do { do {
if (pf_sldcache.cache[i].index == slide_index) if (pf_sldcache.cache[i].index == slide_index) {
if (is_initial_slide && slide_index == center_index)
is_initial_slide = false;
return get_slide(pf_sldcache.cache[i].hid); return get_slide(pf_sldcache.cache[i].hid);
}
i = pf_sldcache.cache[i].next; i = pf_sldcache.cache[i].next;
j++; j++;
} while (i != pf_sldcache.used && j < SLIDE_CACHE_SIZE); } while (i != pf_sldcache.used && j < SLIDE_CACHE_SIZE);
} }
if (is_initial_slide && slide_index == center_index)
return NULL;
else
return get_slide(empty_slide_hid); return get_slide(empty_slide_hid);
} }
@ -3245,6 +3252,7 @@ static bool sort_albums(int new_sorting, bool from_settings)
rb->buflib_init(&buf_ctx, (void *)pf_idx.buf, pf_idx.buf_sz); rb->buflib_init(&buf_ctx, (void *)pf_idx.buf, pf_idx.buf_sz);
empty_slide_hid = read_pfraw(EMPTY_SLIDE, 0); empty_slide_hid = read_pfraw(EMPTY_SLIDE, 0);
initialize_slide_cache(); initialize_slide_cache();
is_initial_slide = true;
create_pf_thread(); create_pf_thread();
/* Go to previously selected slide */ /* Go to previously selected slide */
@ -4455,6 +4463,7 @@ static int pictureflow_main(const char* selected_file)
/* Copy offscreen buffer to LCD and give time to other threads */ /* Copy offscreen buffer to LCD and give time to other threads */
if (is_initial_slide == false)
mylcd_update(); mylcd_update();
rb->yield(); rb->yield();