Arquivos
CuraEngine/src/progress/Progress.cpp
T

98 linhas
2.4 KiB
C++

/** Copyright (C) 2015 Ultimaker - Released under terms of the AGPLv3 License */
#include "Progress.h"
#include "../commandSocket.h"
#include "../utils/gettime.h"
namespace cura {
double Progress::times [] =
{
0.0, // START = 0,
5.269, // SLICING = 1,
1.533, // PARTS = 2,
71.811, // INSET_SKIN = 3
51.009, // SUPPORT = 4,
154.62, // EXPORT = 5,
0.1 // FINISH = 6
};
std::string Progress::names [] =
{
"start",
"slice",
"layerparts",
"inset+skin",
"support",
"export",
"process"
};
double Progress::accumulated_times [N_PROGRESS_STAGES] = {-1};
double Progress::total_timing = -1;
/*
const Progress::Stage Progress::stages[] =
{
Progress::Stage::START,
Progress::Stage::SLICING,
Progress::Stage::PARTS,
Progress::Stage::INSET_SKIN,
Progress::Stage::SUPPORT,
Progress::Stage::EXPORT,
Progress::Stage::FINISH
};
*/
float Progress::calcOverallProgress(Stage stage, float stage_progress)
{
return ( accumulated_times[(int)stage] + stage_progress * times[(int)stage] ) / total_timing;
}
void Progress::init()
{
double accumulated_time = 0;
for (int stage = 0; stage < N_PROGRESS_STAGES; stage++)
{
accumulated_times[(int)stage] = accumulated_time;
accumulated_time += times[(int)stage];
}
total_timing = accumulated_time;
}
void Progress::messageProgress(Progress::Stage stage, int progress_in_stage, int progress_in_stage_max)
{
float percentage = calcOverallProgress(stage, float(progress_in_stage) / float(progress_in_stage_max));
if (CommandSocket::getInstance())
{
CommandSocket::getInstance()->sendProgress(percentage);
}
logProgress(names[(int)stage].c_str(), progress_in_stage, progress_in_stage_max, percentage);
}
void Progress::messageProgressStage(Progress::Stage stage, TimeKeeper* time_keeper)
{
if (CommandSocket::getInstance())
{
CommandSocket::getInstance()->sendProgressStage(stage);
}
if (time_keeper)
{
if ((int)stage > 0)
{
log("Progress: %s accomplished in %5.3fs\n", names[(int)stage-1].c_str(), time_keeper->restart());
}
else
{
time_keeper->restart();
}
if ((int)stage < (int)Stage::FINISH)
log("Starting %s...\n", names[(int)stage].c_str());
}
}
}// namespace cura