From 236c4a44855b93c0dd4dc8e5e2ab80380b595046 Mon Sep 17 00:00:00 2001 From: jaseg Date: Tue, 17 Aug 2021 22:55:47 +0200 Subject: svg-flatten: Fix case where document unit is not mm --- svg-flatten/src/out_scaler.cpp | 61 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 61 insertions(+) create mode 100644 svg-flatten/src/out_scaler.cpp (limited to 'svg-flatten/src/out_scaler.cpp') diff --git a/svg-flatten/src/out_scaler.cpp b/svg-flatten/src/out_scaler.cpp new file mode 100644 index 0000000..983dffe --- /dev/null +++ b/svg-flatten/src/out_scaler.cpp @@ -0,0 +1,61 @@ +/* + * This file is part of gerbolyze, a vector image preprocessing toolchain + * Copyright (C) 2021 Jan Sebastian Götte + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see . + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +using namespace gerbolyze; +using namespace std; + +void Scaler::header(d2p origin, d2p size) { + m_sink.header({origin[0] * m_scale, origin[1] * m_scale}, {size[0] * m_scale, size[1] * m_scale}); +} + +void Scaler::footer() { + m_sink.footer(); +} + +Scaler &Scaler::operator<<(const LayerNameToken &layer_name) { + m_sink << layer_name; + + return *this; +} + +Scaler &Scaler::operator<<(GerberPolarityToken pol) { + m_sink << pol; + + return *this; +} + +Scaler &Scaler::operator<<(const Polygon &poly) { + Polygon new_poly; + for (auto &p : poly) { + new_poly.push_back({ p[0] * m_scale, p[1] * m_scale }); + } + m_sink << new_poly; + + return *this; +} + -- cgit