finished CubemapConvert codes, but not run test.
This commit is contained in:
parent
f86f862522
commit
4fbbba2c64
@ -19,7 +19,7 @@ bool ConvertImage(const OSString &filename,const ImageConvertConfig *cfg)
|
||||
|
||||
const uint channels=image.channels();
|
||||
|
||||
if(channels<0||channels>4)
|
||||
if(channels<=0||channels>4)
|
||||
{
|
||||
LOG_ERROR(OS_TEXT("image format don't support "));
|
||||
return(false);
|
||||
|
@ -1,6 +1,7 @@
|
||||
#include<iostream>
|
||||
#include<hgl/util/cmd/CmdParse.h>
|
||||
#include<hgl/filesystem/FileSystem.h>
|
||||
#include<hgl/type/StringList.h>
|
||||
#include"ILImage.h"
|
||||
#include"TextureFileCreater.h"
|
||||
#include"ImageConvertConfig.h"
|
||||
@ -11,35 +12,61 @@ using namespace hgl;
|
||||
using namespace hgl::filesystem;
|
||||
using namespace hgl::util;
|
||||
|
||||
bool ConvertImage(const OSString &filename,const ImageConvertConfig *cfg)
|
||||
bool ConvertCubemap(const OSString &filename,const OSStringList &file_list,const ImageConvertConfig *cfg)
|
||||
{
|
||||
ILImage image;
|
||||
ILImage image[6];
|
||||
|
||||
if(!image.LoadFile(filename))
|
||||
uint width,height,channels,bits;
|
||||
|
||||
for(int i=0;i<6;i++)
|
||||
{
|
||||
if(!image[i].LoadFile(file_list[i]))
|
||||
return(false);
|
||||
|
||||
if(i==0)
|
||||
{
|
||||
width=image[0].width();
|
||||
height=image[0].height();
|
||||
channels=image[0].channels();
|
||||
bits=image[0].bit();
|
||||
}
|
||||
else
|
||||
{
|
||||
if(width!=image[i].width()
|
||||
||height!=image[i].height()
|
||||
||channels!=image[i].channels()
|
||||
||bits!=image[i].bit())
|
||||
{
|
||||
LOG_ERROR(OS_TEXT("image formats can't batch"));
|
||||
return(false);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
int miplevel=1;
|
||||
|
||||
if(cfg->gen_mipmaps)
|
||||
miplevel=hgl::GetMipLevel(image.width(),image.height());
|
||||
miplevel=hgl::GetMipLevel(width,height);
|
||||
|
||||
const uint channels=image.channels();
|
||||
|
||||
if(channels<0||channels>4)
|
||||
if(channels<=0||channels>4)
|
||||
{
|
||||
LOG_ERROR(OS_TEXT("image format don't support "));
|
||||
return(false);
|
||||
}
|
||||
|
||||
TextureFileCreater *tex_file_creater;
|
||||
const PixelFormat *fmt=cfg->pixel_fmt[channels-1];
|
||||
|
||||
Image2D *origin_img=nullptr;
|
||||
uint total=0;
|
||||
uint bytes=0;
|
||||
|
||||
for(int face=0;face<6;face++)
|
||||
{
|
||||
TextureFileCreater *tex_file_creater;
|
||||
|
||||
if(fmt->format<ColorFormat::COMPRESS)
|
||||
tex_file_creater=CreateTFC[channels-1](fmt,&image);
|
||||
tex_file_creater=CreateTFC[channels-1](fmt,&image[face]);
|
||||
else
|
||||
tex_file_creater=CreateTextureFileCreaterCompress(fmt,&image);
|
||||
tex_file_creater=CreateTextureFileCreaterCompress(fmt,&image[face]);
|
||||
|
||||
if(!tex_file_creater->WriteFileHeader(filename,TextureFileType::TexCubemap,miplevel))
|
||||
{
|
||||
@ -50,11 +77,6 @@ bool ConvertImage(const OSString &filename,const ImageConvertConfig *cfg)
|
||||
|
||||
tex_file_creater->InitFormat();
|
||||
|
||||
uint width=image.width();
|
||||
uint height=image.height();
|
||||
uint total=0;
|
||||
uint bytes=0;
|
||||
|
||||
for(int i=0;i<miplevel;i++)
|
||||
{
|
||||
bytes=tex_file_creater->Write();
|
||||
@ -72,15 +94,16 @@ bool ConvertImage(const OSString &filename,const ImageConvertConfig *cfg)
|
||||
if(width>1)width>>=1;
|
||||
if(height>1)height>>=1;
|
||||
|
||||
image.Resize(width,height);
|
||||
image[face].Resize(width,height);
|
||||
}
|
||||
}
|
||||
|
||||
LOG_INFO(OS_TEXT("pixel total length: ")+OSString::valueOf(total)+OS_TEXT(" bytes."));
|
||||
|
||||
tex_file_creater->Close();
|
||||
|
||||
delete tex_file_creater;
|
||||
}
|
||||
|
||||
LOG_INFO(OS_TEXT("pixel total length: ")+OSString::valueOf(total)+OS_TEXT(" bytes."));
|
||||
return(true);
|
||||
}
|
||||
|
||||
@ -92,10 +115,10 @@ int os_main(int argc,os_char **argv)
|
||||
{
|
||||
std::cout<<"Cubemap to Texture Convert tools 1.2"<<std::endl<<std::endl;
|
||||
|
||||
if(argc<=1)
|
||||
if(argc<=7)
|
||||
{
|
||||
std::cout<< "Command format:\n"
|
||||
"\tCubemapConv [/R:][/RG:][/RGB:][/RGBA:] [/mip] <filename>\n\n";
|
||||
"\tCubemapConv [/R:][/RG:][/RGB:][/RGBA:] [/mip] <output texture filename> <neg x>,<neg y>,<neg z>,<pos x>,<pos y>,<pos z>\n\n";
|
||||
|
||||
PrintFormatList();
|
||||
return 0;
|
||||
@ -115,9 +138,22 @@ int os_main(int argc,os_char **argv)
|
||||
CMP_RegisterHostPlugins();
|
||||
CMP_InitializeBCLibrary();
|
||||
|
||||
if(filesystem::FileCanRead(argv[argc-1]))
|
||||
OSString out_filename=argv[argc-8];
|
||||
OSStringList file_list;
|
||||
|
||||
for(int i=argc-7;i<argc-1;i++)
|
||||
{
|
||||
ConvertImage(argv[argc-1],&icc);
|
||||
if(filesystem::FileCanRead(argv[i]))
|
||||
file_list.Add(argv[i]);
|
||||
}
|
||||
|
||||
if(file_list.GetCount()==6)
|
||||
{
|
||||
os_out<<OS_TEXT("output: ")<<out_filename.c_str()<<std::endl;
|
||||
for(int i=0;i<6;i++)
|
||||
os_out<<OS_TEXT("source ")<<OSString::valueOf(i).c_str()<<OS_TEXT(": ")<<file_list[i].c_str()<<std::endl;
|
||||
|
||||
ConvertCubemap(out_filename,file_list,&icc);
|
||||
}
|
||||
|
||||
CMP_ShutdownBCLibrary();
|
||||
|
@ -194,12 +194,15 @@ bool ILImage::LoadFile(const OSString &filename)
|
||||
|
||||
if(!filesystem::FileExist(filename))
|
||||
{
|
||||
LOG_INFO(OS_TEXT("Can't find filename: ")+filename);
|
||||
LOG_ERROR(OS_TEXT("Can't find filename: ")+filename);
|
||||
return(false);
|
||||
}
|
||||
|
||||
if(!ilLoadImage(filename.c_str()))
|
||||
{
|
||||
LOG_ERROR(OS_TEXT("can't Load image: ")+filename);
|
||||
return(false);
|
||||
}
|
||||
|
||||
LOG_INFO(OS_TEXT("\nFile: ")+filename);
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user