From 5a01e129266afda8614b766147606e3d318fc89c Mon Sep 17 00:00:00 2001 From: basisbit Date: Mon, 14 Sep 2015 00:11:19 +0000 Subject: * added texts and English+German translation for JukeBox * write to log if a skin-texture can't be found / loaded * implemented search-feature in jukebox-mode similar to the search feature in normal mode * fixed bunch of bugs in jukebox mode that existed in usdx wp * jukebox mode: start playing full playlist when user presses enter after doing a search without results instead of crashing * repeat playlist by default in jukebox mode git-svn-id: svn://svn.code.sf.net/p/ultrastardx/svn/trunk@3137 b956fd51-792f-4845-bead-9b4dfca2ff2c --- game/languages/English.ini | 15 ++++ game/languages/German.ini | 15 ++++ src/base/UPath.pas | 3 +- src/base/USkins.pas | 2 +- src/screens/UScreenJukebox.pas | 157 ++++++++++++++++------------------------- 5 files changed, 94 insertions(+), 98 deletions(-) diff --git a/game/languages/English.ini b/game/languages/English.ini index 66815a7e..ebb44b1d 100644 --- a/game/languages/English.ini +++ b/game/languages/English.ini @@ -443,3 +443,18 @@ ERROR_CORRUPT_SONG_UNKNOWN_IN_LINE=Song could not be loaded: Error parsing line ERROR_NO_EDITOR=This feature is not available on Linux/Mac ERROR_PLAYER_DEVICE_ASSIGNMENT=Player %d is assigned to multiple microphones. Please check your record options ERROR_PLAYER_NO_DEVICE_ASSIGNMENT=Player %d is not assigned to a microphone. Please check your record options + +MSG_END_JUKEBOX=Do you want leave Jukebox Mode? +JUKEBOX_RANDOM=Random +JUKEBOX_REPEAT=Repeat +JUKEBOX_FIND=Find: +JUKEBOX_SORT=Sort: +JUKEBOX_SONGLIST=List of Songs + +JUKEBOX_OPTIONS_SONGPOSITION=CTRl+UP/DOWN: move song to up/down +JUKEBOX_OPTIONS_LYRIC=CTRL+L: On/Off Lyric +JUKEBOX_OPTIONS_REPEAT=CTRL+X: On/Off Playlist Repeat +JUKEBOX_OPTIONS_RANDOM=CTRL+R: Random Sort +JUKEBOX_OPTIONS_SORT=CTRL+S: Sort by Artist/Title/Edition/Genre/Language +JUKEBOX_OPTIONS_FIND=CTRL+F: On/Off Song Search + diff --git a/game/languages/German.ini b/game/languages/German.ini index 2a2fbea9..b0ffc6ec 100644 --- a/game/languages/German.ini +++ b/game/languages/German.ini @@ -443,3 +443,18 @@ ERROR_NO_EDITOR=Diese Funktion ist unter Linux/Mac noch nicht verfügbar ERROR_PLAYER_DEVICE_ASSIGNMENT=Mehrere Mikrofone für Spieler %d gewählt.\nAufnahmeoptionen überprüfen. ERROR_PLAYER_NO_DEVICE_ASSIGNMENT=Kein Mikrofon für Spieler %d gewählt.\nAufnahmeoptionen überprüfen. ;UNUSED: SING_OPTIONS_ADVANCED_COUNT_HOW_OFTEN_SUNG=Wie oft gesungen mitzählen + +MSG_END_JUKEBOX=JokeBox Modus beenden? +JUKEBOX_RANDOM=Zufall +JUKEBOX_REPEAT=Wiederholen +JUKEBOX_FIND=Suche +JUKEBOX_SORT=Sortierung: +JUKEBOX_SONGLIST=Liederliste + +JUKEBOX_OPTIONS_SONGPOSITION=CTRl+UP/DOWN: Songwahl hoch/runter +JUKEBOX_OPTIONS_LYRIC=CTRL+L: An/Aus Liedtext +JUKEBOX_OPTIONS_REPEAT=CTRL+X: An/Aus Wiedergabeliste wiederhoen +JUKEBOX_OPTIONS_RANDOM=CTRL+R: Zufällige Sortierung +JUKEBOX_OPTIONS_SORT=CTRL+S: Sortieren nach Künstler/Titel/Edition/Genre/Sprache +JUKEBOX_OPTIONS_FIND=CTRL+F: An/Aus Song-Suche + diff --git a/src/base/UPath.pas b/src/base/UPath.pas index 77ccd65d..6708262f 100644 --- a/src/base/UPath.pas +++ b/src/base/UPath.pas @@ -36,6 +36,7 @@ interface uses SysUtils, Classes, + TntSysUtils, IniFiles, {$IFDEF MSWINDOWS} TntClasses, @@ -667,7 +668,7 @@ begin if (IsNativeUTF8()) then Result := fName else - Result := Utf8ToAnsi(fName); + Result := Utf8ToAnsi(fName); //basisbit hackyhack - rteverted already end; function TPathImpl.GetDrive(): IPath; diff --git a/src/base/USkins.pas b/src/base/USkins.pas index a909b081..6d8c2ebf 100644 --- a/src/base/USkins.pas +++ b/src/base/USkins.pas @@ -187,7 +187,7 @@ begin if (TextureName <> '') and (Result.IsSet) then begin //Log.LogError('', '-----------------------------------------'); - //Log.LogError(TextureName+' - '+ Result, 'TSkin.GetTextureFileName'); + Log.LogError('Was not able to retrieve Texture for ' + TextureName + ' - ' + Result.ToNative, 'TSkin.GetTextureFileName'); end; end; diff --git a/src/screens/UScreenJukebox.pas b/src/screens/UScreenJukebox.pas index d282d979..ae0eacad 100644 --- a/src/screens/UScreenJukebox.pas +++ b/src/screens/UScreenJukebox.pas @@ -614,19 +614,19 @@ begin // allow search for songs Ord('J'): begin - LastTick := SDL_GetTicks(); - FindSongList := not FindSongList; - if (Filter = '') then + if (SongListVisible) then begin - if (FindSongList) then - Button[JukeboxFindSong].Text[0].Text := ''; + LastTick := SDL_GetTicks(); + FindSongList := not FindSongList; + if (Filter = '') and (FindSongList) then + Button[JukeboxFindSong].Text[0].Text := ''; + Button[JukeboxFindSong].SetSelect(FindSongList); + if FindSongList then + FilterSongList(Filter) + else + FilterSongList(''); + Exit; end; - Button[JukeboxFindSong].SetSelect(FindSongList); - if FindSongList then - FilterSongList(Filter) - else - FilterSongList(''); - Exit; end; //Randomixe Playlist @@ -758,7 +758,14 @@ begin SDLK_ESCAPE: begin if (SongListVisible) then - SongListVisible := false + begin + SongListVisible := false; + FindSongList := false; + Button[JukeboxFindSong].SetSelect(FindSongList); + Filter:= ''; + FilterSongList(''); + Button[JukeboxFindSong].Text[0].Text := ''; + end else ScreenPopupCheck.ShowPopup('MSG_END_JUKEBOX', OnEscapeJukebox, nil, false) end; @@ -769,6 +776,12 @@ begin if (FindSongList) and (SongListVisible) then begin LastTick := SDL_GetTicks(); + if (Filter = '') then + begin + FindSongList:=false; + Button[JukeboxFindSong].SetSelect(FindSongList); + Exit; + end; Button[JukeboxFindSong].Text[0].DeleteLastLetter(); Filter := Button[JukeboxFindSong].Text[0].Text; FilterSongList(Filter); @@ -795,20 +808,24 @@ begin if (SongListVisible) then begin LastTick := SDL_GetTicks(); + if (FindSongList) then + begin + FindSongList:=false; + Button[JukeboxFindSong].SetSelect(FindSongList); + end; + if (High(JukeboxVisibleSongs) < 0) then + begin + FilterSongList(''); + end; CurrentSongList := ActualInteraction - 1; Finish; PlayMusic(CurrentSongList); end; + end; SDLK_LEFT: begin - {if not (SongListVisible) and (CurrentSongList > 0) then - begin - CurrentSongList := CurrentSongList - 2; - PlayMusic(CurrentSongList); - end; - } if (SDL_ModState = KMOD_LSHIFT) then begin fCurrentVideo.GetScreenPosition(X, Y, Z); @@ -823,21 +840,12 @@ begin SDLK_RIGHT: begin - { - if not (SongListVisible) and (CurrentSongList < High(JukeboxVisibleSongs)) then - begin - CurrentSongList := CurrentSongList + 1; - PlayMusic(CurrentSongList); - end; - } - if (SDL_ModState = KMOD_LSHIFT) then begin fCurrentVideo.GetScreenPosition(X, Y, Z); fCurrentVideo.SetScreenPosition(X - 2, Y, Z); fCurrentVideo.SetWidth(fCurrentVideo.GetWidth + 4); end; - end; SDLK_DELETE: @@ -848,51 +856,6 @@ begin end; end; - SDLK_PAGEDOWN: - begin - {if (SongListVisible) and ((ActualInteraction + 10) < High(JukeboxVisibleSongs)) then - begin - - LastTick := SDL_GetTicks(); - - // TODO: BUG AT END - if (ListMin + 10 < High(JukeboxVisibleSongs) - 9 + Interaction) then - begin - ListMin := ListMin + 10; - ActualInteraction := ActualInteraction + 10; - end - else - begin - ListMin := High(JukeboxVisibleSongs) - 9 + Interaction; - ActualInteraction := High(JukeboxVisibleSongs) - 9 + Interaction; - end; - - end;} - end; - - SDLK_PAGEUP: - begin - { - if (SongListVisible) and (ActualInteraction - 9 > 0) then - begin - if (ListMin > 10) then - ListMin := ListMin - 10 - else - ListMin := 0; - - ActualInteraction := ActualInteraction - 10; - - if (ActualInteraction < 10) then - Interaction := ActualInteraction; - - LastTick := SDL_GetTicks(); - end;} - end; - - // up and down could be done at the same time, - // but i don't want to declare variables inside - // functions like this one, called so many times - SDLK_DOWN: begin if (SongListVisible) then @@ -1107,9 +1070,10 @@ begin JukeboxSongListOrder := AddButton(Theme.Jukebox.SongListOrder); JukeboxRandomSongList := AddButton(Theme.Jukebox.RandomSongList); JukeboxLyric := AddButton(Theme.Jukebox.Lyric); + RepeatSongList := true; Button[JukeboxFindSong].Selectable := false; - Button[JukeboxRepeatSongList].Selectable := false; + Button[JukeboxRepeatSongList].Selectable := true; Button[JukeboxSongListOrder].Selectable := false; Button[JukeboxRandomSongList].Selectable := false; Button[JukeboxLyric].Selectable := false; @@ -1405,7 +1369,7 @@ begin begin if (RepeatSongList) then begin - // resyart playlist + // restart playlist CurrentSongList := 0; CatSongs.Selected := JukeboxVisibleSongs[CurrentSongList]; PlayMusic(CurrentSongList); @@ -1705,8 +1669,8 @@ begin Lyrics.AddLine(@Lines[0].Line[Lyrics.LineCounter]); end; - Text[JukeboxTextSongText].Visible := true; - Text[JukeboxTextSongText].Text := CurrentSong.Artist + ' - ' + CurrentSong.Title; + //Text[JukeboxTextSongText].Visible := true; + //Text[JukeboxTextSongText].Text := CurrentSong.Artist + ' - ' + CurrentSong.Title; Max := 9; @@ -1769,31 +1733,32 @@ begin Button[JukeboxRepeatSongList].Draw; Button[JukeboxRandomSongList].Draw; Button[JukeboxLyric].Draw; + try + for I := 0 to Max do + begin + Button[SongDescription[I]].Visible := true; + Button[SongDescription[I]].Selectable := true; - for I := 0 to Max do - begin - Button[SongDescription[I]].Visible := true; - Button[SongDescription[I]].Selectable := true; + SongDesc := CatSongs.Song[JukeboxVisibleSongs[I + ListMin]].Artist + ' - ' + CatSongs.Song[JukeboxVisibleSongs[I + ListMin]].Title; - SongDesc := CatSongs.Song[JukeboxVisibleSongs[I + ListMin]].Artist + ' - ' + CatSongs.Song[JukeboxVisibleSongs[I + ListMin]].Title; + if (JukeboxVisibleSongs[I + ListMin] = CurrentSongID) and (I + ListMin <> ActualInteraction) then + begin + Button[SongDescription[I]].Text[0].ColR := SelectColR; + Button[SongDescription[I]].Text[0].ColG := SelectColG; + Button[SongDescription[I]].Text[0].ColB := SelectColB; + end + else + begin + Button[SongDescription[I]].Text[0].ColR := 1; + Button[SongDescription[I]].Text[0].ColG := 1; + Button[SongDescription[I]].Text[0].ColB := 1; + end; - if (JukeboxVisibleSongs[I + ListMin] = CurrentSongID) and (I + ListMin <> ActualInteraction) then - begin - Button[SongDescription[I]].Text[0].ColR := SelectColR; - Button[SongDescription[I]].Text[0].ColG := SelectColG; - Button[SongDescription[I]].Text[0].ColB := SelectColB; - end - else - begin - Button[SongDescription[I]].Text[0].ColR := 1; - Button[SongDescription[I]].Text[0].ColG := 1; - Button[SongDescription[I]].Text[0].ColB := 1; + Button[SongDescription[I]].Text[0].Text := SongDesc; + Button[SongDescription[I]].Draw; end; - - Button[SongDescription[I]].Text[0].Text := SongDesc; - Button[SongDescription[I]].Draw; + finally end; - end; end. -- cgit v1.2.3