mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-09-02 06:51:50 -06:00
More work for XS Config
This commit is contained in:
parent
008f38cf68
commit
64e549a46f
7 changed files with 316 additions and 10 deletions
|
@ -3,8 +3,13 @@
|
|||
|
||||
#include <myinit.h>
|
||||
#include <map>
|
||||
#include <sstream>
|
||||
#include <cstdio>
|
||||
#include <cstdlib>
|
||||
#include <iostream>;
|
||||
#include <string>
|
||||
#include <vector>
|
||||
#include "Point.hpp"
|
||||
|
||||
namespace Slic3r {
|
||||
|
||||
|
@ -14,27 +19,79 @@ typedef std::vector<std::string> t_config_option_keys;
|
|||
class ConfigOption {
|
||||
public:
|
||||
virtual ~ConfigOption() {};
|
||||
virtual std::string serialize() = 0;
|
||||
virtual void deserialize(std::string str) = 0;
|
||||
};
|
||||
|
||||
class ConfigOptionFloat : public ConfigOption
|
||||
{
|
||||
public:
|
||||
float value;
|
||||
ConfigOptionFloat() : value(0) {};
|
||||
|
||||
operator float() const { return this->value; };
|
||||
|
||||
std::string serialize() {
|
||||
std::ostringstream ss;
|
||||
ss << this->value;
|
||||
return ss.str();
|
||||
};
|
||||
|
||||
void deserialize(std::string str) {
|
||||
this->value = ::atof(str.c_str());
|
||||
};
|
||||
};
|
||||
|
||||
class ConfigOptionInt : public ConfigOption
|
||||
{
|
||||
public:
|
||||
int value;
|
||||
ConfigOptionInt() : value(0) {};
|
||||
|
||||
operator int() const { return this->value; };
|
||||
|
||||
std::string serialize() {
|
||||
std::ostringstream ss;
|
||||
ss << this->value;
|
||||
return ss.str();
|
||||
};
|
||||
|
||||
void deserialize(std::string str) {
|
||||
this->value = ::atoi(str.c_str());
|
||||
};
|
||||
};
|
||||
|
||||
class ConfigOptionString : public ConfigOption
|
||||
{
|
||||
public:
|
||||
std::string value;
|
||||
ConfigOptionString() : value("") {};
|
||||
|
||||
operator std::string() const { return this->value; };
|
||||
|
||||
std::string serialize() {
|
||||
std::string str = this->value;
|
||||
|
||||
// s/\R/\\n/g
|
||||
size_t pos = 0;
|
||||
while ((pos = str.find("\n", pos)) != std::string::npos || (pos = str.find("\r", pos)) != std::string::npos) {
|
||||
str.replace(pos, 1, "\\n");
|
||||
pos += 2; // length of "\\n"
|
||||
}
|
||||
|
||||
return str;
|
||||
};
|
||||
|
||||
void deserialize(std::string str) {
|
||||
// s/\\n/\n/g
|
||||
size_t pos = 0;
|
||||
while ((pos = str.find("\\n", pos)) != std::string::npos) {
|
||||
str.replace(pos, 2, "\n");
|
||||
pos += 1; // length of "\n"
|
||||
}
|
||||
|
||||
this->value = str;
|
||||
};
|
||||
};
|
||||
|
||||
class ConfigOptionFloatOrPercent : public ConfigOption
|
||||
|
@ -42,6 +99,44 @@ class ConfigOptionFloatOrPercent : public ConfigOption
|
|||
public:
|
||||
float value;
|
||||
bool percent;
|
||||
ConfigOptionFloatOrPercent() : value(0), percent(false) {};
|
||||
|
||||
std::string serialize() {
|
||||
std::ostringstream ss;
|
||||
ss << this->value;
|
||||
std::string s(ss.str());
|
||||
if (this->percent) s += "%";
|
||||
return s;
|
||||
};
|
||||
|
||||
void deserialize(std::string str) {
|
||||
if (str.find_first_of("%") != std::string::npos) {
|
||||
sscanf(str.c_str(), "%f%%", &this->value);
|
||||
this->percent = true;
|
||||
} else {
|
||||
this->value = ::atof(str.c_str());
|
||||
this->percent = false;
|
||||
}
|
||||
};
|
||||
};
|
||||
|
||||
class ConfigOptionPoint : public ConfigOption
|
||||
{
|
||||
public:
|
||||
Pointf point;
|
||||
ConfigOptionPoint() : point(Pointf(0,0)) {};
|
||||
|
||||
std::string serialize() {
|
||||
std::ostringstream ss;
|
||||
ss << this->point.x;
|
||||
ss << ",";
|
||||
ss << this->point.y;
|
||||
return ss.str();
|
||||
};
|
||||
|
||||
void deserialize(std::string str) {
|
||||
sscanf(str.c_str(), "%f%*1[,x]%f", &this->point.x, &this->point.y);
|
||||
};
|
||||
};
|
||||
|
||||
enum ConfigOptionType {
|
||||
|
@ -49,6 +144,7 @@ enum ConfigOptionType {
|
|||
coInt,
|
||||
coString,
|
||||
coFloatOrPercent,
|
||||
coPoint,
|
||||
};
|
||||
|
||||
class ConfigOptionDef
|
||||
|
@ -57,30 +153,41 @@ class ConfigOptionDef
|
|||
ConfigOptionType type;
|
||||
std::string label;
|
||||
std::string tooltip;
|
||||
std::string ratio_over;
|
||||
};
|
||||
|
||||
typedef std::map<t_config_option_key,ConfigOptionDef> t_optiondef_map;
|
||||
|
||||
ConfigOptionDef* get_config_option_def(const t_config_option_key opt_key);
|
||||
|
||||
class ConfigBase
|
||||
{
|
||||
public:
|
||||
virtual ConfigOption* option(const t_config_option_key opt_key) = 0;
|
||||
virtual ConfigOption* option(const t_config_option_key opt_key, bool create = false) = 0;
|
||||
virtual void keys(t_config_option_keys *keys) = 0;
|
||||
void apply(ConfigBase &other, bool ignore_nonexistent = false);
|
||||
std::string serialize(const t_config_option_key opt_key);
|
||||
void set_deserialize(const t_config_option_key opt_key, std::string str);
|
||||
float get_abs_value(const t_config_option_key opt_key);
|
||||
|
||||
#ifdef SLIC3RXS
|
||||
SV* get(t_config_option_key opt_key);
|
||||
void set(t_config_option_key opt_key, SV* value);
|
||||
#endif
|
||||
};
|
||||
|
||||
class DynamicConfig : public ConfigBase
|
||||
{
|
||||
public:
|
||||
ConfigOption* option(const t_config_option_key opt_key);
|
||||
DynamicConfig() {};
|
||||
~DynamicConfig();
|
||||
ConfigOption* option(const t_config_option_key opt_key, bool create = false);
|
||||
void keys(t_config_option_keys *keys);
|
||||
bool has(const t_config_option_key opt_key) const;
|
||||
|
||||
private:
|
||||
DynamicConfig(const DynamicConfig& other); // we disable this by making it private and unimplemented
|
||||
DynamicConfig& operator= (const DynamicConfig& other); // we disable this by making it private and unimplemented
|
||||
typedef std::map<t_config_option_key,ConfigOption*> t_options_map;
|
||||
t_options_map options;
|
||||
};
|
||||
|
@ -96,10 +203,19 @@ class FullConfig : public StaticConfig
|
|||
public:
|
||||
ConfigOptionFloat layer_height;
|
||||
ConfigOptionFloatOrPercent first_layer_height;
|
||||
ConfigOptionInt perimeters;
|
||||
ConfigOptionString extrusion_axis;
|
||||
ConfigOptionPoint print_center;
|
||||
ConfigOptionString notes;
|
||||
|
||||
ConfigOption* option(const t_config_option_key opt_key) {
|
||||
ConfigOption* option(const t_config_option_key opt_key, bool create = false) {
|
||||
assert(!create); // can't create options in StaticConfig
|
||||
if (opt_key == "layer_height") return &this->layer_height;
|
||||
if (opt_key == "first_layer_height") return &this->first_layer_height;
|
||||
if (opt_key == "perimeters") return &this->perimeters;
|
||||
if (opt_key == "extrusion_axis") return &this->extrusion_axis;
|
||||
if (opt_key == "print_center") return &this->print_center;
|
||||
if (opt_key == "notes") return &this->notes;
|
||||
return NULL;
|
||||
};
|
||||
};
|
||||
|
@ -111,6 +227,18 @@ static t_optiondef_map _build_optiondef_map () {
|
|||
Options["layer_height"].tooltip = "This setting controls the height (and thus the total number) of the slices/layers. Thinner layers give better accuracy but take more time to print.";
|
||||
|
||||
Options["first_layer_height"].type = coFloatOrPercent;
|
||||
Options["first_layer_height"].ratio_over = "layer_height";
|
||||
|
||||
Options["perimeters"].type = coInt;
|
||||
Options["perimeters"].label = "Perimeters (minimum)";
|
||||
Options["perimeters"].tooltip = "This option sets the number of perimeters to generate for each layer. Note that Slic3r may increase this number automatically when it detects sloping surfaces which benefit from a higher number of perimeters if the Extra Perimeters option is enabled.";
|
||||
|
||||
Options["extrusion_axis"].type = coString;
|
||||
|
||||
Options["print_center"].type = coPoint;
|
||||
|
||||
Options["notes"].type = coString;
|
||||
|
||||
return Options;
|
||||
}
|
||||
|
||||
|
@ -120,6 +248,10 @@ static FullConfig _build_default_config () {
|
|||
defconf.layer_height.value = 0.4;
|
||||
defconf.first_layer_height.value = 0.35;
|
||||
defconf.first_layer_height.percent = false;
|
||||
defconf.perimeters.value = 3;
|
||||
defconf.extrusion_axis.value = "E";
|
||||
defconf.print_center.point = Pointf(100,100);
|
||||
defconf.notes.value = "";
|
||||
|
||||
return defconf;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue