summaryrefslogtreecommitdiff
path: root/displaymenu.c
diff options
context:
space:
mode:
authorkamel5 <vdr.kamel5 (at) gmx (dot) net>2021-06-06 14:59:51 +0200
committerkamel5 <vdr.kamel5 (at) gmx (dot) net>2021-07-12 13:53:53 +0200
commitbde0fc5d1f2766c7376511a629b8667248242db1 (patch)
treedb6f1504a6688213f9cea6724df9083bf19bcfac /displaymenu.c
parent0d8dc799b8ffc13784ca80a62deae6b53cc655bc (diff)
downloadskin-nopacity-bde0fc5d1f2766c7376511a629b8667248242db1.tar.gz
skin-nopacity-bde0fc5d1f2766c7376511a629b8667248242db1.tar.bz2
Optimize Flush in display menu
These changes ensures that only one flush is active when the fade-in thread is running. The first Pixmap::Lock() in cNopacityDisplayMenu::Action() takes so much longer than the following, Thats why the first Pixmap::Lock() was moved before the while loop. This makes the fade-in softer. The DetailView thread was eliminated.
Diffstat (limited to 'displaymenu.c')
-rw-r--r--displaymenu.c100
1 files changed, 44 insertions, 56 deletions
diff --git a/displaymenu.c b/displaymenu.c
index 474969f..4c0c9af 100644
--- a/displaymenu.c
+++ b/displaymenu.c
@@ -33,10 +33,10 @@ cNopacityDisplayMenu::~cNopacityDisplayMenu(void) {
Cancel(-1);
while (Active())
cCondWait::SleepMs(10);
- if (detailView) {
+ if (detailView)
delete detailView;
- }
- delete menuView;
+ if (menuView)
+ delete menuView;
menuItems.clear();
timers.Clear();
delete osd;
@@ -109,9 +109,6 @@ void cNopacityDisplayMenu::DrawTimers(bool timersChanged, int numConflicts) {
int currentHeight = menuView->GetTimersInitHeight();
if (numConflicts > 0) {
cNopacityTimer *t = menuView->DrawTimerConflict(numConflicts, currentHeight);
- if (initial)
- if (FadeTime)
- t->SetAlpha(0);
currentHeight += t->GetHeight() + geoManager->menuSpace;
timers.Add(t);
}
@@ -120,9 +117,6 @@ void cNopacityDisplayMenu::DrawTimers(bool timersChanged, int numConflicts) {
if (const cTimer *Timer = SortedTimers[i]) {
if (Timer->HasFlags(tfActive)) {
cNopacityTimer *t = menuView->DrawTimer(Timer, currentHeight);
- if (initial)
- if (FadeTime)
- t->SetAlpha(0);
currentHeight += t->GetHeight() + geoManager->menuSpace;
if (currentHeight < maxTimersHeight) {
timers.Add(t);
@@ -257,6 +251,7 @@ void cNopacityDisplayMenu::SetMenuCategory(eMenuCategory MenuCategory) {
void cNopacityDisplayMenu::SetTitle(const char *Title) {
//resetting menuitems if no call to clear
+ DELETENULL(detailView);
menuItems.clear();
int left = 5;
menuView->DestroyHeaderIcon();
@@ -279,16 +274,16 @@ void cNopacityDisplayMenu::SetTitle(const char *Title) {
break;
case mcSchedule:
menuView->ShowHeaderLogo(false);
- left += menuView->ShowHeaderIconChannelLogo(Title);
+ left += menuView->ShowHeaderIconChannelLogo(Title, initial);
break;
case mcRecording:
menuView->ShowHeaderLogo(false);
title = cString::sprintf("%s (%s)", Title, *cVideoDiskUsage::String());
- left += menuView->DrawHeaderIcon(MenuCategory());
+ left += menuView->DrawHeaderIcon(MenuCategory(), initial);
break;
default:
menuView->ShowHeaderLogo(false);
- left += menuView->DrawHeaderIcon(MenuCategory());
+ left += menuView->DrawHeaderIcon(MenuCategory(), initial);
}
menuView->AdjustContentBackground(this->MenuCategory(), menuCategoryLast, videoWindowRect);
menuView->DrawHeaderLabel(left, title);
@@ -365,12 +360,7 @@ bool cNopacityDisplayMenu::SetItemEvent(const cEvent *Event, int Index, bool Cur
}
item->CreatePixmapStatic();
item->CreatePixmapTextScroller(textWidth);
- item->Render();
- if (initial) {
- if (FadeTime) {
- item->SetAlpha(0);
- }
- }
+ item->Render(initial);
} else {
cNopacityMenuItem *item = menuItems[Index].get();
item->SetCurrent(Current);
@@ -401,12 +391,7 @@ bool cNopacityDisplayMenu::SetItemTimer(const cTimer *Timer, int Index, bool Cur
}
item->CreatePixmapStatic();
item->CreatePixmapTextScroller(textWidth);
- item->Render();
- if (initial) {
- if (FadeTime) {
- item->SetAlpha(0);
- }
- }
+ item->Render(initial);
} else {
cNopacityMenuItem *item = menuItems[Index].get();
item->SetCurrent(Current);
@@ -437,12 +422,7 @@ bool cNopacityDisplayMenu::SetItemChannel(const cChannel *Channel, int Index, bo
if (config.GetValue("displayType") == dtGraphical) {
item->CreatePixmapForeground();
}
- item->Render();
- if (initial) {
- if (FadeTime) {
- item->SetAlpha(0);
- }
- }
+ item->Render(initial);
} else {
cNopacityMenuItem *item = menuItems[Index].get();
item->SetCurrent(Current);
@@ -475,12 +455,7 @@ bool cNopacityDisplayMenu::SetItemRecording(const cRecording *Recording, int Ind
if (config.GetValue("displayType") == dtGraphical) {
item->CreatePixmapForeground();
}
- item->Render();
- if (initial) {
- if (FadeTime) {
- item->SetAlpha(0);
- }
- }
+ item->Render(initial);
} else {
cNopacityMenuItem *item = menuItems[Index].get();
item->SetCurrent(Current);
@@ -533,12 +508,7 @@ void cNopacityDisplayMenu::SetItem(const char *Text, int Index, bool Current, bo
item->CreatePixmapStatic();
if (textWidth > 0)
item->CreatePixmapTextScroller(textWidth);
- item->Render();
- if (initial) {
- if (FadeTime) {
- item->SetAlpha(0);
- }
- }
+ item->Render(initial);
}
SetEditableWidth(menuView->GetEditableWidth());
}
@@ -630,8 +600,25 @@ void cNopacityDisplayMenu::SetText(const char *Text, bool FixedFont) {
detailView->Start();
}
+void cNopacityDisplayMenu::SetAlpha(int Alpha, bool Force) {
+ if (menuView && (Force || Running()))
+ menuView->SetAlpha(Alpha);
+ if (detailView && (Force || Running()))
+ detailView->SetAlpha(Alpha);
+ for (auto i = menuItems.begin(); i != menuItems.end(); ++i) {
+ if (*i && (Force || Running())) {
+ cNopacityMenuItem *item = i->get();
+ item->SetAlpha(Alpha);
+ }
+ }
+ for (cNopacityTimer *t = timers.First(); (Force || Running()) && t; t = timers.Next(t))
+ t->SetAlpha(Alpha);
+}
+
void cNopacityDisplayMenu::Flush(void) {
- //int start = cTimeMs::Now();
+ if (Running())
+ return;
+
menuView->DrawDate(initial);
if (MenuCategory() == mcMain) {
if (config.GetValue("showDiscUsage"))
@@ -643,34 +630,35 @@ void cNopacityDisplayMenu::Flush(void) {
if (config.GetValue("showTimers"))
DrawTimers(timersChanged, numConflicts);
}
+ if (detailView)
+ while (detailView->IsRunning())
+ cCondWait::SleepMs(10);
if (initial) {
- if (FadeTime)
+ if (FadeTime) {
+ SetAlpha(0, true);
Start();
+ }
}
- initial = false;
osd->Flush();
+ initial = false;
cDevice::PrimaryDevice()->ScaleVideo(videoWindowRect);
}
void cNopacityDisplayMenu::Action(void) {
+ uint64_t First = cTimeMs::Now();
+ cPixmap::Lock();
+ cPixmap::Unlock();
uint64_t Start = cTimeMs::Now();
+ dsyslog ("skinnopacity: First Lock(): %lims\n", Start - First);
while (Running()) {
uint64_t Now = cTimeMs::Now();
- cPixmap::Lock();
double t = std::min(double(Now - Start) / FadeTime, 1.0);
int Alpha = t * ALPHA_OPAQUE;
- menuView->SetAlpha(Alpha);
- for (auto i = menuItems.begin(); i != menuItems.end(); ++i) {
- if (*i && Running()) {
- cNopacityMenuItem *item = i->get();
- item->SetAlpha(Alpha);
- }
- }
- for (cNopacityTimer *t = timers.First(); Running() && t; t = timers.Next(t))
- t->SetAlpha(Alpha);
- cPixmap::Unlock();
+ cPixmap::Lock();
+ SetAlpha(Alpha);
if (Running())
osd->Flush();
+ cPixmap::Unlock();
int Delta = cTimeMs::Now() - Now;
if (Running() && (Delta < FrameTime))
cCondWait::SleepMs(FrameTime - Delta);