ObjImporter: Added better progress reporting during file import.
There are two stages to this: 1) Processing '\'s - this accounts for 1/3rd of the file import progress. 2) Parsing the file data - this accounts for the other 2/3rds.pull/749/head
parent
bd268bd864
commit
1632f1fbb9
|
@ -145,6 +145,13 @@ void ObjFileImporter::InternReadFile( const std::string& pFile, aiScene* pScene,
|
||||||
modelName = pFile;
|
modelName = pFile;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// This next stage takes ~ 1/3th of the total readFile task
|
||||||
|
// so should amount for 1/3th of the progress
|
||||||
|
// only update every 100KB or it'll be too slow
|
||||||
|
unsigned int progress = 0;
|
||||||
|
unsigned int progressCounter = 0;
|
||||||
|
const unsigned int updateProgressEveryBytes = 100 * 1024;
|
||||||
|
const unsigned int progressTotal = (3*m_Buffer.size()/updateProgressEveryBytes);
|
||||||
// process all '\'
|
// process all '\'
|
||||||
std::vector<char> ::iterator iter = m_Buffer.begin();
|
std::vector<char> ::iterator iter = m_Buffer.begin();
|
||||||
while (iter != m_Buffer.end())
|
while (iter != m_Buffer.end())
|
||||||
|
@ -159,10 +166,19 @@ void ObjFileImporter::InternReadFile( const std::string& pFile, aiScene* pScene,
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
++iter;
|
++iter;
|
||||||
|
|
||||||
|
if (++progressCounter >= updateProgressEveryBytes)
|
||||||
|
{
|
||||||
|
m_progress->UpdateFileRead(++progress, progressTotal);
|
||||||
|
progressCounter = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 1/3rd progress
|
||||||
|
m_progress->UpdateFileRead(1, 3);
|
||||||
|
|
||||||
// parse the file into a temporary representation
|
// parse the file into a temporary representation
|
||||||
ObjFileParser parser(m_Buffer, modelName, pIOHandler);
|
ObjFileParser parser(m_Buffer, modelName, pIOHandler, m_progress);
|
||||||
|
|
||||||
// And create the proper return structures out of it
|
// And create the proper return structures out of it
|
||||||
CreateDataFromImport(parser.GetModel(), pScene);
|
CreateDataFromImport(parser.GetModel(), pScene);
|
||||||
|
|
|
@ -61,12 +61,13 @@ const std::string ObjFileParser::DEFAULT_MATERIAL = AI_DEFAULT_MATERIAL_NAME;
|
||||||
|
|
||||||
// -------------------------------------------------------------------
|
// -------------------------------------------------------------------
|
||||||
// Constructor with loaded data and directories.
|
// Constructor with loaded data and directories.
|
||||||
ObjFileParser::ObjFileParser(std::vector<char> &data,const std::string &modelName, IOSystem *io ) :
|
ObjFileParser::ObjFileParser(std::vector<char> &data,const std::string &modelName, IOSystem *io, ProgressHandler* progress ) :
|
||||||
m_DataIt(data.begin()),
|
m_DataIt(data.begin()),
|
||||||
m_DataItEnd(data.end()),
|
m_DataItEnd(data.end()),
|
||||||
m_pModel(NULL),
|
m_pModel(NULL),
|
||||||
m_uiLine(0),
|
m_uiLine(0),
|
||||||
m_pIO( io )
|
m_pIO( io ),
|
||||||
|
m_progress(progress)
|
||||||
{
|
{
|
||||||
std::fill_n(m_buffer,Buffersize,0);
|
std::fill_n(m_buffer,Buffersize,0);
|
||||||
|
|
||||||
|
@ -106,8 +107,28 @@ void ObjFileParser::parseFile()
|
||||||
if (m_DataIt == m_DataItEnd)
|
if (m_DataIt == m_DataItEnd)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
// only update every 100KB or it'll be too slow
|
||||||
|
const unsigned int updateProgressEveryBytes = 100 * 1024;
|
||||||
|
unsigned int progressCounter = 0;
|
||||||
|
const unsigned int bytesToProcess = std::distance(m_DataIt, m_DataItEnd);
|
||||||
|
const unsigned int progressTotal = 3 * bytesToProcess;
|
||||||
|
const unsigned int progressOffset = bytesToProcess;
|
||||||
|
unsigned int processed = 0;
|
||||||
|
|
||||||
|
DataArrayIt lastDataIt = m_DataIt;
|
||||||
|
|
||||||
while (m_DataIt != m_DataItEnd)
|
while (m_DataIt != m_DataItEnd)
|
||||||
{
|
{
|
||||||
|
// Handle progress reporting
|
||||||
|
processed += std::distance(lastDataIt, m_DataIt);
|
||||||
|
lastDataIt = m_DataIt;
|
||||||
|
if (processed > (progressCounter * updateProgressEveryBytes))
|
||||||
|
{
|
||||||
|
progressCounter++;
|
||||||
|
m_progress->UpdateFileRead(progressOffset + processed*2, progressTotal);
|
||||||
|
}
|
||||||
|
|
||||||
|
// parse line
|
||||||
switch (*m_DataIt)
|
switch (*m_DataIt)
|
||||||
{
|
{
|
||||||
case 'v': // Parse a vertex texture coordinate
|
case 'v': // Parse a vertex texture coordinate
|
||||||
|
|
|
@ -59,6 +59,7 @@ namespace ObjFile {
|
||||||
|
|
||||||
class ObjFileImporter;
|
class ObjFileImporter;
|
||||||
class IOSystem;
|
class IOSystem;
|
||||||
|
class ProgressHandler;
|
||||||
|
|
||||||
/// \class ObjFileParser
|
/// \class ObjFileParser
|
||||||
/// \brief Parser for a obj waveform file
|
/// \brief Parser for a obj waveform file
|
||||||
|
@ -71,7 +72,7 @@ public:
|
||||||
|
|
||||||
public:
|
public:
|
||||||
/// \brief Constructor with data array.
|
/// \brief Constructor with data array.
|
||||||
ObjFileParser(std::vector<char> &Data,const std::string &strModelName, IOSystem* io);
|
ObjFileParser(std::vector<char> &Data,const std::string &strModelName, IOSystem* io, ProgressHandler* progress);
|
||||||
/// \brief Destructor
|
/// \brief Destructor
|
||||||
~ObjFileParser();
|
~ObjFileParser();
|
||||||
/// \brief Model getter.
|
/// \brief Model getter.
|
||||||
|
@ -139,6 +140,8 @@ private:
|
||||||
char m_buffer[Buffersize];
|
char m_buffer[Buffersize];
|
||||||
/// Pointer to IO system instance.
|
/// Pointer to IO system instance.
|
||||||
IOSystem *m_pIO;
|
IOSystem *m_pIO;
|
||||||
|
//! Pointer to progress handler
|
||||||
|
ProgressHandler* m_progress;
|
||||||
/// Path to the current model
|
/// Path to the current model
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue