# HG changeset patch # User ib # Date 1395658135 0 # Node ID 97a4746e7888b413ceaf65d2812fd4601da131ac # Parent f11488e801a9e1b7da79131d7794d9a93ab85aa8 Utilize item defaults given in the skin configuration as start values. Do so for movie position, volume and balance (and hence show these values before playback). Add new btnValue() to retrieve the value and replace the btnModify() calls with btnValue() calls. (The btnModify() calls will be performed in the windows' draw handler prior to rendering anyway.) Initialize last_balance with -1 in order to be able to initialize balance (and volume) with the start values prior to playback (in GUI_SET_AUDIO). diff -r f11488e801a9 -r 97a4746e7888 gui/app/app.c --- a/gui/app/app.c Mon Mar 24 10:26:33 2014 +0000 +++ b/gui/app/app.c Mon Mar 24 10:48:55 2014 +0000 @@ -231,3 +231,21 @@ if (hasButton(guiApp.playbarItems[i])) guiApp.playbarItems[i].pressed = state; } + +/** + * @brief Retrieve the value of the (main) item belonging to an event. + * + * @param event event + * @param value pointer to a variable to store the value (if event has been found) + */ +void btnValue(int event, float *value) +{ + int i; + + for (i = 0; i <= guiApp.IndexOfMainItems; i++) + if (guiApp.mainItems[i].message == event) + if (hasValue(guiApp.mainItems[i]) && hasButton(guiApp.mainItems[i])) { + *value = guiApp.mainItems[i].value; + return; + } +} diff -r f11488e801a9 -r 97a4746e7888 gui/app/app.h --- a/gui/app/app.h Mon Mar 24 10:26:33 2014 +0000 +++ b/gui/app/app.h Mon Mar 24 10:48:55 2014 +0000 @@ -182,5 +182,6 @@ void appFreeStruct(void); void btnModify(int event, float value); void btnSet(int event, int state); +void btnValue(int event, float *value); #endif /* MPLAYER_GUI_APP_H */ diff -r f11488e801a9 -r 97a4746e7888 gui/interface.c --- a/gui/interface.c Mon Mar 24 10:26:33 2014 +0000 +++ b/gui/interface.c Mon Mar 24 10:48:55 2014 +0000 @@ -186,9 +186,12 @@ WinID = (Window)guiApp.videoWindow.WindowID; - btnModify(evSetVolume, guiInfo.Volume); - btnModify(evSetBalance, guiInfo.Balance); - btnModify(evSetMoviePosition, guiInfo.Position); + btnValue(evSetVolume, &guiInfo.Volume); + btnValue(evSetBalance, &guiInfo.Balance); + btnValue(evSetMoviePosition, &guiInfo.Position); + + if (guiInfo.Position) + uiEvent(evSetMoviePosition, guiInfo.Position); wsWindowVisibility(&guiApp.mainWindow, wsShowWindow); @@ -317,7 +320,7 @@ */ int gui(int what, void *data) { - static float last_balance = 50.0f; + static float last_balance = -1.0f; #ifdef CONFIG_DVDREAD dvd_priv_t *dvd; #endif @@ -709,6 +712,15 @@ guiInfo.VideoHeight = 0; } + if (last_balance < 0.0f) { + uiEvent(ivSetVolume, guiInfo.Volume); + + if (guiInfo.AudioChannels >= 2) + uiEvent(ivSetBalance, guiInfo.Balance); + + last_balance = guiInfo.Balance; + } + if (gtkEnableAudioEqualizer) { equalizer_t eq; unsigned int i, j;