mirror of
https://github.com/leozide/leocad
synced 2025-01-14 08:01:45 +01:00
Added --export-csv command line option.
This commit is contained in:
parent
37dd02ee08
commit
3abe683d2b
5 changed files with 61 additions and 40 deletions
|
@ -354,20 +354,6 @@ lcCommandLineOptions lcApplication::ParseCommandLineOptions()
|
||||||
|
|
||||||
lcCommandLineOptions Options;
|
lcCommandLineOptions Options;
|
||||||
|
|
||||||
Options.ParseOK = true;
|
|
||||||
Options.Exit = false;
|
|
||||||
Options.SaveImage = false;
|
|
||||||
Options.SaveWavefront = false;
|
|
||||||
Options.Save3DS = false;
|
|
||||||
Options.SaveCOLLADA = false;
|
|
||||||
Options.SaveHTML = false;
|
|
||||||
Options.SetCameraAngles = false;
|
|
||||||
Options.SetCameraPosition = false;
|
|
||||||
Options.Orthographic = false;
|
|
||||||
Options.SetFoV = false;
|
|
||||||
Options.SetZPlanes = false;
|
|
||||||
Options.SetFadeStepsColor = false;
|
|
||||||
Options.SetHighlightColor = false;
|
|
||||||
Options.FadeSteps = Preferences.mFadeSteps;
|
Options.FadeSteps = Preferences.mFadeSteps;
|
||||||
Options.ImageHighlight = Preferences.mHighlightNewParts;
|
Options.ImageHighlight = Preferences.mHighlightNewParts;
|
||||||
Options.ImageWidth = lcGetProfileInt(LC_PROFILE_IMAGE_WIDTH);
|
Options.ImageWidth = lcGetProfileInt(LC_PROFILE_IMAGE_WIDTH);
|
||||||
|
@ -788,6 +774,11 @@ lcCommandLineOptions lcApplication::ParseCommandLineOptions()
|
||||||
Options.SaveCOLLADA = true;
|
Options.SaveCOLLADA = true;
|
||||||
ParseString(Options.SaveCOLLADAName, false);
|
ParseString(Options.SaveCOLLADAName, false);
|
||||||
}
|
}
|
||||||
|
else if (Option == QLatin1String("-csv") || Option == QLatin1String("--export-csv"))
|
||||||
|
{
|
||||||
|
Options.SaveCSV = true;
|
||||||
|
ParseString(Options.SaveCSVName, false);
|
||||||
|
}
|
||||||
else if (Option == QLatin1String("-html") || Option == QLatin1String("--export-html"))
|
else if (Option == QLatin1String("-html") || Option == QLatin1String("--export-html"))
|
||||||
{
|
{
|
||||||
Options.SaveHTML = true;
|
Options.SaveHTML = true;
|
||||||
|
@ -842,6 +833,7 @@ lcCommandLineOptions lcApplication::ParseCommandLineOptions()
|
||||||
Options.StdOut += tr(" -obj, --export-wavefront <outfile.obj>: Export the model to Wavefront OBJ format.\n");
|
Options.StdOut += tr(" -obj, --export-wavefront <outfile.obj>: Export the model to Wavefront OBJ format.\n");
|
||||||
Options.StdOut += tr(" -3ds, --export-3ds <outfile.3ds>: Export the model to 3D Studio 3DS format.\n");
|
Options.StdOut += tr(" -3ds, --export-3ds <outfile.3ds>: Export the model to 3D Studio 3DS format.\n");
|
||||||
Options.StdOut += tr(" -dae, --export-collada <outfile.dae>: Export the model to COLLADA DAE format.\n");
|
Options.StdOut += tr(" -dae, --export-collada <outfile.dae>: Export the model to COLLADA DAE format.\n");
|
||||||
|
Options.StdOut += tr(" -csv, --export-csv <outfile.csv>: Export the list of parts used in csv format.\n");
|
||||||
Options.StdOut += tr(" -html, --export-html <folder>: Create an HTML page for the model.\n");
|
Options.StdOut += tr(" -html, --export-html <folder>: Create an HTML page for the model.\n");
|
||||||
Options.StdOut += tr(" -v, --version: Output version information and exit.\n");
|
Options.StdOut += tr(" -v, --version: Output version information and exit.\n");
|
||||||
Options.StdOut += tr(" -?, --help: Display this help message and exit.\n");
|
Options.StdOut += tr(" -?, --help: Display this help message and exit.\n");
|
||||||
|
@ -888,7 +880,7 @@ lcCommandLineOptions lcApplication::ParseCommandLineOptions()
|
||||||
Options.StdErr += tr("--camera-position is ignored when --camera-angles is set.\n");
|
Options.StdErr += tr("--camera-position is ignored when --camera-angles is set.\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
const bool SaveAndExit = (Options.SaveImage || Options.SaveWavefront || Options.Save3DS || Options.SaveCOLLADA || Options.SaveHTML);
|
const bool SaveAndExit = (Options.SaveImage || Options.SaveWavefront || Options.Save3DS || Options.SaveCOLLADA || Options.SaveCSV || Options.SaveHTML);
|
||||||
|
|
||||||
if (SaveAndExit && Options.ProjectName.isEmpty())
|
if (SaveAndExit && Options.ProjectName.isEmpty())
|
||||||
{
|
{
|
||||||
|
@ -929,7 +921,7 @@ lcStartupMode lcApplication::Initialize(const QList<QPair<QString, bool>>& Libra
|
||||||
return lcStartupMode::Error;
|
return lcStartupMode::Error;
|
||||||
}
|
}
|
||||||
|
|
||||||
const bool SaveAndExit = (Options.SaveImage || Options.SaveWavefront || Options.Save3DS || Options.SaveCOLLADA || Options.SaveHTML);
|
const bool SaveAndExit = (Options.SaveImage || Options.SaveWavefront || Options.Save3DS || Options.SaveCOLLADA || Options.SaveCSV || Options.SaveHTML);
|
||||||
|
|
||||||
if (!SaveAndExit)
|
if (!SaveAndExit)
|
||||||
{
|
{
|
||||||
|
@ -1191,6 +1183,31 @@ lcStartupMode lcApplication::Initialize(const QList<QPair<QString, bool>>& Libra
|
||||||
StdOut << tr("Saved '%1'.\n").arg(FileName);
|
StdOut << tr("Saved '%1'.\n").arg(FileName);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (Options.SaveCSV)
|
||||||
|
{
|
||||||
|
QString FileName;
|
||||||
|
|
||||||
|
if (!Options.SaveCSVName.isEmpty())
|
||||||
|
FileName = Options.SaveCSVName;
|
||||||
|
else
|
||||||
|
FileName = Options.ProjectName;
|
||||||
|
|
||||||
|
QString Extension = QFileInfo(FileName).suffix().toLower();
|
||||||
|
|
||||||
|
if (Extension.isEmpty())
|
||||||
|
{
|
||||||
|
FileName += ".csv";
|
||||||
|
}
|
||||||
|
else if (Extension != "csv")
|
||||||
|
{
|
||||||
|
FileName = FileName.left(FileName.length() - Extension.length() - 1);
|
||||||
|
FileName += ".csv";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mProject->ExportCSV(FileName))
|
||||||
|
StdOut << tr("Saved '%1'.\n").arg(FileName);
|
||||||
|
}
|
||||||
|
|
||||||
if (Options.SaveHTML)
|
if (Options.SaveHTML)
|
||||||
{
|
{
|
||||||
lcHTMLExportOptions HTMLOptions(mProject);
|
lcHTMLExportOptions HTMLOptions(mProject);
|
||||||
|
|
|
@ -101,23 +101,24 @@ public:
|
||||||
|
|
||||||
struct lcCommandLineOptions
|
struct lcCommandLineOptions
|
||||||
{
|
{
|
||||||
bool ParseOK;
|
bool ParseOK = true;
|
||||||
bool Exit;
|
bool Exit = false;
|
||||||
bool SaveImage;
|
bool SaveImage = false;
|
||||||
bool SaveWavefront;
|
bool SaveWavefront = false;
|
||||||
bool Save3DS;
|
bool Save3DS = false;
|
||||||
bool SaveCOLLADA;
|
bool SaveCOLLADA = false;
|
||||||
bool SaveHTML;
|
bool SaveCSV = false;
|
||||||
bool SetCameraAngles;
|
bool SaveHTML = false;
|
||||||
bool SetCameraPosition;
|
bool SetCameraAngles = false;
|
||||||
bool Orthographic;
|
bool SetCameraPosition = false;
|
||||||
bool SetFoV;
|
bool Orthographic = false;
|
||||||
bool SetZPlanes;
|
bool SetFoV = false;
|
||||||
bool SetFadeStepsColor;
|
bool SetZPlanes = false;
|
||||||
bool SetHighlightColor;
|
bool SetFadeStepsColor = false;
|
||||||
bool FadeSteps;
|
bool SetHighlightColor = false;
|
||||||
bool ImageHighlight;
|
bool FadeSteps = false;
|
||||||
bool AutomateEdgeColor;
|
bool ImageHighlight = false;
|
||||||
|
bool AutomateEdgeColor = false;
|
||||||
int ImageWidth;
|
int ImageWidth;
|
||||||
int ImageHeight;
|
int ImageHeight;
|
||||||
int AASamples;
|
int AASamples;
|
||||||
|
@ -146,6 +147,7 @@ struct lcCommandLineOptions
|
||||||
QString SaveWavefrontName;
|
QString SaveWavefrontName;
|
||||||
QString Save3DSName;
|
QString Save3DSName;
|
||||||
QString SaveCOLLADAName;
|
QString SaveCOLLADAName;
|
||||||
|
QString SaveCSVName;
|
||||||
QString SaveHTMLName;
|
QString SaveHTMLName;
|
||||||
QList<QPair<QString, bool>> LibraryPaths;
|
QList<QPair<QString, bool>> LibraryPaths;
|
||||||
QString StdOut;
|
QString StdOut;
|
||||||
|
|
|
@ -2590,7 +2590,7 @@ void lcMainWindow::HandleCommand(lcCommandId CommandId)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LC_FILE_EXPORT_CSV:
|
case LC_FILE_EXPORT_CSV:
|
||||||
lcGetActiveProject()->ExportCSV();
|
lcGetActiveProject()->ExportCSV(QString());
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LC_FILE_EXPORT_POVRAY:
|
case LC_FILE_EXPORT_POVRAY:
|
||||||
|
|
|
@ -1428,7 +1428,7 @@ bool Project::ExportCOLLADA(const QString& FileName)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Project::ExportCSV()
|
bool Project::ExportCSV(const QString& FileName)
|
||||||
{
|
{
|
||||||
lcPartsList PartsList;
|
lcPartsList PartsList;
|
||||||
|
|
||||||
|
@ -1438,13 +1438,13 @@ void Project::ExportCSV()
|
||||||
if (PartsList.empty())
|
if (PartsList.empty())
|
||||||
{
|
{
|
||||||
QMessageBox::information(gMainWindow, tr("LeoCAD"), tr("Nothing to export."));
|
QMessageBox::information(gMainWindow, tr("LeoCAD"), tr("Nothing to export."));
|
||||||
return;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString SaveFileName = GetExportFileName(QString(), "csv", tr("Export CSV"), tr("CSV Files (*.csv);;All Files (*.*)"));
|
QString SaveFileName = GetExportFileName(FileName, "csv", tr("Export CSV"), tr("CSV Files (*.csv);;All Files (*.*)"));
|
||||||
|
|
||||||
if (SaveFileName.isEmpty())
|
if (SaveFileName.isEmpty())
|
||||||
return;
|
return false;
|
||||||
|
|
||||||
lcDiskFile CSVFile(SaveFileName);
|
lcDiskFile CSVFile(SaveFileName);
|
||||||
char Line[1024];
|
char Line[1024];
|
||||||
|
@ -1452,7 +1452,7 @@ void Project::ExportCSV()
|
||||||
if (!CSVFile.Open(QIODevice::WriteOnly))
|
if (!CSVFile.Open(QIODevice::WriteOnly))
|
||||||
{
|
{
|
||||||
QMessageBox::warning(gMainWindow, tr("LeoCAD"), tr("Could not open file '%1' for writing.").arg(SaveFileName));
|
QMessageBox::warning(gMainWindow, tr("LeoCAD"), tr("Could not open file '%1' for writing.").arg(SaveFileName));
|
||||||
return;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
CSVFile.WriteLine("Part Name,Color,Quantity,Part ID,Color Code\n");
|
CSVFile.WriteLine("Part Name,Color,Quantity,Part ID,Color Code\n");
|
||||||
|
@ -1467,6 +1467,8 @@ void Project::ExportCSV()
|
||||||
CSVFile.WriteLine(Line);
|
CSVFile.WriteLine(Line);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
lcInstructions* Project::GetInstructions()
|
lcInstructions* Project::GetInstructions()
|
||||||
|
|
|
@ -93,7 +93,7 @@ public:
|
||||||
bool Export3DStudio(const QString& FileName);
|
bool Export3DStudio(const QString& FileName);
|
||||||
void ExportBrickLink();
|
void ExportBrickLink();
|
||||||
bool ExportCOLLADA(const QString& FileName);
|
bool ExportCOLLADA(const QString& FileName);
|
||||||
void ExportCSV();
|
bool ExportCSV(const QString& FileName);
|
||||||
void ExportHTML(const lcHTMLExportOptions& Options);
|
void ExportHTML(const lcHTMLExportOptions& Options);
|
||||||
bool ExportPOVRay(const QString& FileName);
|
bool ExportPOVRay(const QString& FileName);
|
||||||
bool ExportWavefront(const QString& FileName);
|
bool ExportWavefront(const QString& FileName);
|
||||||
|
|
Loading…
Reference in a new issue