From: Jakob Haufe
Date: Mon, 6 Aug 2012 20:31:37 +0000 (+0200)
Subject: Imported Upstream version 1.3
X-Git-Tag: upstream/1.3
X-Git-Url: https://git.sur5r.net/?a=commitdiff_plain;h=608a65854915b5cf36ea7b6f92c412be27e22061;p=minitube
Imported Upstream version 1.3
---
diff --git a/CHANGES b/CHANGES
index eac32b8..ee7cef5 100644
--- a/CHANGES
+++ b/CHANGES
@@ -1,8 +1,17 @@
+1.3 - Dec 10, 2010
+- Minitube works again!
+- Big internal changes in how playback works, seeking is now disabled on Linux
+- Brand new icon designed by David Nel
+- Using Qt/Cocoa on the Mac, now requiring Leopard or better
+- New Macedonian translation by Veta Branislav
+- Updated Finnish translation
+- New german translation by Jakob Kramer
+
1.2 - Oct 11, 2010
- Ability to download videos
- Support for media keys on GNOME
- More style, especially on the Mac
-- Fixed crash when trying delete or move the the las playlist item
+- Fixed crash when trying delete or move the the last playlist item
1.1 - Jul 27, 2010
- Minitube now correctly plays cat and mouse with YouTube
diff --git a/data/128x128/minitube.png b/data/128x128/minitube.png
index d46188e..44f4add 100644
Binary files a/data/128x128/minitube.png and b/data/128x128/minitube.png differ
diff --git a/data/16x16/minitube.png b/data/16x16/minitube.png
index c785c2b..ab0d477 100644
Binary files a/data/16x16/minitube.png and b/data/16x16/minitube.png differ
diff --git a/data/22x22/minitube.png b/data/22x22/minitube.png
index bcb2a97..9e4df12 100644
Binary files a/data/22x22/minitube.png and b/data/22x22/minitube.png differ
diff --git a/data/256x256/minitube.png b/data/256x256/minitube.png
index 5a2a186..38c2c30 100644
Binary files a/data/256x256/minitube.png and b/data/256x256/minitube.png differ
diff --git a/data/32x32/minitube.png b/data/32x32/minitube.png
index 7d8d63a..27aed8b 100644
Binary files a/data/32x32/minitube.png and b/data/32x32/minitube.png differ
diff --git a/data/48x48/minitube.png b/data/48x48/minitube.png
index aeb6f11..398e2c3 100644
Binary files a/data/48x48/minitube.png and b/data/48x48/minitube.png differ
diff --git a/data/512x512/minitube.png b/data/512x512/minitube.png
index 1d1d0ed..77cfb03 100644
Binary files a/data/512x512/minitube.png and b/data/512x512/minitube.png differ
diff --git a/data/64x64/minitube.png b/data/64x64/minitube.png
index 674a03d..3afc57b 100644
Binary files a/data/64x64/minitube.png and b/data/64x64/minitube.png differ
diff --git a/data/minitube.svg b/data/minitube.svg
index 5d2670d..dfe72b1 100644
--- a/data/minitube.svg
+++ b/data/minitube.svg
@@ -1,5 +1,6 @@
+
diff --git a/images/app.png b/images/app.png
index 18961b3..44f4add 100644
Binary files a/images/app.png and b/images/app.png differ
diff --git a/locale/de_DE.ts b/locale/de_DE.ts
index d491dd7..b69915b 100644
--- a/locale/de_DE.ts
+++ b/locale/de_DE.ts
@@ -7,47 +7,59 @@
- Es gibt Leben auÃerhalb des Browsers!
+ Es existiert Leben neben dem Browser!
Version %1
+
+
+ Dies ist eine "Technology Vorschau", erwarte nicht, dass sie perfekt ist.
+
- Berichten Sie Fehler und senden Sie Ihre Ideen an %1
+ Bitte berichte Fehler und sende Deine Ideen an %1
%1 ist freie Software, aber die Entwicklung kostet wertvolle Zeit.
+
+
+ Bitte <a href='%1'>spende via PayPal</a> um die dauerhafte Entwicklung von %2 zu unterstützen.
+
- Bitte <a href='%1'>spenden</a> Sie um die ständige Entwicklung von %2 zu unterstützen.
+ Bitte <a href='%1'>spende</a>, um die ständige Entwicklung von %2 zu unterstützen.
- Icon entworfen von %1.
+ Symbol-Entwurf durch %1.
- Kompakt-Ansicht beigetragen von %1.
+ Kompakt-Modus beigetragen von %1.
- HTTP-Proxy Unterstützung beigetragen von %1.
+ HTTP Proxy-Unterstützung beigetragen von %1.
+
+
+
+ Windows Version erstellt durch %1
- Ãbersetzt von %1
+ Ãbersetzung durch %1
@@ -67,7 +79,7 @@
- Was Sie schon immer über %1 wissen wollten, aber nie zu fragen wagten
+ Was Du schon immer über %1 wissen wolltest, aber nie zu fragen wagtest
@@ -75,7 +87,7 @@
- Löschen
+ Säubern
@@ -85,30 +97,30 @@
Bytes
-
-
-
- Bytes/s
-
-
- KiB
+
+ kB
-
- MiB
+
+ MB
+
+
+
+
+ Bytes/s
-
- KiB/s
+
+ kB/s
-
- MiB/s
+
+ MB/s
@@ -131,12 +143,12 @@
- Dies ist nur eine Demoversion von %1.
+ Dies ist nur die Demoversion von %1.
- Sie kann nur Videos herunterladen, die kürzer als %1 Minuten sind, damit Sie diese Funktion testen können.
+ Sie kann nur Videos die kürzer als %1 Minuten sind herunterladen, damit die Download-Funktionalität getestet werden kann.
@@ -146,7 +158,7 @@
- Volle Version herunterladen
+ Die Vollversion holen
@@ -162,27 +174,27 @@
- Pfad ändern...
+ Speicherort ändernâ¦
- Download-Verzeichnis auswählen
+ Wähle den Speicherort
- Download-Verzeichnis geändert.
+ Speicherort wurde verändert.
- Bereits laufende Downloads bleiben weiterhin im alten Verzeichnis.
+ Aktuelle Downloads werden immernoch im alten Speicherort gespeichert.
- Speichere in: %1
+ Lade herunter nach: %1
@@ -204,22 +216,22 @@
- Pausieren
+ Pause
- Wiedergeben/Pausieren
+ Abspielen/Pause
- Anhalten
+ Halt
- Wiedergabe nach aktuellem Titel anhalten
+ Nachdem aktueller Titel abgespielt wurde halten
@@ -244,17 +256,17 @@
- Stumm schalten
+ Stummschalten
- Vorspulen
+ Vorwärts spulen
- Zurückspulen
+ Rückwärts spulen
@@ -290,15 +302,23 @@
MainWindow
+
+
+ &Zurück
+
+
+
+ Gehe zur vorherigen Ansicht
+
- An&alten
+ &Halt
- Wiedergabe anhalten und zurück zur Suchansicht
+ Wiedergabe anhalten und zur Suchansicht zurückkehren
@@ -308,7 +328,7 @@
- Springe zum nächsten Video
+ Zum nächsten Video springen
@@ -333,6 +353,26 @@
Vollbildmodus aktivieren
+
+
+ &Kompakt Ansicht
+
+
+
+ Kompakt Ansicht aktivieren
+
+
+
+ &YouTube
+
+
+
+ Ãffne die YouTube Video Seite
+
+
+
+ Ctrl+Y
+
@@ -346,37 +386,45 @@
- &Herunterladen
+ H&erunterladen
+
+
+
+ Dieses Video herunterladen
+
+
+
+ Strg+S
- Ãffne die &YouTube Seite
+ Ãffne die &YouTube-Seite
- Gehe zur YouTube Video Seite und pausiere die Wiedergabe
+ Gehe zur YouTube-Video-Seite und pausiere die Wiedergabe
- YouTube &Link kopieren
+ YouTube-&Link kopieren
- YouTube Link in die Zwischenablage kopieren
+ YouTube-Link in die Zwischenablage kopieren
- Video &URL kopieren
+ Video-&URL kopieren
- Video URL in die Zwischenablage kopieren
+ Video-URL in die Zwischenablage kopieren
@@ -396,7 +444,7 @@
- Bewerge das ausgewählte Video in der Abspielliste hinauf
+ Bewege das ausgewählte Video in der Abspielliste hinauf
@@ -416,7 +464,7 @@
- Such-Chronik löschen. Kann nicht rückgängig gemacht werden.
+ Such-Verlauf leeren. Kann nicht rückgängig gemacht werden.
@@ -426,7 +474,7 @@
- Ctrl+Q
+ Strg+Q
@@ -441,12 +489,12 @@
- %1 im Internet
+ %1 im Web
- Eine Spen&de machen
+ Spen&den
@@ -457,47 +505,51 @@
- Details über Video-Downloads zeigen
+ Zeige Details über Video-Downloads
- Video herunterladen
+ Das aktuelle Video herunterladen
- Wollen Sie %1 mit einem aktivem Download beenden?
+ Möchtest Du %1 mit einem aktiven Download beenden?
- Wenn Sie %1 beenden, wird das Herunterladen abgebrochen.
+ Wenn Du %1 jetzt beendest, wird der Download abgebrochen.
- Beenden und Herunterladen abbrechen
+ Beenden und Download abbrechen
- Warten, bis das Herunterladen abgeschlossen ist
+ Auf Abschluà des Downloads warten
- Maximale Videoauflösung wurde auf %1 gesetzt
+ Maximale Video-Auflösung wurde auf %1 gesetzt
- Downloads abgeschlossen
+ Downloads heruntergeladen
+
+
+
+ Spen&den via PayPal
- Bitte unterstützen Sie die fortwährende Entwicklung von %1
+ Bitte unterstütze die weitere Entwicklung von %1
@@ -517,7 +569,7 @@
- Ton stumm schalten
+ Stummschalten
@@ -534,10 +586,58 @@
Verbleibende Zeit: %1
+
+
+ High Definition Video ist eingeschaltet
+
+
+
+ High Definition Video ist nicht eingeschaltet
+
+
+
+ Das derzeitige Video ist in High Definition
+
+
+
+ Das derzeitige Video ist nicht in High Definition
+
- Ihre Privatsphäre ist nun geschützt
+ Deine Privatsphäre ist nun geschützt
+
+
+
+ Es wird kein Video abgespielt
+
+
+
+ Du musst das Video erst abspielen !
+
+
+
+ Video speichern unter...
+
+
+
+ minitube video.mp4
+
+
+
+ Herunterladen:
+
+
+
+ Herunterladen abbrechen
+
+
+
+ Das anlegen der Datei ist fehlgeschlagen
+
+
+
+ Herunterladen fehlgeschlagen
@@ -547,12 +647,16 @@
- Ton ist stumm geschaltet
+ Ton ist stummgeschaltet
- Stummschaltung deaktiviert
+ Ton ist angeschaltet
+
+
+
+ &Suche
@@ -562,7 +666,7 @@
- &Abspielliste
+ A&bspielliste
@@ -611,12 +715,12 @@
- Die bedeutsamsten
+ Die Bedeutsamsten
- Die neusten
+ Die Neusten
@@ -626,12 +730,12 @@
- Sie können nun den YouTube Link in einer anderen Anwendung einfügen
+ Du kannst den YouTube-Link nun in einer anderen Anwendung einfügen
- Sie können nun die Video URL in einer anderen Anwendung einfügen
+ Du kannst die Video-URL nun in einer anderen Anwendung einfügen
@@ -646,7 +750,7 @@
- Es gibt Ihnen die Möglichkeit das Programm zu testen und zu sehen, ob es funktioniert.
+ Sie erlaubt Dir die Anwendung zu testen und zu schauen ob es bei Dir läuft.
@@ -656,7 +760,7 @@
- Volle Version herunterladen
+ Die Vollversion holen
@@ -666,7 +770,7 @@
- Sie betrachten "%1"
+ Du betrachtest "%1"
@@ -687,12 +791,12 @@
- %1 von %2 (%3) ? %4
+ %1 von %2 (%3) â %4
- Initialisiere
+ Bereite vor
@@ -702,27 +806,27 @@
- Abgeschlossen
+ Fertiggestellt
- Abgebrochen
+ Gestoppt
- Herunterladen abbrechen
+ Stoppe herunterladen
-
+ Zeige in %1
- Beinhaltenden Ordner öffnen
+ Eltern-Ordner öffnen
@@ -758,7 +862,7 @@
- Kürzlich verwendete Schlüsselwörter
+ Aktuelle Schlüsselwörter
@@ -768,7 +872,18 @@
- Machen Sie es sich gemütlich
+ Mach es Dir gemütlich
+
+
+
+ SettingsView
+
+
+ Einstellungen
+
+
+
+ S&chlieÃen
@@ -776,7 +891,7 @@
- Netzwerk Fehler: %1 für %2
+ Netzwerk-Fehler: %1 für %2
diff --git a/locale/fi_FI.ts b/locale/fi_FI.ts
index 061d14d..dde17fe 100644
--- a/locale/fi_FI.ts
+++ b/locale/fi_FI.ts
@@ -68,146 +68,146 @@
DownloadItem
-
+ tavua
-
+ Kt
-
+ Mt
-
+ tavua/sekunnissa
-
+ Kt/s
-
+ Mt/s
-
+ sekunttia
-
+ minuuttia
-
+ %4 %5 jäljellä
DownloadManager
-
-
+
+ %n Lataus(ta)
-
+ Tämä on vain kokeilu versio %1sta.
-
+ Voit ladata vain videoita jotka ovat lyhyempiä kuin %1 minuuttia, jotta voit testata lataus ominaisuutta.
-
+ Jatka
-
+ Hanki täysi versio
DownloadSettings
-
+ Vaihda sijaintia...
-
+ Valitse latausten sijainti
-
+ Lataus sijaintia on muutettu.
-
+ Nykyiset lataukset menevät vanhaan sijaintiin.
-
+ Ladataan kansioon: %1
DownloadView
-
+ Lataukset
GlobalShortcuts
-
+ Toista
-
+ Keskeytä
-
+ Toista/Keskeytä
-
+ Pysäytä
-
+ Pysäytä toisto nykyisen kappaleen jälkeen
-
+ Seuraava kappale
-
+ Edellinen kappale
-
+ Lisää äänen voimakkuutta
-
+ Vähennä äänen voimakkuutta
-
+ Mykistä
-
+ Kelaa eteenpäin
-
+ Kelaa taaksepäin
@@ -452,39 +452,39 @@
-
+ &Lataukset
-
+ Näytä tietoja latauksista
-
+ &Lataa
-
+ Lataa nykyinen video
-
+ Tahdotko lopettaa vaikka %1 lataus(ta) on kesken?
-
+ Jos suljet %1n nyt niin tämä lataus keskeytetään.
-
+ Sulje ja keskeytä lataus
-
+ Odota latauksen valmistumista
-
+ Lataukset ovat valmistuneet
@@ -519,23 +519,23 @@
-
+ Tämä on vain %1n kokeiluversio.
-
+ Voit kokeilla ohjelmaa nähdäksesi että toimiiko se.
-
+ Jatka
-
+ Hanki täysi versio
-
+ Ladataan %1ta/tä
@@ -553,39 +553,39 @@
-
+ %1 %2 (%3)sta ? %4
-
+ Valmistellaan
-
+ Epäonnistui
-
+ Valmis
-
+ Pysäytetty
-
+ Pysäytä lataus
-
+ Avaa %1ssa/ssä
-
+ Avaa yläkansio
-
+ Käynnistä lataus uudelleen
diff --git a/locale/locale.pri b/locale/locale.pri
index 77a2f13..e3d47fa 100644
--- a/locale/locale.pri
+++ b/locale/locale.pri
@@ -29,7 +29,8 @@ TRANSLATIONS += \
pt_PT.ts \
fi_FI.ts \
bg_BG.ts \
- zh_CN.ts
+ zh_CN.ts \
+ mkd_MKD.ts
isEmpty(QMAKE_LRELEASE) {
win32:QMAKE_LRELEASE = $$[QT_INSTALL_BINS]\lrelease.exe
diff --git a/locale/mkd_MKD.ts b/locale/mkd_MKD.ts
new file mode 100644
index 0000000..09a8099
--- /dev/null
+++ b/locale/mkd_MKD.ts
@@ -0,0 +1,447 @@
+
+
+
+
+
+
+
+ AboutView
+ Ðма Ð¶Ð¸Ð²Ð¾Ñ Ð¸ Ð½Ð°Ð´Ð²Ð¾Ñ Ð¾Ð´ бÑаÑзеÑоÑ!
+
+
+
+ AboutView
+ ÐеÑзиÑа %1
+
+
+
+ AboutView
+ %1 е Слободен СоÑÑвеÑ, но Ð½ÐµÐ³Ð¾Ð²Ð¸Ð¾Ñ ÑÐ°Ð·Ð²Ð¾Ñ Ð¾Ð´Ð·ÐµÐ¼Ð° дÑагоÑено вÑеме.
+
+
+
+ AboutView
+ Ðе молам <a href='%1'>дониÑаÑÑе</a> за да го поддÑжиÑе понаÑамоÑÐ½Ð¸Ð¾Ñ ÑÐ°Ð·Ð²Ð¾Ñ Ð½Ð° %2.
+
+
+
+ AboutView
+ ÐзвеÑÑÑваÑÑе за гÑеÑки и иÑпÑаÑаÑÑе ги ваÑиÑе идеи на %1
+
+
+
+ AboutView
+ ÐкониÑе Ñе изÑабоÑени од %1.
+
+
+
+ AboutView
+ ÐомпакÑÐ½Ð¸Ð¾Ñ Ñежим е обÑавен од %1.
+
+
+
+ AboutView
+ HTTP proxy поддÑжкаÑа е обÑавена од %1.
+
+
+
+ AboutView
+ ÐÑеведено од %1
+
+
+
+ AboutView
+ ÐбÑавено е под <a href='%1'>GNU General Public License</a>
+
+
+
+ AboutView
+ &ÐаÑвоÑи
+
+
+
+ AboutView
+ Ðа
+
+
+
+ AboutView
+ ШÑо одÑÐµÐºÐ¾Ð³Ð°Ñ ÑÑе Ñакале да знаеÑе за %1 но Ð½Ð¸ÐºÐ¾Ð³Ð°Ñ Ð½Ðµ ÑÑе Ñе оÑмелиле да пÑаÑаÑе
+
+
+
+ ClearButton
+ ÐÑÑиÑÑи
+
+
+
+ ListModel
+ ÐÑебаÑÑваÑе...
+
+
+
+ ListModel
+ ÐÑикажи %1 повеÑе
+
+
+
+ ListModel
+ Ðема видео
+
+
+
+ ListModel
+ Ðема повеÑе видеа
+
+
+
+ LoadingWidget
+ ÐÑеÑка
+
+
+
+ MainWindow
+ &СÑоп
+
+
+
+ MainWindow
+ СÑопиÑÐ°Ñ Ñа ÑепÑодÑкÑиÑаÑа и вÑаÑи Ñе во пÑебаÑÑваÑоÑ
+
+
+
+ MainWindow
+ Ð&ÑеÑкокни
+
+
+
+ MainWindow
+ Следно видео
+
+
+
+ MainWindow
+ &ÐаÑза
+
+
+
+ MainWindow
+ ÐаÑзиÑÐ°Ñ Ñа ÑепÑодÑкÑиÑаÑа
+
+
+
+ MainWindow
+ &Цел ÐкÑан
+
+
+
+ MainWindow
+ ÐÑвоÑи на Ñел екÑан
+
+
+
+ MainWindow
+ &ÐомпакÑен Ñежим
+
+
+
+ MainWindow
+ СокÑÐ¸Ñ Ñа плеÑлиÑÑаÑа и ленÑаÑа Ñо алаÑки
+
+
+
+ MainWindow
+ ÐÑвоÑи Ñа &YouTube ÑÑÑаниÑаÑа
+
+
+
+ MainWindow
+ ÐÑиди на YouTube ÑÑÑаниÑаÑа и паÑзиÑÐ°Ñ Ñа ÑепÑодÑкÑиÑаÑа
+
+
+
+ MainWindow
+ ÐопиÑÐ°Ñ Ð³Ð¾ YouTube &линкоÑ
+
+
+
+ MainWindow
+ ÐопиÑÐ°Ñ Ð³Ð¾ видео Ð»Ð¸Ð½Ð¾Ñ Ð¾Ð´ YouTube во клипбодоÑ
+
+
+
+ MainWindow
+ ÐопиÑÐ°Ñ Ð³Ð¾ &URL-Ñо на видео емиÑÑваÑеÑо
+
+
+
+ MainWindow
+ ÐопиÑÐ°Ñ Ð³Ð¾ URL-Ñо на гледаноÑо видео во клипбоÑдоÑ
+
+
+
+ MainWindow
+ &ÐÑÑÑÑани
+
+
+
+ MainWindow
+ ÐÑÑÑÑанеÑе ги избÑаниÑе видеа од плеÑлиÑÑаÑа
+
+
+
+ MainWindow
+ ÐÑидвижи &нагоÑе
+
+
+
+ MainWindow
+ ÐÑемеÑÑи ги избÑаниÑе видеа во плеÑлиÑÑаÑа
+
+
+
+ MainWindow
+ ÐÑидвижи &надолÑ
+
+
+
+ MainWindow
+ ÐÑемеÑÑи ги Ð½Ð°Ð´Ð¾Ð»Ñ Ð²Ð¾ плеÑлиÑÑаÑа избÑаниÑе видеа
+
+
+
+ MainWindow
+ &ÐÑÑиÑÑи ги поÑледниве клÑÑни збоÑови
+
+
+
+ MainWindow
+ ÐÑÑиÑÑи Ñа иÑÑоÑиÑаÑа од пÑебаÑÑваÑеÑо.Ðеможе да Ñе назад.
+
+
+
+ MainWindow
+ &Ðзлез
+
+
+
+ MainWindow
+ Ctrl+Q
+
+
+
+ MainWindow
+ Чао
+
+
+
+ MainWindow
+ &Ðеб ÑÑÑана
+
+
+
+ MainWindow
+ %1 на Ðеб
+
+
+
+ MainWindow
+ ÐапÑави &донаÑиÑа
+
+
+
+ MainWindow
+ Ðе молам подпомогнеÑе го Ð¸Ð´Ð½Ð¸Ð¾Ñ ÑÐ°Ð·Ð²Ð¾Ñ Ð½Ð° %1
+
+
+
+ MainWindow
+ &Ðа
+
+
+
+ MainWindow
+ ÐнÑоÑмаÑиÑа за %1
+
+
+
+ MainWindow
+ ÐÑебаÑÑваÑе
+
+
+
+ MainWindow
+ ÐÑекини го звÑкоÑ
+
+
+
+ MainWindow
+ Ctrl+M
+
+
+
+ MainWindow
+ &ÐпликаÑиÑа
+
+
+
+ MainWindow
+ &ÐлеÑлиÑÑа
+
+
+
+ MainWindow
+ &Ðидео
+
+
+
+ MainWindow
+ &ÐомоÑ
+
+
+
+ MainWindow
+ ÐÑиÑиÑни %1 за да го Ð·Ð³Ð¾Ð»ÐµÐ¼Ð¸Ñ Ð·Ð²ÑкоÑ, %2 да го намалиÑ
+
+
+
+ MainWindow
+ Се оÑваÑа %1
+
+
+
+ MainWindow
+ ФаÑална гÑеÑка: %1
+
+
+
+ MainWindow
+ ÐÑеÑка: %1
+
+
+
+ MainWindow
+ &ÐÑÑÑи
+
+
+
+ MainWindow
+ ÐÑодолжи Ñо ÑепÑодÑкÑиÑа
+
+
+
+ MainWindow
+ Ðзлези од &Цел екÑан
+
+
+
+ MainWindow
+ ÐÑÑанаÑо вÑеме: %1
+
+
+
+ MainWindow
+ ÐвÑк на %1%
+
+
+
+ MainWindow
+ ÐвÑÐºÐ¾Ñ Ðµ иÑклÑÑен
+
+
+
+ MainWindow
+ ÐвÑÐºÐ¾Ñ Ðµ вклÑÑен
+
+
+
+ MainWindow
+ ÐакÑималнаÑа видео ÑезолÑÑиÑа е поÑÑавена на %1
+
+
+
+ MainWindow
+ ÐаÑаÑа пÑиваÑноÑÑ Ðµ заÑÑиÑена
+
+
+
+ MediaView
+ ÐаÑÑелеванÑни
+
+
+
+ MediaView
+ ÐаÑновиÑе
+
+
+
+ MediaView
+ ÐаÑÐ¼Ð½Ð¾Ð³Ñ Ð³Ð»ÐµÐ´Ð°Ð½Ð¸
+
+
+
+ MediaView
+ Ðоже да го вмеÑнеÑе YouTube Ð»Ð¸Ð½ÐºÐ¾Ñ Ð²Ð¾ дÑÑга апликаÑиÑа
+
+
+
+ MediaView
+ Ðоже да Ñа вмеÑнеÑе URL адÑеÑаÑа на емиÑÑваÑеÑо во дÑÑга апликаÑиÑа
+
+
+
+ MediaView
+ ÐÐ¸Ð½ÐºÐ¾Ñ Ñе биде валиден Ñамо за опÑеделно вÑеме.
+
+
+
+ MediaView
+ Ðие гледаÑе "%1"
+
+
+
+ NetworkAccess
+ ÐÑеÑка во мÑежаÑа: %1
+
+
+
+ PrettyItemDelegate
+ %1 пÑегледÑваÑа
+
+
+
+ SearchView
+ ÐобÑедоÑдовÑе во <a href='%1'>%2</a>,
+
+
+
+ SearchView
+ ÐнеÑеÑе клÑÑен Ð·Ð±Ð¾Ñ Ð·Ð° да поÑнеÑе да гледаÑе видео клипови.
+
+
+
+ SearchView
+ ÐледаÑ
+
+
+
+ SearchView
+ ÐоÑледни коÑиÑÑени клÑÑни збоÑови
+
+
+
+ SearchView
+ Ðова веÑзиÑа на %1 е доÑÑапна.Ðе молиме <a href='%2'> обновеÑе до веÑзиÑа %3</a>
+
+
+
+ SearchView
+ ÐпÑÑÑеÑе Ñе
+
+
+
+ Video
+ ÐÑеÑка во мÑежаÑа: %1 за %2
+
+
+
diff --git a/minitube.pro b/minitube.pro
index bea0df2..94ac55e 100755
--- a/minitube.pro
+++ b/minitube.pro
@@ -1,6 +1,6 @@
CONFIG += release
TEMPLATE = app
-VERSION = 1.2
+VERSION = 1.3
DEFINES += APP_VERSION="$$VERSION"
INCLUDEPATH += /usr/include/phonon
diff --git a/src/AboutView.cpp b/src/AboutView.cpp
index 961c867..1a0ec17 100644
--- a/src/AboutView.cpp
+++ b/src/AboutView.cpp
@@ -59,7 +59,8 @@ AboutView::AboutView(QWidget *parent) : QWidget(parent) {
"Daniel Rodrigues (pt_PT), "
"Jesse Jaara (fi_FI), "
"Tsvyatko Makazchiev (bg_BG), "
- "Changtai Liang (zh_CN)"
+ "Changtai Liang (zh_CN), "
+ "Veta Branislav (mkd_MKD)"
) + "
"
#if !defined(APP_MAC) && !defined(Q_WS_WIN)
"" + tr("Released under the GNU General Public License")
diff --git a/src/ListModel.cpp b/src/ListModel.cpp
index 761e5a4..1c146ee 100755
--- a/src/ListModel.cpp
+++ b/src/ListModel.cpp
@@ -202,6 +202,10 @@ void ListModel::addVideo(Video* video) {
// save keyword
QString query = searchParams->keywords();
+ if (query.startsWith("http://")) {
+ // Save the video title
+ query += "|" + videos.first()->title();
+ }
QSettings settings;
QStringList keywords = settings.value(recentKeywordsKey).toStringList();
keywords.removeAll(query);
diff --git a/src/MainWindow.cpp b/src/MainWindow.cpp
index c87c398..1ef752b 100755
--- a/src/MainWindow.cpp
+++ b/src/MainWindow.cpp
@@ -45,6 +45,7 @@ MainWindow::MainWindow() :
createStatusBar();
initPhonon();
+ // mediaView->setSlider(slider);
mediaView->setMediaObject(mediaObject);
// remove that useless menu/toolbar context menu
@@ -395,12 +396,24 @@ void MainWindow::createToolBars() {
mainToolBar->addWidget(new Spacer());
seekSlider = new Phonon::SeekSlider(this);
+#ifdef Q_WS_X11
+ seekSlider->setDisabled(true);
+#endif
seekSlider->setIconVisible(false);
seekSlider->setSizePolicy(QSizePolicy::MinimumExpanding, QSizePolicy::Preferred);
mainToolBar->addWidget(seekSlider);
mainToolBar->addWidget(new Spacer());
+/*
+ slider = new QSlider(this);
+ slider->setOrientation(Qt::Horizontal);
+ slider->setSizePolicy(QSizePolicy::MinimumExpanding, QSizePolicy::Preferred);
+ mainToolBar->addWidget(slider);
+*/
+
+ mainToolBar->addWidget(new Spacer());
+
totalTime = new QLabel(mainToolBar);
totalTime->setFont(smallerFont);
mainToolBar->addWidget(totalTime);
@@ -453,7 +466,7 @@ void MainWindow::readSettings() {
restoreGeometry(settings.value("geometry").toByteArray());
#ifdef APP_MAC
if (!isMaximized())
- move(x(), y() + mainToolBar->height() + 8);
+ move(x(), y() + 10);
#endif
setDefinitionMode(settings.value("definition", VideoDefinition::getDefinitionNames().first()).toString());
audioOutput->setVolume(settings.value("volume", 1).toDouble());
@@ -814,6 +827,11 @@ void MainWindow::tick(qint64 time) {
const qint64 remainingTime = mediaObject->remainingTime();
currentTime->setStatusTip(tr("Remaining time: %1").arg(formatTime(remainingTime)));
+ /*
+ slider->blockSignals(true);
+ slider->setValue(time/1000);
+ slider->blockSignals(false);
+ */
}
void MainWindow::totalTimeChanged(qint64 time) {
@@ -822,6 +840,13 @@ void MainWindow::totalTimeChanged(qint64 time) {
return;
}
totalTime->setText(formatTime(time));
+
+ /*
+ slider->blockSignals(true);
+ slider->setMaximum(time/1000);
+ slider->blockSignals(false);
+ */
+
}
QString MainWindow::formatTime(qint64 time) {
diff --git a/src/MainWindow.h b/src/MainWindow.h
index e90dbf8..203a214 100755
--- a/src/MainWindow.h
+++ b/src/MainWindow.h
@@ -21,6 +21,7 @@ class MainWindow : public QMainWindow {
public:
MainWindow();
~MainWindow();
+ Phonon::SeekSlider* getSeekSlider() { return seekSlider; }
protected:
void closeEvent(QCloseEvent *);
@@ -125,6 +126,7 @@ private:
// phonon
Phonon::SeekSlider *seekSlider;
+ // QSlider *slider;
Phonon::VolumeSlider *volumeSlider;
Phonon::MediaObject *mediaObject;
Phonon::AudioOutput *audioOutput;
diff --git a/src/MediaView.cpp b/src/MediaView.cpp
index 739c595..8890ace 100644
--- a/src/MediaView.cpp
+++ b/src/MediaView.cpp
@@ -5,6 +5,12 @@
#include "minisplitter.h"
#include "constants.h"
#include "downloadmanager.h"
+#include "downloaditem.h"
+#include "MainWindow.h"
+
+namespace The {
+ NetworkAccess* http();
+}
namespace The {
QMap* globalActions();
@@ -15,6 +21,7 @@ namespace The {
MediaView::MediaView(QWidget *parent) : QWidget(parent) {
reallyStopped = false;
+ downloadItem = 0;
QBoxLayout *layout = new QHBoxLayout();
layout->setMargin(0);
@@ -152,6 +159,12 @@ void MediaView::search(SearchParams *searchParams) {
workaroundTimer->stop();
errorTimer->stop();
+ mediaObject->pause();
+ if (downloadItem) {
+ delete downloadItem;
+ downloadItem = 0;
+ }
+
this->searchParams = searchParams;
// start serching for videos
@@ -162,6 +175,17 @@ void MediaView::search(SearchParams *searchParams) {
listView->setFocus();
+
+ QString keyword = searchParams->keywords();
+ QString display = keyword;
+ if (keyword.startsWith("http://")) {
+ int separator = keyword.indexOf("|");
+ if (separator > 0 && separator + 1 < keyword.length()) {
+ display = keyword.mid(separator+1);
+ }
+ }
+ // tr("You're watching \"%1\"").arg(searchParams->keywords())
+
}
void MediaView::disappear() {
@@ -179,12 +203,14 @@ void MediaView::stateChanged(Phonon::State newState, Phonon::State /*oldState*/)
{
// qDebug() << "Phonon state: " << newState << oldState;
+ // slider->setEnabled(newState == Phonon::PlayingState);
switch (newState) {
case Phonon::ErrorState:
qDebug() << "Phonon error:" << mediaObject->errorString() << mediaObject->errorType();
- handleError(mediaObject->errorString());
+ if (mediaObject->errorType() == Phonon::FatalError)
+ handleError(mediaObject->errorString());
break;
case Phonon::PlayingState:
@@ -244,6 +270,10 @@ void MediaView::stop() {
workaroundTimer->stop();
errorTimer->stop();
listView->selectionModel()->clearSelection();
+ if (downloadItem) {
+ delete downloadItem;
+ downloadItem = 0;
+ }
}
void MediaView::activeRowChanged(int row) {
@@ -257,6 +287,13 @@ void MediaView::activeRowChanged(int row) {
workaroundTimer->stop();
errorTimer->stop();
+ mediaObject->pause();
+ if (downloadItem) {
+ delete downloadItem;
+ downloadItem = 0;
+ }
+ // slider->setMinimum(0);
+
// immediately show the loading widget
videoAreaWidget->showLoading(video);
@@ -289,9 +326,75 @@ void MediaView::gotStreamUrl(QUrl streamUrl) {
}
video->disconnect(this);
+ QString tempDir = QDesktopServices::storageLocation(QDesktopServices::TempLocation);
+ QString tempFile = tempDir + "/minitube.mp4";
+ if (!QFile::remove(tempFile)) {
+ qDebug() << "Cannot remove temp file";
+ }
+
+ Video *videoCopy = video->clone();
+ if (downloadItem) delete downloadItem;
+ downloadItem = new DownloadItem(videoCopy, streamUrl, tempFile, this);
+ connect(downloadItem, SIGNAL(statusChanged()), SLOT(downloadStatusChanged()));
+ // connect(downloadItem, SIGNAL(progress(int)), SLOT(downloadProgress(int)));
+ // connect(downloadItem, SIGNAL(finished()), SLOT(itemFinished()));
+ downloadItem->start();
+
+}
+
+/*
+void MediaView::downloadProgress(int percent) {
+ MainWindow* mainWindow = dynamic_cast(window());
+
+ mainWindow->getSeekSlider()->setStyleSheet(" QSlider::groove:horizontal {"
+ "border: 1px solid #999999;"
+ // "border-left: 50px solid rgba(255, 0, 0, 128);"
+ "height: 8px;"
+ "background: qlineargradient(x1:0, y1:0, x2:.5, y2:0, stop:0 rgba(255, 0, 0, 92), stop:"
+ + QString::number(percent/100.0) +
+
+ " rgba(255, 0, 0, 92), stop:" + QString::number((percent+1)/100.0) + " transparent, stop:1 transparent);"
+ "margin: 2px 0;"
+ "}"
+ "QSlider::handle:horizontal {"
+ "background: qlineargradient(x1:0, y1:0, x2:1, y2:1, stop:0 #b4b4b4, stop:1 #8f8f8f);"
+ "border: 1px solid #5c5c5c;"
+ "width: 16px;"
+ "height: 16px;"
+ "margin: -2px 0;"
+ "border-radius: 8px;"
+ "}"
+
+ );
+}
+
+*/
+
+void MediaView::downloadStatusChanged() {
+ switch(downloadItem->status()) {
+ case Downloading:
+ startPlaying();
+ break;
+ case Starting:
+ qDebug() << "Starting";
+ break;
+ case Finished:
+ qDebug() << "Finished";
+ break;
+ case Failed:
+ qDebug() << "Failed";
+ case Idle:
+ qDebug() << "Idle";
+ break;
+ }
+}
+
+void MediaView::startPlaying() {
+ if (reallyStopped) return;
+
// go!
- qDebug() << "Playing" << streamUrl.toString();
- mediaObject->setCurrentSource(streamUrl);
+ qDebug() << "Playing" << downloadItem->currentFilename();
+ mediaObject->setCurrentSource(downloadItem->currentFilename());
mediaObject->play();
// ensure we always have 10 videos ahead
@@ -364,7 +467,7 @@ void MediaView::copyWebPage() {
void MediaView::copyVideoLink() {
Video* video = listModel->activeVideo();
if (!video) return;
- QApplication::clipboard()->setText(video->getStreamUrl().toString());
+ QApplication::clipboard()->setText(video->getStreamUrl().toEncoded());
QString message = tr("You can now paste the video stream URL into another application")
+ ". " + tr("The link will be valid only for a limited time.");
QMainWindow* mainWindow = dynamic_cast(window());
@@ -500,3 +603,50 @@ void MediaView::fullscreen() {
videoAreaWidget->setParent(0);
videoAreaWidget->showFullScreen();
}
+
+/*
+void MediaView::setSlider(QSlider *slider) {
+ this->slider = slider;
+ // slider->setEnabled(false);
+ slider->setTracking(false);
+ // connect(slider, SIGNAL(valueChanged(int)), SLOT(sliderMoved(int)));
+}
+
+void MediaView::sliderMoved(int value) {
+ qDebug() << __func__;
+ int sliderPercent = (value * 100) / (slider->maximum() - slider->minimum());
+ qDebug() << slider->minimum() << value << slider->maximum();
+ if (sliderPercent <= downloadItem->currentPercent()) {
+ qDebug() << sliderPercent << downloadItem->currentPercent();
+ mediaObject->seek(value);
+ } else {
+ seekTo(value);
+ }
+}
+
+void MediaView::seekTo(int value) {
+ qDebug() << __func__;
+ mediaObject->pause();
+ workaroundTimer->stop();
+ errorTimer->stop();
+ // mediaObject->clear();
+
+ QString tempDir = QDesktopServices::storageLocation(QDesktopServices::TempLocation);
+ QString tempFile = tempDir + "/minitube" + QString::number(value) + ".mp4";
+ if (!QFile::remove(tempFile)) {
+ qDebug() << "Cannot remove temp file";
+ }
+ Video *videoCopy = downloadItem->getVideo()->clone();
+ QUrl streamUrl = videoCopy->getStreamUrl();
+ streamUrl.addQueryItem("begin", QString::number(value));
+ if (downloadItem) delete downloadItem;
+ downloadItem = new DownloadItem(videoCopy, streamUrl, tempFile, this);
+ connect(downloadItem, SIGNAL(statusChanged()), SLOT(downloadStatusChanged()));
+ // connect(downloadItem, SIGNAL(finished()), SLOT(itemFinished()));
+ downloadItem->start();
+
+ // slider->setMinimum(value);
+
+}
+
+*/
diff --git a/src/MediaView.h b/src/MediaView.h
index 7a19d68..f61799a 100644
--- a/src/MediaView.h
+++ b/src/MediaView.h
@@ -13,6 +13,8 @@
#include "loadingwidget.h"
#include "videoareawidget.h"
+class DownloadItem;
+
namespace The {
QMap* globalActions();
}
@@ -32,13 +34,14 @@ public:
QMap metadata() {
QMap metadata;
if (searchParams) {
- metadata.insert("title", searchParams->keywords());
- metadata.insert("description", tr("You're watching \"%1\"").arg(searchParams->keywords()));
+ metadata.insert("title", "");
+ metadata.insert("description", "");
}
return metadata;
}
void setMediaObject(Phonon::MediaObject *mediaObject);
+ void setSlider(QSlider *slider);
public slots:
void search(SearchParams *searchParams);
@@ -78,6 +81,14 @@ private slots:
#ifdef APP_DEMO
void demoMessage();
#endif
+ void startPlaying();
+ void downloadStatusChanged();
+
+ /*
+ void downloadProgress(int percent);
+ void sliderMoved(int value);
+ void seekTo(int value);
+ */
private:
@@ -114,6 +125,9 @@ private:
QTimer *demoTimer;
#endif
+ DownloadItem *downloadItem;
+ // QSlider *slider;
+
};
#endif // __MEDIAVIEW_H__
diff --git a/src/SearchView.cpp b/src/SearchView.cpp
index d1907f0..76f7da4 100644
--- a/src/SearchView.cpp
+++ b/src/SearchView.cpp
@@ -135,9 +135,18 @@ void SearchView::updateRecentKeywords() {
The::globalActions()->value("clearRecentKeywords")->setEnabled(!keywords.isEmpty());
foreach (QString keyword, keywords) {
- QLabel *itemLabel = new QLabel(" 0 && separator + 1 < keyword.length()) {
+ link = keyword.left(separator);
+ display = keyword.mid(separator+1);
+ }
+ }
+ QLabel *itemLabel = new QLabel(""
- + keyword + "", this);
+ + display + "", this);
itemLabel->setMaximumWidth(queryEdit->width() + watchButton->width());
// itemLabel->setSizePolicy(QSizePolicy::Fixed, QSizePolicy::Fixed);
diff --git a/src/downloaditem.cpp b/src/downloaditem.cpp
index ab92fc3..1219fb4 100644
--- a/src/downloaditem.cpp
+++ b/src/downloaditem.cpp
@@ -99,7 +99,6 @@ void DownloadItem::downloadReadyRead() {
emit statusChanged();
}
- m_status = Downloading;
if (-1 == m_file.write(m_reply->readAll())) {
/*
downloadInfoLabel->setText(tr("Error saving: %1")
@@ -108,7 +107,10 @@ void DownloadItem::downloadReadyRead() {
*/
} else {
m_startedSaving = true;
- if (m_finishedDownloading)
+ if (m_status != Downloading) {
+ // m_status = Downloading;
+ // emit statusChanged();
+ } else if (m_finishedDownloading)
requestFinished();
}
}
@@ -157,6 +159,14 @@ void DownloadItem::downloadProgress(qint64 bytesReceived, qint64 bytesTotal) {
percent = bytesReceived * 100 / bytesTotal;
}
+ // qDebug() << bytesReceived << bytesTotal;
+ if (m_status != Downloading
+ && bytesReceived > 1024 * 512
+ && bytesReceived > bytesTotal * .01) {
+ m_status = Downloading;
+ emit statusChanged();
+ }
+
emit progress(percent);
// emit statusChanged();
}
diff --git a/src/downloaditem.h b/src/downloaditem.h
index 1d6b1f1..7ccf4db 100644
--- a/src/downloaditem.h
+++ b/src/downloaditem.h
@@ -31,6 +31,7 @@ public:
double currentSpeed() const;
int currentPercent() const { return percent; }
Video* getVideo() const { return video; }
+ QString currentFilename() const { return m_file.fileName(); }
DownloadItemStatus status() const { return m_status; }
static QString formattedFilesize(qint64 size);
static QString formattedSpeed(double speed);
diff --git a/src/networkaccess.cpp b/src/networkaccess.cpp
index 378cb1a..4c4058e 100644
--- a/src/networkaccess.cpp
+++ b/src/networkaccess.cpp
@@ -6,9 +6,13 @@ namespace The {
NetworkAccess* http();
}
+/*
const QString USER_AGENT = QString(Constants::APP_NAME)
+ " " + Constants::VERSION
+ " (" + Constants::WEBSITE + ")";
+*/
+
+const QString USER_AGENT = "Mozilla/5.0 (X11; U; Linux x86; en-US; rv:1.9.2.12) Gecko/20101028 Firefox/3.6.12";
NetworkReply::NetworkReply(QNetworkReply *networkReply) : QObject(networkReply) {
this->networkReply = networkReply;
@@ -54,24 +58,20 @@ void NetworkReply::requestError(QNetworkReply::NetworkError code) {
NetworkAccess::NetworkAccess( QObject* parent) : QObject( parent ) {}
-QNetworkReply* NetworkAccess::simpleGet(QUrl url, int operation) {
+QNetworkReply* NetworkAccess::manualGet(QNetworkRequest request, int operation) {
QNetworkAccessManager *manager = The::networkAccessManager();
- QNetworkRequest request(url);
- request.setRawHeader("User-Agent", USER_AGENT.toUtf8());
- request.setRawHeader("Connection", "Keep-Alive");
-
QNetworkReply *networkReply;
switch (operation) {
case QNetworkAccessManager::GetOperation:
- qDebug() << "GET" << url.toString();
+ qDebug() << "GET" << request.url().toEncoded();
networkReply = manager->get(request);
break;
case QNetworkAccessManager::HeadOperation:
- qDebug() << "HEAD" << url.toString();
+ qDebug() << "HEAD" << request.url().toEncoded();
networkReply = manager->head(request);
break;
@@ -86,7 +86,18 @@ QNetworkReply* NetworkAccess::simpleGet(QUrl url, int operation) {
this, SLOT(error(QNetworkReply::NetworkError)));
return networkReply;
+}
+
+QNetworkReply* NetworkAccess::simpleGet(QUrl url, int operation) {
+
+ QNetworkRequest request(url);
+ request.setRawHeader("User-Agent", USER_AGENT.toUtf8());
+ request.setRawHeader("Accept-Charset", "ISO-8859-1,utf-8;q=0.7,*;q=0.7");
+ request.setRawHeader("Accept", "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8");
+ request.setRawHeader("Accept-Language", "en-us,en;q=0.5");
+ // request.setRawHeader("Connection", "Keep-Alive");
+ return manualGet(request, operation);
}
NetworkReply* NetworkAccess::get(const QUrl url) {
diff --git a/src/networkaccess.h b/src/networkaccess.h
index 64cf508..58e55e3 100644
--- a/src/networkaccess.h
+++ b/src/networkaccess.h
@@ -1,6 +1,7 @@
#ifndef NETWORKACCESS_H
#define NETWORKACCESS_H
+#include
#include
namespace The {
@@ -35,6 +36,7 @@ class NetworkAccess : public QObject {
public:
NetworkAccess( QObject* parent=0);
+ QNetworkReply* manualGet(QNetworkRequest request, int operation = QNetworkAccessManager::GetOperation);
QNetworkReply* simpleGet(QUrl url, int operation = QNetworkAccessManager::GetOperation);
NetworkReply* get(QUrl url);
NetworkReply* head(QUrl url);
diff --git a/src/video.cpp b/src/video.cpp
index 35e8371..7b7a803 100644
--- a/src/video.cpp
+++ b/src/video.cpp
@@ -102,6 +102,8 @@ void Video::getVideoInfo() {
void Video::gotVideoInfo(QByteArray data) {
QString videoInfo = QString::fromUtf8(data);
+ // qDebug() << "videoInfo" << videoInfo;
+
// get video token
QRegExp re = QRegExp("^.*&token=([^&]+).*$");
bool match = re.exactMatch(videoInfo);
@@ -118,7 +120,6 @@ void Video::gotVideoInfo(QByteArray data) {
// qDebug() << "videoToken" << videoToken;
this->videoToken = videoToken;
- /*
// get fmt_url_map
re = QRegExp("^.*&fmt_url_map=([^&]+).*$");
match = re.exactMatch(videoInfo);
@@ -129,32 +130,54 @@ void Video::gotVideoInfo(QByteArray data) {
getVideoInfo();
return;
}
+
QString fmtUrlMap = re.cap(1);
+ fmtUrlMap = QByteArray::fromPercentEncoding(fmtUrlMap.toUtf8());
- while (fmtUrlMap.contains('%'))
- fmtUrlMap = QByteArray::fromPercentEncoding(fmtUrlMap.toAscii());
+ QSettings settings;
+ QString definitionName = settings.value("definition").toString();
+ int definitionCode = VideoDefinition::getDefinitionCode(definitionName);
- qDebug() << "fmtUrlMap" << fmtUrlMap;
+ // qDebug() << "fmtUrlMap" << fmtUrlMap;
QStringList formatUrls = fmtUrlMap.split(",", QString::SkipEmptyParts);
+ QHash urlMap;
foreach(QString formatUrl, formatUrls) {
int separator = formatUrl.indexOf("|");
if (separator == -1) continue;
int format = formatUrl.left(separator).toInt();
QString url = formatUrl.mid(separator + 1);
- qDebug() << format << url;
+
+ if (format == definitionCode) {
+ QUrl videoUrl = QUrl::fromEncoded(url.toUtf8(), QUrl::StrictMode);
+ m_streamUrl = videoUrl;
+ emit gotStreamUrl(videoUrl);
+ loadingStreamUrl = false;
+ return;
+ }
+
+ urlMap.insert(format, url);
}
- */
- QSettings settings;
- QString definitionName = settings.value("definition").toString();
- int definitionCode = VideoDefinition::getDefinitionCode(definitionName);
- if (definitionCode == 18) {
- // This is assumed always available
- foundVideoUrl(videoToken, 18);
- } else {
- findVideoUrl(definitionCode);
+ QList definitionCodes = VideoDefinition::getDefinitionCodes();
+ int currentIndex = definitionCodes.indexOf(definitionCode);
+ int previousIndex = 0;
+ while (currentIndex >= 0) {
+ previousIndex = currentIndex - 1;
+ int definitionCode = definitionCodes.at(previousIndex);
+ if (urlMap.contains(definitionCode)) {
+ qDebug() << "Found format" << definitionCode;
+ QString url = urlMap.value(definitionCode);
+ QUrl videoUrl = QUrl::fromEncoded(url.toUtf8(), QUrl::StrictMode);
+ m_streamUrl = videoUrl;
+ emit gotStreamUrl(videoUrl);
+ loadingStreamUrl = false;
+ return;
+ }
+ currentIndex--;
}
+ emit errorStreamUrl(tr("Cannot get video stream for %1").arg(m_webpage.toString()));
+
}
void Video::foundVideoUrl(QString videoToken, int definitionCode) {