mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-26 21:35:28 +00:00
Make some updated to hires texture loading ect.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@3235 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
parent
14a67bc8bc
commit
80e2052372
@ -19,6 +19,7 @@
|
|||||||
|
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
#include <algorithm>
|
||||||
#include "SOIL.h"
|
#include "SOIL.h"
|
||||||
#include "CommonPaths.h"
|
#include "CommonPaths.h"
|
||||||
#include "FileUtil.h"
|
#include "FileUtil.h"
|
||||||
@ -34,26 +35,26 @@ void Init(const char *gameCode)
|
|||||||
CFileSearch::XStringVector Directories;
|
CFileSearch::XStringVector Directories;
|
||||||
Directories.push_back(std::string(FULL_HIRES_TEXTURES_DIR));
|
Directories.push_back(std::string(FULL_HIRES_TEXTURES_DIR));
|
||||||
|
|
||||||
for(u32 i = 0; i < Directories.size(); i++)
|
for (u32 i = 0; i < Directories.size(); i++)
|
||||||
{
|
{
|
||||||
File::FSTEntry FST_Temp;
|
File::FSTEntry FST_Temp;
|
||||||
File::ScanDirectoryTree(Directories.at(i).c_str(), FST_Temp);
|
File::ScanDirectoryTree(Directories.at(i).c_str(), FST_Temp);
|
||||||
for(u32 j = 0; j < FST_Temp.children.size(); j++)
|
for (u32 j = 0; j < FST_Temp.children.size(); j++)
|
||||||
{
|
{
|
||||||
if(FST_Temp.children.at(j).isDirectory)
|
if (FST_Temp.children.at(j).isDirectory)
|
||||||
{
|
{
|
||||||
bool duplicate = false;
|
bool duplicate = false;
|
||||||
NormalizeDirSep(&(FST_Temp.children.at(j).physicalName));
|
NormalizeDirSep(&(FST_Temp.children.at(j).physicalName));
|
||||||
for(u32 k = 0; k < Directories.size(); k++)
|
for (u32 k = 0; k < Directories.size(); k++)
|
||||||
{
|
{
|
||||||
NormalizeDirSep(&Directories.at(k));
|
NormalizeDirSep(&Directories.at(k));
|
||||||
if(strcmp(Directories.at(k).c_str(), FST_Temp.children.at(j).physicalName.c_str()) == 0)
|
if (strcmp(Directories.at(k).c_str(), FST_Temp.children.at(j).physicalName.c_str()) == 0)
|
||||||
{
|
{
|
||||||
duplicate = true;
|
duplicate = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(!duplicate)
|
if (!duplicate)
|
||||||
Directories.push_back(FST_Temp.children.at(j).physicalName.c_str());
|
Directories.push_back(FST_Temp.children.at(j).physicalName.c_str());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -64,18 +65,21 @@ void Init(const char *gameCode)
|
|||||||
Extensions.push_back("*.bmp");
|
Extensions.push_back("*.bmp");
|
||||||
Extensions.push_back("*.tga");
|
Extensions.push_back("*.tga");
|
||||||
Extensions.push_back("*.dds");
|
Extensions.push_back("*.dds");
|
||||||
|
Extensions.push_back("*.jpg"); // Why not? Could be useful for large photo-like textures
|
||||||
|
|
||||||
CFileSearch FileSearch(Extensions, Directories);
|
CFileSearch FileSearch(Extensions, Directories);
|
||||||
const CFileSearch::XStringVector& rFilenames = FileSearch.GetFileNames();
|
const CFileSearch::XStringVector& rFilenames = FileSearch.GetFileNames();
|
||||||
|
char code[MAX_PATH];
|
||||||
|
sprintf(code, "%s_", gameCode);
|
||||||
|
|
||||||
if(rFilenames.size() > 0)
|
if (rFilenames.size() > 0)
|
||||||
{
|
{
|
||||||
for(u32 i = 0; i < rFilenames.size(); i++)
|
for (u32 i = 0; i < rFilenames.size(); i++)
|
||||||
{
|
{
|
||||||
std::string FileName;
|
std::string FileName;
|
||||||
SplitPath(rFilenames[i], NULL, &FileName, NULL);
|
SplitPath(rFilenames[i], NULL, &FileName, NULL);
|
||||||
|
|
||||||
if(FileName.substr(0, strlen(gameCode)).compare(gameCode) == 0 && textureMap.find(FileName) == textureMap.end())
|
if (FileName.substr(0, strlen(code)).compare(code) == 0 && textureMap.find(FileName) == textureMap.end())
|
||||||
textureMap.insert(std::map<std::string, std::string>::value_type(FileName, rFilenames[i]));
|
textureMap.insert(std::map<std::string, std::string>::value_type(FileName, rFilenames[i]));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -86,7 +90,7 @@ void Shutdown()
|
|||||||
textureMap.clear();
|
textureMap.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
PC_TexFormat GetHiresTex(const char *fileName, int *pWidth, int *pHeight, u8 *data)
|
PC_TexFormat GetHiresTex(const char *fileName, int *pWidth, int *pHeight, int texformat, u8 *data)
|
||||||
{
|
{
|
||||||
std::string key(fileName);
|
std::string key(fileName);
|
||||||
|
|
||||||
@ -96,6 +100,7 @@ PC_TexFormat GetHiresTex(const char *fileName, int *pWidth, int *pHeight, u8 *da
|
|||||||
int width;
|
int width;
|
||||||
int height;
|
int height;
|
||||||
int channels;
|
int channels;
|
||||||
|
|
||||||
u8 *temp = SOIL_load_image(textureMap[key].c_str(), &width, &height, &channels, SOIL_LOAD_RGBA);
|
u8 *temp = SOIL_load_image(textureMap[key].c_str(), &width, &height, &channels, SOIL_LOAD_RGBA);
|
||||||
|
|
||||||
if (temp == NULL) {
|
if (temp == NULL) {
|
||||||
@ -110,11 +115,34 @@ PC_TexFormat GetHiresTex(const char *fileName, int *pWidth, int *pHeight, u8 *da
|
|||||||
return PC_TEX_FMT_NONE;
|
return PC_TEX_FMT_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
memcpy(data, temp, width*height*4);
|
int offset = 0;
|
||||||
|
PC_TexFormat returnTex;
|
||||||
|
|
||||||
|
switch (texformat)
|
||||||
|
{
|
||||||
|
case GX_TF_I4:
|
||||||
|
case GX_TF_I8:
|
||||||
|
case GX_TF_IA4:
|
||||||
|
case GX_TF_IA8:
|
||||||
|
for (int i = 0; i < width * height * 4; i += 4)
|
||||||
|
{
|
||||||
|
// Rather than use a luminosity function, just use the most intense color for luminance
|
||||||
|
data[offset++] = *std::max_element(temp+i, temp+i+3);
|
||||||
|
data[offset++] = temp[i+3];
|
||||||
|
}
|
||||||
|
returnTex = PC_TEX_FMT_IA8;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
memcpy(data, temp, width*height*4);
|
||||||
|
returnTex = PC_TEX_FMT_RGBA32;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
*pWidth = width;
|
*pWidth = width;
|
||||||
*pHeight = height;
|
*pHeight = height;
|
||||||
SOIL_free_image_data(temp);
|
SOIL_free_image_data(temp);
|
||||||
return PC_TEX_FMT_RGBA32;
|
INFO_LOG(VIDEO, "loading custom texture from %s", textureMap[key].c_str());
|
||||||
|
return returnTex;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -26,7 +26,7 @@ namespace HiresTextures
|
|||||||
{
|
{
|
||||||
void Init(const char *gameCode);
|
void Init(const char *gameCode);
|
||||||
void Shutdown();
|
void Shutdown();
|
||||||
PC_TexFormat GetHiresTex(const char *fileName, int *pWidth, int *pHeight, u8 *data);
|
PC_TexFormat GetHiresTex(const char *fileName, int *pWidth, int *pHeight, int texformat, u8 *data);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -332,7 +332,7 @@ TextureMngr::TCacheEntry* TextureMngr::Load(int texstage, u32 address, int width
|
|||||||
|
|
||||||
//Make an entry in the table
|
//Make an entry in the table
|
||||||
TCacheEntry& entry = textures[texID];
|
TCacheEntry& entry = textures[texID];
|
||||||
PC_TexFormat dfmt = PC_TEX_FMT_NONE;
|
PC_TexFormat dfmt = PC_TEX_FMT_NONE;
|
||||||
|
|
||||||
if (g_Config.bHiresTextures)
|
if (g_Config.bHiresTextures)
|
||||||
{
|
{
|
||||||
@ -341,16 +341,14 @@ TextureMngr::TCacheEntry* TextureMngr::Load(int texstage, u32 address, int width
|
|||||||
int oldWidth = width;
|
int oldWidth = width;
|
||||||
int oldHeight = height;
|
int oldHeight = height;
|
||||||
sprintf(texPathTemp, "%s_%08x_%i", ((struct SConfig *)globals->config)->m_LocalCoreStartupParameter.GetUniqueID().c_str(), texHash, tex_format);
|
sprintf(texPathTemp, "%s_%08x_%i", ((struct SConfig *)globals->config)->m_LocalCoreStartupParameter.GetUniqueID().c_str(), texHash, tex_format);
|
||||||
dfmt = HiresTextures::GetHiresTex(texPathTemp, &width, &height, temp);
|
dfmt = HiresTextures::GetHiresTex(texPathTemp, &width, &height, tex_format, temp);
|
||||||
|
|
||||||
if (dfmt != PC_TEX_FMT_NONE)
|
if (dfmt != PC_TEX_FMT_NONE)
|
||||||
{
|
{
|
||||||
expandedWidth = width;
|
expandedWidth = width;
|
||||||
expandedHeight = height;
|
expandedHeight = height;
|
||||||
entry.size_in_bytes = sizeof(temp);
|
|
||||||
entry.scaleX = (float) width / oldWidth;
|
entry.scaleX = (float) width / oldWidth;
|
||||||
entry.scaleY = (float) height / oldHeight;
|
entry.scaleY = (float) height / oldHeight;
|
||||||
INFO_LOG(VIDEO, "loading custom texture from %s", texPathTemp);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -462,7 +460,7 @@ TextureMngr::TCacheEntry* TextureMngr::Load(int texstage, u32 address, int width
|
|||||||
if (g_Config.bDumpTextures) // dump texture to file
|
if (g_Config.bDumpTextures) // dump texture to file
|
||||||
{
|
{
|
||||||
char szTemp[MAX_PATH];
|
char szTemp[MAX_PATH];
|
||||||
|
&m_LastFilename
|
||||||
sprintf(szTemp, "%s/%s_%08x_%i.tga", FULL_DUMP_TEXTURES_DIR, ((struct SConfig *)globals->config)->m_LocalCoreStartupParameter.GetUniqueID().c_str(), texHash, tex_format);
|
sprintf(szTemp, "%s/%s_%08x_%i.tga", FULL_DUMP_TEXTURES_DIR, ((struct SConfig *)globals->config)->m_LocalCoreStartupParameter.GetUniqueID().c_str(), texHash, tex_format);
|
||||||
if (!File::Exists(szTemp))
|
if (!File::Exists(szTemp))
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user