mirror of
https://github.com/chibicitiberiu/rainmeter-studio.git
synced 2024-02-24 04:33:31 +00:00
NowPlayingPlugin: Improved handling of cached album art and fixed that some tracks don't display metadata with Winamp.
This commit is contained in:
parent
ef97fb2435
commit
3ba7d39bc4
@ -17,7 +17,6 @@
|
||||
*/
|
||||
|
||||
#include "StdAfx.h"
|
||||
#include "../../Library/Export.h"
|
||||
#include "../../Library/DisableThreadLibraryCalls.h" // contains DllMain entry point
|
||||
#include "NowPlaying.h"
|
||||
#include "PlayerAIMP.h"
|
||||
@ -163,13 +162,12 @@ UINT Initialize(HMODULE instance, LPCTSTR iniFile, LPCTSTR section, UINT id)
|
||||
}
|
||||
else
|
||||
{
|
||||
std::wstring error = L"PlayerName=";
|
||||
std::wstring error = L"NowPlayingPlugin: PlayerName=";
|
||||
error += str;
|
||||
error += L" is not valid in section [";
|
||||
error += section;
|
||||
error += L"] of the following file: \n\n";
|
||||
error += iniFile;
|
||||
MessageBox(NULL, error.c_str(), L"Rainmeter", MB_OK | MB_ICONERROR | MB_TOPMOST);
|
||||
error += L"].";
|
||||
LSLog(LOG_ERROR, L"Rainmeter", error.c_str());
|
||||
delete data;
|
||||
return maxValue;
|
||||
}
|
||||
@ -311,9 +309,11 @@ UINT Update(UINT id)
|
||||
case MEASURE_VOLUME:
|
||||
return player->GetVolume();
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
return 0;
|
||||
return 1;
|
||||
}
|
||||
|
||||
/*
|
||||
|
@ -97,17 +97,17 @@ void CPlayer::ClearInfo()
|
||||
}
|
||||
|
||||
/*
|
||||
** CreateCoverArtPath
|
||||
** GetCachedArt
|
||||
**
|
||||
** Determines the path to save cover art.
|
||||
** Checks if cover art is in cache.
|
||||
**
|
||||
*/
|
||||
std::wstring CPlayer::CreateCoverArtPath()
|
||||
bool CPlayer::GetCachedArt()
|
||||
{
|
||||
std::wstring targetPath = g_CachePath;
|
||||
m_CoverPath = g_CachePath;
|
||||
if (m_Artist.empty() || m_Title.empty())
|
||||
{
|
||||
targetPath += L"temp.art";
|
||||
m_CoverPath += L"temp.art";
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -119,16 +119,21 @@ std::wstring CPlayer::CreateCoverArtPath()
|
||||
// Replace reserved chars with _
|
||||
std::wstring::size_type pos = 0;
|
||||
while ((pos = name.find_first_of(L"\\/:*?\"<>|", pos)) != std::wstring::npos) name[pos] = L'_';
|
||||
|
||||
targetPath += name;
|
||||
targetPath += L".art";
|
||||
|
||||
m_CoverPath += name;
|
||||
m_CoverPath += L".art";
|
||||
if (_waccess(m_CoverPath.c_str(), 0) == 0)
|
||||
{
|
||||
// Art found in cache
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
return targetPath;
|
||||
return false;
|
||||
}
|
||||
|
||||
/*
|
||||
** GetArtLocal
|
||||
** GetLocalArt
|
||||
**
|
||||
** Attemps to find local cover art in various formats.
|
||||
**
|
||||
@ -162,12 +167,12 @@ bool CPlayer::GetLocalArt(std::wstring& folder, std::wstring filename)
|
||||
}
|
||||
|
||||
/*
|
||||
** GetEmbeddedCover
|
||||
** GetEmbeddedArt
|
||||
**
|
||||
** Attempts to extract cover art from audio files.
|
||||
**
|
||||
*/
|
||||
bool CPlayer::GetEmbeddedArt(const TagLib::FileRef& fr, std::wstring& path)
|
||||
bool CPlayer::GetEmbeddedArt(const TagLib::FileRef& fr)
|
||||
{
|
||||
bool found = false;
|
||||
|
||||
@ -175,60 +180,55 @@ bool CPlayer::GetEmbeddedArt(const TagLib::FileRef& fr, std::wstring& path)
|
||||
{
|
||||
if (file->ID3v2Tag())
|
||||
{
|
||||
found = GetArtID3(file->ID3v2Tag(), path);
|
||||
found = GetArtID3(file->ID3v2Tag());
|
||||
}
|
||||
if (!found && file->APETag())
|
||||
{
|
||||
found = GetArtAPE(file->APETag(), path);
|
||||
found = GetArtAPE(file->APETag());
|
||||
}
|
||||
}
|
||||
else if (TagLib::MP4::File* file = dynamic_cast<TagLib::MP4::File*>(fr.file()))
|
||||
{
|
||||
if (file->tag())
|
||||
{
|
||||
found = GetArtMP4(file, path);
|
||||
found = GetArtMP4(file);
|
||||
}
|
||||
}
|
||||
else if (TagLib::FLAC::File* file = dynamic_cast<TagLib::FLAC::File*>(fr.file()))
|
||||
{
|
||||
found = GetArtFLAC(file, path);
|
||||
found = GetArtFLAC(file);
|
||||
|
||||
if (!found && file->ID3v2Tag())
|
||||
{
|
||||
found = GetArtID3(file->ID3v2Tag(), path);
|
||||
found = GetArtID3(file->ID3v2Tag());
|
||||
}
|
||||
}
|
||||
else if (TagLib::ASF::File* file = dynamic_cast<TagLib::ASF::File*>(fr.file()))
|
||||
{
|
||||
found = GetArtASF(file, path);
|
||||
found = GetArtASF(file);
|
||||
}
|
||||
else if (TagLib::APE::File* file = dynamic_cast<TagLib::APE::File*>(fr.file()))
|
||||
{
|
||||
if (file->APETag())
|
||||
{
|
||||
found = GetArtAPE(file->APETag(), path);
|
||||
found = GetArtAPE(file->APETag());
|
||||
}
|
||||
}
|
||||
else if (TagLib::MPC::File* file = dynamic_cast<TagLib::MPC::File*>(fr.file()))
|
||||
{
|
||||
if (file->APETag())
|
||||
{
|
||||
found = GetArtAPE(file->APETag(), path);
|
||||
found = GetArtAPE(file->APETag());
|
||||
}
|
||||
}
|
||||
else if (TagLib::WavPack::File* file = dynamic_cast<TagLib::WavPack::File*>(fr.file()))
|
||||
{
|
||||
if (file->APETag())
|
||||
{
|
||||
found = GetArtAPE(file->APETag(), path);
|
||||
found = GetArtAPE(file->APETag());
|
||||
}
|
||||
}
|
||||
|
||||
if (found)
|
||||
{
|
||||
m_CoverPath = path;
|
||||
}
|
||||
|
||||
return found;
|
||||
}
|
||||
|
||||
@ -238,7 +238,7 @@ bool CPlayer::GetEmbeddedArt(const TagLib::FileRef& fr, std::wstring& path)
|
||||
** Extracts cover art embedded in APE tags.
|
||||
**
|
||||
*/
|
||||
bool CPlayer::GetArtAPE(TagLib::APE::Tag* tag, std::wstring& path)
|
||||
bool CPlayer::GetArtAPE(TagLib::APE::Tag* tag)
|
||||
{
|
||||
bool ret = false;
|
||||
const TagLib::APE::ItemListMap& listMap = tag->itemListMap();
|
||||
@ -254,7 +254,7 @@ bool CPlayer::GetArtAPE(TagLib::APE::Tag* tag, std::wstring& path)
|
||||
{
|
||||
const TagLib::ByteVector& pic = item.mid(pos);
|
||||
|
||||
FILE* f = _wfopen(path.c_str(), L"wb");
|
||||
FILE* f = _wfopen(m_CoverPath.c_str(), L"wb");
|
||||
if (f)
|
||||
{
|
||||
ret = (fwrite(pic.data(), 1, pic.size(), f) == pic.size());
|
||||
@ -272,7 +272,7 @@ bool CPlayer::GetArtAPE(TagLib::APE::Tag* tag, std::wstring& path)
|
||||
** Extracts cover art embedded in ID3v2 tags.
|
||||
**
|
||||
*/
|
||||
bool CPlayer::GetArtID3(TagLib::ID3v2::Tag* tag, std::wstring& path)
|
||||
bool CPlayer::GetArtID3(TagLib::ID3v2::Tag* tag)
|
||||
{
|
||||
bool ret = false;
|
||||
|
||||
@ -285,7 +285,7 @@ bool CPlayer::GetArtID3(TagLib::ID3v2::Tag* tag, std::wstring& path)
|
||||
|
||||
if (size > 0)
|
||||
{
|
||||
FILE* f = _wfopen(path.c_str(), L"wb");
|
||||
FILE* f = _wfopen(m_CoverPath.c_str(), L"wb");
|
||||
if (f)
|
||||
{
|
||||
ret = (fwrite(frame->picture().data(), 1, size, f) == size);
|
||||
@ -303,7 +303,7 @@ bool CPlayer::GetArtID3(TagLib::ID3v2::Tag* tag, std::wstring& path)
|
||||
** Extracts cover art embedded in ASF/WMA files.
|
||||
**
|
||||
*/
|
||||
bool CPlayer::GetArtASF(TagLib::ASF::File* file, std::wstring& path)
|
||||
bool CPlayer::GetArtASF(TagLib::ASF::File* file)
|
||||
{
|
||||
bool ret = false;
|
||||
|
||||
@ -320,7 +320,7 @@ bool CPlayer::GetArtASF(TagLib::ASF::File* file, std::wstring& path)
|
||||
|
||||
if (wmpic.isValid())
|
||||
{
|
||||
FILE* f = _wfopen(path.c_str(), L"wb");
|
||||
FILE* f = _wfopen(m_CoverPath.c_str(), L"wb");
|
||||
if (f)
|
||||
{
|
||||
ret = (fwrite(wmpic.picture().data(), 1, wmpic.picture().size(), f) == wmpic.picture().size());
|
||||
@ -339,7 +339,7 @@ bool CPlayer::GetArtASF(TagLib::ASF::File* file, std::wstring& path)
|
||||
** Extracts cover art embedded in FLAC files.
|
||||
**
|
||||
*/
|
||||
bool CPlayer::GetArtFLAC(TagLib::FLAC::File* file, std::wstring& path)
|
||||
bool CPlayer::GetArtFLAC(TagLib::FLAC::File* file)
|
||||
{
|
||||
bool ret = false;
|
||||
|
||||
@ -349,7 +349,7 @@ bool CPlayer::GetArtFLAC(TagLib::FLAC::File* file, std::wstring& path)
|
||||
// Let's grab the first image
|
||||
TagLib::FLAC::Picture* pic = picList[0];
|
||||
|
||||
FILE* f = _wfopen(path.c_str(), L"wb");
|
||||
FILE* f = _wfopen(m_CoverPath.c_str(), L"wb");
|
||||
if (f)
|
||||
{
|
||||
ret = (fwrite(pic->data().data(), 1, pic->data().size(), f) == pic->data().size());
|
||||
@ -366,7 +366,7 @@ bool CPlayer::GetArtFLAC(TagLib::FLAC::File* file, std::wstring& path)
|
||||
** Extracts cover art embedded in MP4-like files.
|
||||
**
|
||||
*/
|
||||
bool CPlayer::GetArtMP4(TagLib::MP4::File* file, std::wstring& path)
|
||||
bool CPlayer::GetArtMP4(TagLib::MP4::File* file)
|
||||
{
|
||||
bool ret = false;
|
||||
|
||||
@ -378,7 +378,7 @@ bool CPlayer::GetArtMP4(TagLib::MP4::File* file, std::wstring& path)
|
||||
|
||||
if (size > 0)
|
||||
{
|
||||
FILE* f = _wfopen(path.c_str(), L"wb");
|
||||
FILE* f = _wfopen(m_CoverPath.c_str(), L"wb");
|
||||
if (f)
|
||||
{
|
||||
ret = (fwrite(coverList[0].data().data(), 1, size, f) == size);
|
||||
|
@ -107,14 +107,14 @@ public:
|
||||
void ExecuteTrackChangeAction();
|
||||
void ClearInfo();
|
||||
|
||||
std::wstring CreateCoverArtPath();
|
||||
bool GetCachedArt();
|
||||
bool GetLocalArt(std::wstring& folder, std::wstring filename);
|
||||
bool GetEmbeddedArt(const TagLib::FileRef& fr, std::wstring& path);
|
||||
bool GetArtAPE(TagLib::APE::Tag* tag, std::wstring& path);
|
||||
bool GetArtID3(TagLib::ID3v2::Tag* tag, std::wstring& path);
|
||||
bool GetArtASF(TagLib::ASF::File* file, std::wstring& path);
|
||||
bool GetArtFLAC(TagLib::FLAC::File* file, std::wstring& path);
|
||||
bool GetArtMP4(TagLib::MP4::File* file, std::wstring& path);
|
||||
bool GetEmbeddedArt(const TagLib::FileRef& fr);
|
||||
bool GetArtAPE(TagLib::APE::Tag* tag);
|
||||
bool GetArtID3(TagLib::ID3v2::Tag* tag);
|
||||
bool GetArtASF(TagLib::ASF::File* file);
|
||||
bool GetArtFLAC(TagLib::FLAC::File* file);
|
||||
bool GetArtMP4(TagLib::MP4::File* file);
|
||||
|
||||
protected:
|
||||
int m_InstanceCount;
|
||||
|
@ -206,16 +206,14 @@ void CPlayerAIMP::UpdateData()
|
||||
|
||||
if (m_HasCoverMeasure)
|
||||
{
|
||||
std::wstring cover = CreateCoverArtPath();
|
||||
if (_waccess(cover.c_str(), 0) == 0)
|
||||
if (GetCachedArt())
|
||||
{
|
||||
// Cover is in cache, lets use the that
|
||||
m_CoverPath = cover;
|
||||
return;
|
||||
}
|
||||
|
||||
TagLib::FileRef fr(m_FilePath.c_str());
|
||||
if (!fr.isNull() && fr.tag() && GetEmbeddedArt(fr, cover))
|
||||
if (!fr.isNull() && fr.tag() && GetEmbeddedArt(fr))
|
||||
{
|
||||
// Embedded art found
|
||||
return;
|
||||
|
@ -271,16 +271,14 @@ void CPlayerFoobar::GetCoverArt(LPTSTR filename)
|
||||
// TODO: Fix temp solution
|
||||
if (m_HasCoverMeasure || m_InstanceCount == 0)
|
||||
{
|
||||
std::wstring cover = CreateCoverArtPath();
|
||||
if (_waccess(cover.c_str(), 0) == 0)
|
||||
if (GetCachedArt())
|
||||
{
|
||||
// Cover is in cache, lets use the that
|
||||
m_CoverPath = cover;
|
||||
return;
|
||||
}
|
||||
|
||||
TagLib::FileRef fr(filename);
|
||||
if (!fr.isNull() && fr.tag() && GetEmbeddedArt(fr, cover))
|
||||
if (!fr.isNull() && fr.tag() && GetEmbeddedArt(fr))
|
||||
{
|
||||
// Embedded art found
|
||||
return;
|
||||
|
@ -371,15 +371,9 @@ void CPlayerITunes::OnTrackChange()
|
||||
|
||||
if (m_HasCoverMeasure)
|
||||
{
|
||||
// Check if MP3 file contains embedded art
|
||||
std::wstring cover = CreateCoverArtPath();
|
||||
if (_waccess(cover.c_str(), 0) == 0)
|
||||
{
|
||||
// Cover is in cache, lets use the that
|
||||
m_CoverPath = cover;
|
||||
}
|
||||
else
|
||||
if (!GetCachedArt())
|
||||
{
|
||||
// Art not in cache, check for embedded art
|
||||
IITArtworkCollection* artworkCollection;
|
||||
hr = track->get_Artwork(&artworkCollection);
|
||||
|
||||
@ -395,9 +389,12 @@ void CPlayerITunes::OnTrackChange()
|
||||
|
||||
if (SUCCEEDED(hr))
|
||||
{
|
||||
tmpStr = cover.c_str();
|
||||
tmpStr = m_CoverPath.c_str();
|
||||
hr = artwork->SaveArtworkToFile(tmpStr);
|
||||
SUCCEEDED(hr) ? m_CoverPath = cover : m_CoverPath.clear();
|
||||
if (FAILED(hr))
|
||||
{
|
||||
m_CoverPath.clear();
|
||||
}
|
||||
|
||||
artwork->Release();
|
||||
}
|
||||
@ -409,6 +406,10 @@ void CPlayerITunes::OnTrackChange()
|
||||
|
||||
artworkCollection->Release();
|
||||
}
|
||||
else
|
||||
{
|
||||
m_CoverPath.clear();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -471,16 +471,14 @@ void CPlayerWMP::UpdateData()
|
||||
}
|
||||
else
|
||||
{
|
||||
std::wstring cover = CreateCoverArtPath();
|
||||
if (_waccess(cover.c_str(), 0) == 0)
|
||||
if (GetCachedArt())
|
||||
{
|
||||
// Cover is in cache, lets use the that
|
||||
m_CoverPath = cover;
|
||||
return;
|
||||
}
|
||||
|
||||
TagLib::FileRef fr(url.m_str);
|
||||
if (!fr.isNull() && fr.tag() && GetEmbeddedArt(fr, cover))
|
||||
if (!fr.isNull() && fr.tag() && GetEmbeddedArt(fr))
|
||||
{
|
||||
// Embedded art found
|
||||
return;
|
||||
|
@ -193,43 +193,41 @@ void CPlayerWinamp::UpdateData()
|
||||
}
|
||||
else
|
||||
{
|
||||
ClearInfo();
|
||||
|
||||
/*LPCVOID address = (LPCVOID)SendMessage(m_Window, WM_WA_IPC, 0, IPC_GETPLAYLISTTITLEW);
|
||||
if (ReadProcessMemory(m_WinampHandle, m_WinampAddress, &buffer, MAX_PATH, NULL))
|
||||
// TagLib couldn't parse the file, try title instead
|
||||
int pos = SendMessage(m_Window, WM_WA_IPC, 0, IPC_GETLISTPOS);
|
||||
LPCVOID address = (LPCVOID)SendMessage(m_Window, WM_WA_IPC, pos, IPC_GETPLAYLISTTITLEW);
|
||||
if (ReadProcessMemory(m_WinampHandle, address, &buffer, MAX_PATH, NULL))
|
||||
{
|
||||
std::wstring title = buffer;
|
||||
std::wstring::size_type pos = title.find(L" - ");
|
||||
std::wstring::size_type pos = title.find(L". ");
|
||||
|
||||
if (pos != std::wstring::npos && pos < 5)
|
||||
{
|
||||
pos += 2; // Skip ". "
|
||||
title.erase(0, pos);
|
||||
}
|
||||
|
||||
pos = title.find(L" - ");
|
||||
if (pos != std::wstring::npos)
|
||||
{
|
||||
std::wstring artist = title.substr(0, pos);
|
||||
std::wstring track = title.substr(pos + 3);
|
||||
|
||||
if (track != m_Title && artist != m_Artist)
|
||||
{
|
||||
m_Title = track;
|
||||
m_Artist = artist;
|
||||
m_Album.clear();
|
||||
}
|
||||
m_Title = title.substr(0, pos);
|
||||
pos += 3; // Skip " - "
|
||||
m_Artist = title.substr(pos);
|
||||
m_Album.clear();
|
||||
}
|
||||
}*/
|
||||
|
||||
return;
|
||||
else
|
||||
{
|
||||
ClearInfo();
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (m_HasCoverMeasure)
|
||||
{
|
||||
std::wstring cover = CreateCoverArtPath();
|
||||
if (_waccess(cover.c_str(), 0) == 0)
|
||||
if (GetCachedArt() || GetEmbeddedArt(fr))
|
||||
{
|
||||
// Cover is in cache, lets use the that
|
||||
m_CoverPath = cover;
|
||||
return;
|
||||
}
|
||||
|
||||
if (GetEmbeddedArt(fr, cover))
|
||||
{
|
||||
// Embedded art found
|
||||
// Art found in cache or embedded in file
|
||||
return;
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user