diff options
-rw-r--r-- | XBMC-ATV2.xcodeproj/project.pbxproj | 6 | ||||
-rw-r--r-- | XBMC-IOS.xcodeproj/project.pbxproj | 6 | ||||
-rw-r--r-- | XBMC.xcodeproj/project.pbxproj | 6 | ||||
-rw-r--r-- | language/English/strings.po | 27 | ||||
-rw-r--r-- | project/VS2010Express/XBMC.vcxproj | 2 | ||||
-rw-r--r-- | project/VS2010Express/XBMC.vcxproj.filters | 6 | ||||
-rw-r--r-- | xbmc/TextureCacheJob.h | 2 | ||||
-rw-r--r-- | xbmc/utils/EdenVideoArtUpdater.cpp | 357 | ||||
-rw-r--r-- | xbmc/utils/EdenVideoArtUpdater.h | 53 | ||||
-rw-r--r-- | xbmc/utils/Makefile | 1 | ||||
-rw-r--r-- | xbmc/video/VideoDatabase.h | 1 | ||||
-rw-r--r-- | xbmc/video/windows/GUIWindowVideoBase.cpp | 18 | ||||
-rw-r--r-- | xbmc/video/windows/GUIWindowVideoBase.h | 1 |
13 files changed, 484 insertions, 2 deletions
diff --git a/XBMC-ATV2.xcodeproj/project.pbxproj b/XBMC-ATV2.xcodeproj/project.pbxproj index 7e5862d0ed..52ec61b0da 100644 --- a/XBMC-ATV2.xcodeproj/project.pbxproj +++ b/XBMC-ATV2.xcodeproj/project.pbxproj @@ -44,6 +44,7 @@ 7C99B7AA134072CD00FC2B16 /* GUIDialogPlayEject.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7C99B7A8134072CD00FC2B16 /* GUIDialogPlayEject.cpp */; }; 7CC30DF2162925BE003E7579 /* MusicThumbLoader.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7CC30DF0162925BE003E7579 /* MusicThumbLoader.cpp */; }; 7CC30E1A16292627003E7579 /* VideoThumbLoader.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7CC30E1816292627003E7579 /* VideoThumbLoader.cpp */; }; + 7CC3105D162AAF9B003E7579 /* EdenVideoArtUpdater.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7CC3105B162AAF9B003E7579 /* EdenVideoArtUpdater.cpp */; }; 7CCFD9AA1514952700211D82 /* PCMCodec.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7CCFD9A81514952700211D82 /* PCMCodec.cpp */; }; 7CEE2E6D13D6B7A8000ABF2A /* TimeSmoother.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7CEE2E6B13D6B7A8000ABF2A /* TimeSmoother.cpp */; }; C807119F135DB842002F601B /* InputOperations.cpp in Sources */ = {isa = PBXBuildFile; fileRef = C807119D135DB842002F601B /* InputOperations.cpp */; }; @@ -1069,6 +1070,8 @@ 7CC30DF1162925BE003E7579 /* MusicThumbLoader.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = MusicThumbLoader.h; sourceTree = "<group>"; }; 7CC30E1816292627003E7579 /* VideoThumbLoader.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = VideoThumbLoader.cpp; sourceTree = "<group>"; }; 7CC30E1916292627003E7579 /* VideoThumbLoader.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VideoThumbLoader.h; sourceTree = "<group>"; }; + 7CC3105B162AAF9B003E7579 /* EdenVideoArtUpdater.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = EdenVideoArtUpdater.cpp; sourceTree = "<group>"; }; + 7CC3105C162AAF9B003E7579 /* EdenVideoArtUpdater.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = EdenVideoArtUpdater.h; sourceTree = "<group>"; }; 7CCFD9A81514952700211D82 /* PCMCodec.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = PCMCodec.cpp; sourceTree = "<group>"; }; 7CCFD9A91514952700211D82 /* PCMCodec.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = PCMCodec.h; sourceTree = "<group>"; }; 7CEE2E6B13D6B7A8000ABF2A /* TimeSmoother.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = TimeSmoother.cpp; sourceTree = "<group>"; }; @@ -5680,6 +5683,8 @@ F56C772E131EC154000AD0F6 /* DownloadQueue.h */, F56C772F131EC154000AD0F6 /* DownloadQueueManager.cpp */, F56C7730131EC154000AD0F6 /* DownloadQueueManager.h */, + 7CC3105B162AAF9B003E7579 /* EdenVideoArtUpdater.cpp */, + 7CC3105C162AAF9B003E7579 /* EdenVideoArtUpdater.h */, F56C7731131EC154000AD0F6 /* EndianSwap.h */, F56C7732131EC154000AD0F6 /* Fanart.cpp */, F56C7733131EC154000AD0F6 /* Fanart.h */, @@ -7564,6 +7569,7 @@ F592D4C2162496620023BCE7 /* NptHash.cpp in Sources */, 7CC30DF2162925BE003E7579 /* MusicThumbLoader.cpp in Sources */, 7CC30E1A16292627003E7579 /* VideoThumbLoader.cpp in Sources */, + 7CC3105D162AAF9B003E7579 /* EdenVideoArtUpdater.cpp in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; diff --git a/XBMC-IOS.xcodeproj/project.pbxproj b/XBMC-IOS.xcodeproj/project.pbxproj index 0b7f8706ee..2ad8bc919a 100644 --- a/XBMC-IOS.xcodeproj/project.pbxproj +++ b/XBMC-IOS.xcodeproj/project.pbxproj @@ -45,6 +45,7 @@ 7C99B7BE1340730000FC2B16 /* GUIDialogPlayEject.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7C99B7BC1340730000FC2B16 /* GUIDialogPlayEject.cpp */; }; 7CC30E04162925E6003E7579 /* MusicThumbLoader.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7CC30E02162925E6003E7579 /* MusicThumbLoader.cpp */; }; 7CC30E0716292601003E7579 /* VideoThumbLoader.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7CC30E0516292601003E7579 /* VideoThumbLoader.cpp */; }; + 7CC3106F162AAFE3003E7579 /* EdenVideoArtUpdater.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7CC3106D162AAFE3003E7579 /* EdenVideoArtUpdater.cpp */; }; 7CCFD9991514950700211D82 /* PCMCodec.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7CCFD9971514950700211D82 /* PCMCodec.cpp */; }; 7CEE2E7F13D6B7D4000ABF2A /* TimeSmoother.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7CEE2E7D13D6B7D4000ABF2A /* TimeSmoother.cpp */; }; C80711AD135DB85F002F601B /* InputOperations.cpp in Sources */ = {isa = PBXBuildFile; fileRef = C80711AB135DB85F002F601B /* InputOperations.cpp */; }; @@ -1071,6 +1072,8 @@ 7CC30E03162925E6003E7579 /* MusicThumbLoader.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = MusicThumbLoader.h; sourceTree = "<group>"; }; 7CC30E0516292601003E7579 /* VideoThumbLoader.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = VideoThumbLoader.cpp; sourceTree = "<group>"; }; 7CC30E0616292601003E7579 /* VideoThumbLoader.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VideoThumbLoader.h; sourceTree = "<group>"; }; + 7CC3106D162AAFE3003E7579 /* EdenVideoArtUpdater.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = EdenVideoArtUpdater.cpp; sourceTree = "<group>"; }; + 7CC3106E162AAFE3003E7579 /* EdenVideoArtUpdater.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = EdenVideoArtUpdater.h; sourceTree = "<group>"; }; 7CCFD9971514950700211D82 /* PCMCodec.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = PCMCodec.cpp; sourceTree = "<group>"; }; 7CCFD9981514950700211D82 /* PCMCodec.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = PCMCodec.h; sourceTree = "<group>"; }; 7CEE2E7D13D6B7D4000ABF2A /* TimeSmoother.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = TimeSmoother.cpp; sourceTree = "<group>"; }; @@ -6046,6 +6049,8 @@ F56C871D131F42EC000AD0F6 /* DownloadQueue.h */, F56C871E131F42EC000AD0F6 /* DownloadQueueManager.cpp */, F56C871F131F42EC000AD0F6 /* DownloadQueueManager.h */, + 7CC3106D162AAFE3003E7579 /* EdenVideoArtUpdater.cpp */, + 7CC3106E162AAFE3003E7579 /* EdenVideoArtUpdater.h */, F56C8720131F42EC000AD0F6 /* EndianSwap.h */, F56C8721131F42EC000AD0F6 /* Fanart.cpp */, F56C8722131F42EC000AD0F6 /* Fanart.h */, @@ -7589,6 +7594,7 @@ 36A95DAD1624896C00727135 /* GUIDialogMediaFilter.cpp in Sources */, 7CC30E04162925E6003E7579 /* MusicThumbLoader.cpp in Sources */, 7CC30E0716292601003E7579 /* VideoThumbLoader.cpp in Sources */, + 7CC3106F162AAFE3003E7579 /* EdenVideoArtUpdater.cpp in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; diff --git a/XBMC.xcodeproj/project.pbxproj b/XBMC.xcodeproj/project.pbxproj index bc7881f8b4..a82d921ddd 100644 --- a/XBMC.xcodeproj/project.pbxproj +++ b/XBMC.xcodeproj/project.pbxproj @@ -286,6 +286,7 @@ 7CBEBB8412912BA400431822 /* fstrcmp.c in Sources */ = {isa = PBXBuildFile; fileRef = 7CBEBB8212912BA300431822 /* fstrcmp.c */; }; 7CC30DB116291A5C003E7579 /* MusicThumbLoader.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7CC30DAF16291A5C003E7579 /* MusicThumbLoader.cpp */; }; 7CC30DC016291C2C003E7579 /* VideoThumbLoader.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7CC30DBE16291C2C003E7579 /* VideoThumbLoader.cpp */; }; + 7CC30E8A16296078003E7579 /* EdenVideoArtUpdater.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7CC30E8816296078003E7579 /* EdenVideoArtUpdater.cpp */; }; 7CCF7E721067643800992676 /* DirectoryNodeSets.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7CCF7E701067643800992676 /* DirectoryNodeSets.cpp */; }; 7CCF7F1D1069F3AE00992676 /* Builtins.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7CCF7F1B1069F3AE00992676 /* Builtins.cpp */; }; 7CCF7FC9106A0DF500992676 /* TimeUtils.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 7CCF7FC7106A0DF500992676 /* TimeUtils.cpp */; }; @@ -1601,6 +1602,8 @@ 7CC30DB016291A5C003E7579 /* MusicThumbLoader.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = MusicThumbLoader.h; sourceTree = "<group>"; }; 7CC30DBE16291C2C003E7579 /* VideoThumbLoader.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = VideoThumbLoader.cpp; sourceTree = "<group>"; }; 7CC30DBF16291C2C003E7579 /* VideoThumbLoader.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VideoThumbLoader.h; sourceTree = "<group>"; }; + 7CC30E8816296078003E7579 /* EdenVideoArtUpdater.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = EdenVideoArtUpdater.cpp; sourceTree = "<group>"; }; + 7CC30E8916296078003E7579 /* EdenVideoArtUpdater.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = EdenVideoArtUpdater.h; sourceTree = "<group>"; }; 7CCF7E701067643800992676 /* DirectoryNodeSets.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = DirectoryNodeSets.cpp; sourceTree = "<group>"; }; 7CCF7E711067643800992676 /* DirectoryNodeSets.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = DirectoryNodeSets.h; sourceTree = "<group>"; }; 7CCF7F1B1069F3AE00992676 /* Builtins.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = Builtins.cpp; sourceTree = "<group>"; }; @@ -6080,6 +6083,8 @@ E38E1E320D25F9FD00618676 /* DownloadQueue.h */, E38E1E330D25F9FD00618676 /* DownloadQueueManager.cpp */, E38E1E340D25F9FD00618676 /* DownloadQueueManager.h */, + 7CC30E8816296078003E7579 /* EdenVideoArtUpdater.cpp */, + 7CC30E8916296078003E7579 /* EdenVideoArtUpdater.h */, 436B38F3106628850049AB3B /* EndianSwap.h */, E36C29E90DA72486001F0C9D /* Fanart.cpp */, 6E97BDC30DA2B620003A2A89 /* Fanart.h */, @@ -7622,6 +7627,7 @@ 36A95DA51624894400727135 /* GUIDialogMediaFilter.cpp in Sources */, 7CC30DB116291A5C003E7579 /* MusicThumbLoader.cpp in Sources */, 7CC30DC016291C2C003E7579 /* VideoThumbLoader.cpp in Sources */, + 7CC30E8A16296078003E7579 /* EdenVideoArtUpdater.cpp in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; diff --git a/language/English/strings.po b/language/English/strings.po index 9b1cfc1495..bb59b8254f 100644 --- a/language/English/strings.po +++ b/language/English/strings.po @@ -3796,13 +3796,36 @@ msgctxt "#12348" msgid "Item locked" msgstr "" -#empty strings from id 12349 to 12352 +#: xbmc/utils/EdenVideoArtUpdater.cpp +msgctxt "#12349" +msgid "Updating video library art" +msgstr "" + +#: xbmc/utils/EdenVideoArtUpdater.cpp +msgctxt "#12350" +msgid "Processing %s" +msgstr "" + +#: xbmc/video/windows/GUIWindowVideoBase.cpp +msgctxt "#12351" +msgid "The art cache in your video library needs updating." +msgstr "" + +#: xbmc/video/windows/GUIWindowVideoBase.cpp +msgctxt "#12352" +msgid "No downloading is needed." +msgstr "" msgctxt "#12353" msgid "Reactivate lock" msgstr "" -#empty strings from id 12354 to 12355 +#: xbmc/video/windows/GUIWindowVideoBase.cpp +msgctxt "#12354" +msgid "Would you like to update it now?" +msgstr "" + +#empty strings with id 12355 msgctxt "#12356" msgid "Change lock" diff --git a/project/VS2010Express/XBMC.vcxproj b/project/VS2010Express/XBMC.vcxproj index 010cd759ce..12b59520d3 100644 --- a/project/VS2010Express/XBMC.vcxproj +++ b/project/VS2010Express/XBMC.vcxproj @@ -1220,6 +1220,7 @@ <ClCompile Include="..\..\xbmc\utils\DatabaseUtils.cpp" /> <ClCompile Include="..\..\xbmc\utils\DownloadQueue.cpp" /> <ClCompile Include="..\..\xbmc\utils\DownloadQueueManager.cpp" /> + <ClCompile Include="..\..\xbmc\utils\EdenVideoArtUpdater.cpp" /> <ClCompile Include="..\..\xbmc\utils\EndianSwap.cpp" /> <ClCompile Include="..\..\xbmc\utils\Fanart.cpp" /> <ClCompile Include="..\..\xbmc\utils\fft.cpp" /> @@ -2371,6 +2372,7 @@ <ClInclude Include="..\..\xbmc\utils\DatabaseUtils.h" /> <ClInclude Include="..\..\xbmc\utils\DownloadQueue.h" /> <ClInclude Include="..\..\xbmc\utils\DownloadQueueManager.h" /> + <ClInclude Include="..\..\xbmc\utils\EdenVideoArtUpdater.h" /> <ClInclude Include="..\..\xbmc\utils\EndianSwap.h" /> <ClInclude Include="..\..\xbmc\utils\Fanart.h" /> <ClInclude Include="..\..\xbmc\utils\fft.h" /> diff --git a/project/VS2010Express/XBMC.vcxproj.filters b/project/VS2010Express/XBMC.vcxproj.filters index 357ac3ff82..bb0e3e0100 100644 --- a/project/VS2010Express/XBMC.vcxproj.filters +++ b/project/VS2010Express/XBMC.vcxproj.filters @@ -2581,6 +2581,9 @@ <ClCompile Include="..\..\xbmc\filesystem\VideoDatabaseDirectory\DirectoryNodeTags.cpp"> <Filter>filesystem\VideoDatabaseDirectory</Filter> </ClCompile> + <ClCompile Include="..\..\xbmc\utils\EdenVideoArtUpdater.cpp"> + <Filter>utils</Filter> + </ClCompile> <ClCompile Include="..\..\xbmc\utils\EndianSwap.cpp"> <Filter>utils</Filter> </ClCompile> @@ -4401,6 +4404,9 @@ <ClInclude Include="..\..\xbmc\utils\DownloadQueueManager.h"> <Filter>utils</Filter> </ClInclude> + <ClInclude Include="..\..\xbmc\utils\EdenVideoArtUpdater.h"> + <Filter>utils</Filter> + </ClInclude> <ClInclude Include="..\..\xbmc\utils\EndianSwap.h"> <Filter>utils</Filter> </ClInclude> diff --git a/xbmc/TextureCacheJob.h b/xbmc/TextureCacheJob.h index 786c7a68be..8ee1d45948 100644 --- a/xbmc/TextureCacheJob.h +++ b/xbmc/TextureCacheJob.h @@ -79,6 +79,8 @@ public: CStdString m_oldHash; CTextureDetails m_details; private: + friend class CEdenVideoArtUpdater; + /*! \brief retrieve a hash for the given image Combines the size, ctime and mtime of the image file into a "unique" hash \param url location of the image diff --git a/xbmc/utils/EdenVideoArtUpdater.cpp b/xbmc/utils/EdenVideoArtUpdater.cpp new file mode 100644 index 0000000000..528b5c4a83 --- /dev/null +++ b/xbmc/utils/EdenVideoArtUpdater.cpp @@ -0,0 +1,357 @@ +/* + * Copyright (C) 2012 Team XBMC + * http://www.xbmc.org + * + * This Program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2, or (at your option) + * any later version. + * + * This Program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with XBMC; see the file COPYING. If not, see + * <http://www.gnu.org/licenses/>. + * + */ + +#include "EdenVideoArtUpdater.h" +#include "video/VideoDatabase.h" +#include "video/VideoInfoScanner.h" +#include "FileItem.h" +#include "utils/log.h" +#include "utils/Crc32.h" +#include "utils/URIUtils.h" +#include "utils/ScraperUrl.h" +#include "utils/StringUtils.h" +#include "TextureCache.h" +#include "TextureCacheJob.h" +#include "pictures/Picture.h" +#include "settings/GUISettings.h" +#include "settings/Settings.h" +#include "settings/AdvancedSettings.h" +#include "guilib/Texture.h" +#include "guilib/GUIWindowManager.h" +#include "guilib/LocalizeStrings.h" +#include "filesystem/File.h" +#include "dialogs/GUIDialogExtendedProgressBar.h" + +using namespace std; +using namespace VIDEO; +using namespace XFILE; + +CEdenVideoArtUpdater::CEdenVideoArtUpdater() : CThread("EdenVideoArtUpdater") +{ + m_textureDB.Open(); +} + +CEdenVideoArtUpdater::~CEdenVideoArtUpdater() +{ + m_textureDB.Close(); +} + +void CEdenVideoArtUpdater::Start() +{ + CEdenVideoArtUpdater *updater = new CEdenVideoArtUpdater(); + updater->Create(true); // autodelete +} + +void CEdenVideoArtUpdater::Process() +{ + // grab all movies... + CVideoDatabase db; + if (!db.Open()) + return; + + CFileItemList items; + + CGUIDialogExtendedProgressBar* dialog = + (CGUIDialogExtendedProgressBar*)g_windowManager.GetWindow(WINDOW_DIALOG_EXT_PROGRESS); + + CGUIDialogProgressBarHandle *handle = dialog->GetHandle(g_localizeStrings.Get(314)); + handle->SetTitle(g_localizeStrings.Get(12349)); + + // movies + db.GetMoviesByWhere("videodb://1/2/", CDatabase::Filter(), items, false); + for (int i = 0; i < items.Size(); i++) + { + CFileItemPtr item = items[i]; + handle->SetProgress(i, items.Size()); + handle->SetText(StringUtils::Format(g_localizeStrings.Get(12350).c_str(), item->GetLabel().c_str())); + string cachedThumb = GetCachedVideoThumb(*item); + string cachedFanart = GetCachedFanart(*item); + + item->SetPath(item->GetVideoInfoTag()->m_strFileNameAndPath); + item->GetVideoInfoTag()->m_fanart.Unpack(); + item->GetVideoInfoTag()->m_strPictureURL.Parse(); + + map<string, string> artwork; + if (!db.GetArtForItem(item->GetVideoInfoTag()->m_iDbId, item->GetVideoInfoTag()->m_type, artwork)) + { + CStdString art = CVideoInfoScanner::GetImage(item.get(), true, item->GetVideoInfoTag()->m_basePath != item->GetPath(), "thumb"); + if (!art.empty() && CacheTexture(art, cachedThumb)) + artwork.insert(make_pair("thumb", art)); + + art = CVideoInfoScanner::GetFanart(item.get(), true); + if (!art.empty() && CacheTexture(art, cachedFanart)) + artwork.insert(make_pair("fanart", art)); + + if (artwork.empty()) + artwork.insert(make_pair("thumb", "")); + db.SetArtForItem(item->GetVideoInfoTag()->m_iDbId, item->GetVideoInfoTag()->m_type, artwork); + } + } + items.Clear(); + + // music videos + db.GetMusicVideosNav("videodb://3/2/", items, false); + for (int i = 0; i < items.Size(); i++) + { + CFileItemPtr item = items[i]; + handle->SetProgress(i, items.Size()); + handle->SetText(StringUtils::Format(g_localizeStrings.Get(12350).c_str(), item->GetLabel().c_str())); + string cachedThumb = GetCachedVideoThumb(*item); + string cachedFanart = GetCachedFanart(*item); + + item->SetPath(item->GetVideoInfoTag()->m_strFileNameAndPath); + item->GetVideoInfoTag()->m_fanart.Unpack(); + item->GetVideoInfoTag()->m_strPictureURL.Parse(); + + map<string, string> artwork; + if (!db.GetArtForItem(item->GetVideoInfoTag()->m_iDbId, item->GetVideoInfoTag()->m_type, artwork)) + { + CStdString art = CVideoInfoScanner::GetImage(item.get(), true, item->GetVideoInfoTag()->m_basePath != item->GetPath(), "thumb"); + if (!art.empty() && CacheTexture(art, cachedThumb)) + artwork.insert(make_pair("thumb", art)); + + art = CVideoInfoScanner::GetFanart(item.get(), true); + if (!art.empty() && CacheTexture(art, cachedFanart)) + artwork.insert(make_pair("fanart", art)); + + if (artwork.empty()) + artwork.insert(make_pair("thumb", "")); + db.SetArtForItem(item->GetVideoInfoTag()->m_iDbId, item->GetVideoInfoTag()->m_type, artwork); + } + } + items.Clear(); + + // tvshows + // count the number of episodes + db.GetTvShowsNav("videodb://3/2/", items); + for (int i = 0; i < items.Size(); i++) + { + CFileItemPtr item = items[i]; + handle->SetText(StringUtils::Format(g_localizeStrings.Get(12350).c_str(), item->GetLabel().c_str())); + string cachedThumb = GetCachedVideoThumb(*item); + string cachedFanart = GetCachedFanart(*item); + + item->SetPath(item->GetVideoInfoTag()->m_strPath); + item->GetVideoInfoTag()->m_fanart.Unpack(); + item->GetVideoInfoTag()->m_strPictureURL.Parse(); + + map<string, string> artwork; + if (!db.GetArtForItem(item->GetVideoInfoTag()->m_iDbId, item->GetVideoInfoTag()->m_type, artwork)) + { + CStdString art = CVideoInfoScanner::GetImage(item.get(), true, false, "thumb"); + if (!art.empty() && CacheTexture(art, cachedThumb)) + artwork.insert(make_pair("thumb", art)); + + art = CVideoInfoScanner::GetFanart(item.get(), true); + if (!art.empty() && CacheTexture(art, cachedFanart)) + artwork.insert(make_pair("fanart", art)); + + if (artwork.empty()) + artwork.insert(make_pair("thumb", "")); + db.SetArtForItem(item->GetVideoInfoTag()->m_iDbId, item->GetVideoInfoTag()->m_type, artwork); + } + + // now season art... + map<int, string> seasons; + CVideoInfoScanner::GetSeasonThumbs(*item->GetVideoInfoTag(), seasons, true); + for (map<int, string>::const_iterator j = seasons.begin(); j != seasons.end(); ++j) + { + int idSeason = db.AddSeason(item->GetVideoInfoTag()->m_iDbId, j->first); + if (!db.GetArtForItem(idSeason, "season", "thumb").empty()) + { + std::string cachedSeason = GetCachedSeasonThumb(j->first, item->GetVideoInfoTag()->m_strPath); + if (CacheTexture(j->second, cachedSeason)) + { + if (idSeason > -1) + db.SetArtForItem(idSeason, "season", "thumb", j->second); + } + } + } + + // now episodes... + CFileItemList items2; + db.GetEpisodesByWhere("videodb://2/2/-1/-1/", db.PrepareSQL("episodeview.idShow=%d", item->GetVideoInfoTag()->m_iDbId), items2); + for (int j = 0; j < items2.Size(); j++) + { + handle->SetProgress(j, items2.Size()); + CFileItemPtr episode = items2[j]; + string cachedThumb = GetCachedVideoThumb(*episode); + episode->SetPath(episode->GetVideoInfoTag()->m_strFileNameAndPath); + episode->GetVideoInfoTag()->m_strPictureURL.Parse(); + + map<string, string> artwork; + if (!db.GetArtForItem(episode->GetVideoInfoTag()->m_iDbId, episode->GetVideoInfoTag()->m_type, artwork)) + { + CStdString art = CVideoInfoScanner::GetImage(episode.get(), true, episode->GetVideoInfoTag()->m_basePath != episode->GetPath(), "thumb"); + if (!art.empty() && CacheTexture(art, cachedThumb)) + artwork.insert(make_pair("thumb", art)); + else + artwork.insert(make_pair("thumb", "")); + db.SetArtForItem(episode->GetVideoInfoTag()->m_iDbId, episode->GetVideoInfoTag()->m_type, artwork); + } + } + } + items.Clear(); + + // now sets + db.GetSetsNav("videodb://1/7/", items, VIDEODB_CONTENT_MOVIES); + for (int i = 0; i < items.Size(); i++) + { + CFileItemPtr item = items[i]; + handle->SetProgress(i, items.Size()); + handle->SetText(StringUtils::Format(g_localizeStrings.Get(12350).c_str(), item->GetLabel().c_str())); + map<string, string> artwork; + if (!db.GetArtForItem(item->GetVideoInfoTag()->m_iDbId, item->GetVideoInfoTag()->m_type, artwork)) + { // grab the first movie from this set + CFileItemList items2; + db.GetMoviesNav("videodb://1/2/", items2, -1, -1, -1, -1, -1, -1, item->GetVideoInfoTag()->m_iDbId); + if (items2.Size() > 1) + { + if (db.GetArtForItem(items2[0]->GetVideoInfoTag()->m_iDbId, items2[0]->GetVideoInfoTag()->m_type, artwork)) + db.SetArtForItem(item->GetVideoInfoTag()->m_iDbId, item->GetVideoInfoTag()->m_type, artwork); + } + } + } + items.Clear(); + + // now actors + if (g_guiSettings.GetBool("videolibrary.actorthumbs")) + { + db.GetActorsNav("videodb://1/2/", items, VIDEODB_CONTENT_MOVIES); + db.GetActorsNav("videodb://2/2/", items, VIDEODB_CONTENT_TVSHOWS); + db.GetActorsNav("videodb://2/2/", items, VIDEODB_CONTENT_EPISODES); + db.GetActorsNav("videodb://3/2/", items, VIDEODB_CONTENT_MUSICVIDEOS); + for (int i = 0; i < items.Size(); i++) + { + CFileItemPtr item = items[i]; + handle->SetProgress(i, items.Size()); + handle->SetText(StringUtils::Format(g_localizeStrings.Get(12350).c_str(), item->GetLabel().c_str())); + map<string, string> artwork; + if (!db.GetArtForItem(item->GetVideoInfoTag()->m_iDbId, item->GetVideoInfoTag()->m_type, artwork)) + { + item->GetVideoInfoTag()->m_strPictureURL.Parse(); + string cachedThumb = GetCachedActorThumb(*item); + + string art = CScraperUrl::GetThumbURL(item->GetVideoInfoTag()->m_strPictureURL.GetFirstThumb()); + if (!art.empty() && CacheTexture(art, cachedThumb)) + artwork.insert(make_pair("thumb", art)); + else + artwork.insert(make_pair("thumb", "")); + db.SetArtForItem(item->GetVideoInfoTag()->m_iDbId, item->GetVideoInfoTag()->m_type, artwork); + } + } + } + handle->MarkFinished(); + items.Clear(); +} + +bool CEdenVideoArtUpdater::CacheTexture(const std::string &originalUrl, const std::string &cachedFile) +{ + if (!CFile::Exists(cachedFile)) + return false; + + CTextureDetails details; + details.updateable = false;; + details.hash = "NOHASH"; + + CBaseTexture *texture = CTextureCacheJob::LoadImage(cachedFile, 0, 0, ""); + if (texture) + { + if (texture->HasAlpha()) + details.file = CTextureCache::GetCacheFile(originalUrl) + ".png"; + else + details.file = CTextureCache::GetCacheFile(originalUrl) + ".jpg"; + + CLog::Log(LOGDEBUG, "Caching image '%s' ('%s') to '%s':", originalUrl.c_str(), cachedFile.c_str(), details.file.c_str()); + + uint32_t width = 0, height = 0; + if (CPicture::CacheTexture(texture, width, height, CTextureCache::GetCachedPath(details.file))) + { + details.width = width; + details.height = height; + delete texture; + m_textureDB.AddCachedTexture(originalUrl, details); + return true; + } + } + CLog::Log(LOGDEBUG, "Can't cache image '%s' ('%s')", originalUrl.c_str(), cachedFile.c_str()); + return false; +} + +CStdString CEdenVideoArtUpdater::GetCachedActorThumb(const CFileItem &item) +{ + return GetThumb("actor" + item.GetLabel(), g_settings.GetVideoThumbFolder(), true); +} + +CStdString CEdenVideoArtUpdater::GetCachedSeasonThumb(int season, const CStdString &path) +{ + CStdString label; + if (season == 0) + label = g_localizeStrings.Get(20381); + else + label.Format(g_localizeStrings.Get(20358), season); + return GetThumb("season" + path + label, g_settings.GetVideoThumbFolder(), true); +} + +CStdString CEdenVideoArtUpdater::GetCachedEpisodeThumb(const CFileItem &item) +{ + // get the locally cached thumb + CStdString strCRC; + strCRC.Format("%sepisode%i", item.GetVideoInfoTag()->m_strFileNameAndPath.c_str(), item.GetVideoInfoTag()->m_iEpisode); + return GetThumb(strCRC, g_settings.GetVideoThumbFolder(), true); +} + +CStdString CEdenVideoArtUpdater::GetCachedVideoThumb(const CFileItem &item) +{ + if (item.m_bIsFolder && !item.GetVideoInfoTag()->m_strPath.IsEmpty()) + return GetThumb(item.GetVideoInfoTag()->m_strPath, g_settings.GetVideoThumbFolder(), true); + else if (!item.GetVideoInfoTag()->m_strFileNameAndPath.IsEmpty()) + return GetThumb(item.GetVideoInfoTag()->m_strFileNameAndPath, g_settings.GetVideoThumbFolder(), true); + return GetThumb(item.GetPath(), g_settings.GetVideoThumbFolder(), true); +} + +CStdString CEdenVideoArtUpdater::GetCachedFanart(const CFileItem &item) +{ + if (!item.GetVideoInfoTag()->m_artist.empty()) + return GetThumb(StringUtils::Join(item.GetVideoInfoTag()->m_artist, g_advancedSettings.m_videoItemSeparator), URIUtils::AddFileToFolder(g_settings.GetThumbnailsFolder(), "Music/Fanart/"), false); + CStdString path = item.GetVideoInfoTag()->GetPath(); + if (path.empty()) + return ""; + return GetThumb(path, URIUtils::AddFileToFolder(g_settings.GetVideoThumbFolder(), "Fanart/"), false); +} + +CStdString CEdenVideoArtUpdater::GetThumb(const CStdString &path, const CStdString &path2, bool split) +{ + // get the locally cached thumb + Crc32 crc; + crc.ComputeFromLowerCase(path); + + CStdString thumb; + if (split) + { + CStdString hex; + hex.Format("%08x", (__int32)crc); + thumb.Format("%c\\%08x.tbn", hex[0], (unsigned __int32)crc); + } + else + thumb.Format("%08x.tbn", (unsigned __int32)crc); + + return URIUtils::AddFileToFolder(path2, thumb); +} diff --git a/xbmc/utils/EdenVideoArtUpdater.h b/xbmc/utils/EdenVideoArtUpdater.h new file mode 100644 index 0000000000..a3eb199c3e --- /dev/null +++ b/xbmc/utils/EdenVideoArtUpdater.h @@ -0,0 +1,53 @@ +#pragma once +/* + * Copyright (C) 2012 Team XBMC + * http://www.xbmc.org + * + * This Program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2, or (at your option) + * any later version. + * + * This Program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with XBMC; see the file COPYING. If not, see + * <http://www.gnu.org/licenses/>. + * + */ + +#include <string> +#include "threads/thread.h" +#include "TextureDatabase.h" + +class CFileItem; + +class CEdenVideoArtUpdater : CThread +{ +public: + CEdenVideoArtUpdater(); + ~CEdenVideoArtUpdater(); + + static void Start(); + + virtual void Process(); + +private: + /*! \brief Caches the texture from oldCachedFile as if it came from originalUrl into the texture cache. + \param originalUrl the url that we think the oldCachedFile came from. + \param oldCachedFile the old cached file + */ + bool CacheTexture(const std::string &originalUrl, const std::string &oldCachedFile); + + CStdString GetCachedActorThumb(const CFileItem &item); + CStdString GetCachedSeasonThumb(int season, const CStdString &path); + CStdString GetCachedEpisodeThumb(const CFileItem &item); + CStdString GetCachedVideoThumb(const CFileItem &item); + CStdString GetCachedFanart(const CFileItem &item); + CStdString GetThumb(const CStdString &path, const CStdString &path2, bool split /* = false */); + + CTextureDatabase m_textureDB; +}; diff --git a/xbmc/utils/Makefile b/xbmc/utils/Makefile index cbece381f9..b2a5c5fc3b 100644 --- a/xbmc/utils/Makefile +++ b/xbmc/utils/Makefile @@ -14,6 +14,7 @@ SRCS=AlarmClock.cpp \ DownloadQueue.cpp \ DownloadQueueManager.cpp \ EndianSwap.cpp \ + EdenVideoArtUpdater.cpp \ Fanart.cpp \ fastmemcpy.c \ fastmemcpy-arm.S \ diff --git a/xbmc/video/VideoDatabase.h b/xbmc/video/VideoDatabase.h index a7a094f08d..1f18e84c29 100644 --- a/xbmc/video/VideoDatabase.h +++ b/xbmc/video/VideoDatabase.h @@ -688,6 +688,7 @@ public: virtual bool GetFilter(CDbUrl &videoUrl, Filter &filter); protected: + friend class CEdenVideoArtUpdater; int GetMovieId(const CStdString& strFilenameAndPath); int GetMusicVideoId(const CStdString& strFilenameAndPath); diff --git a/xbmc/video/windows/GUIWindowVideoBase.cpp b/xbmc/video/windows/GUIWindowVideoBase.cpp index 7a0ed7e249..9c7db34d70 100644 --- a/xbmc/video/windows/GUIWindowVideoBase.cpp +++ b/xbmc/video/windows/GUIWindowVideoBase.cpp @@ -69,6 +69,8 @@ #include "storage/MediaManager.h" #include "Autorun.h" #include "URL.h" +#include "utils/EdenVideoArtUpdater.h" +#include "GUIInfoManager.h" using namespace std; using namespace XFILE; @@ -2146,3 +2148,19 @@ void CGUIWindowVideoBase::OnAssignContent(const CStdString &path) g_application.StartVideoScan(path, true); } } + +void CGUIWindowVideoBase::OnInitWindow() +{ + CGUIMediaWindow::OnInitWindow(); + if (g_settings.m_videoNeedsUpdate == 63 && !g_application.IsVideoScanning() && + g_infoManager.GetLibraryBool(LIBRARY_HAS_VIDEO)) + { + // rescan of video library required + if (CGUIDialogYesNo::ShowAndGetInput(799, 12351, 12352, 12354)) + { + CEdenVideoArtUpdater::Start(); + g_settings.m_videoNeedsUpdate = 0; // once is enough + g_settings.Save(); + } + } +} diff --git a/xbmc/video/windows/GUIWindowVideoBase.h b/xbmc/video/windows/GUIWindowVideoBase.h index 32eef36b85..fa2a748950 100644 --- a/xbmc/video/windows/GUIWindowVideoBase.h +++ b/xbmc/video/windows/GUIWindowVideoBase.h @@ -83,6 +83,7 @@ public: protected: void OnScan(const CStdString& strPath, bool scanAll = false); + virtual void OnInitWindow(); virtual void UpdateButtons(); virtual bool Update(const CStdString &strDirectory); virtual bool GetDirectory(const CStdString &strDirectory, CFileItemList &items); |