/* * 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 . */ #pragma once #include #include #include #include "vec_grid.h" namespace gerbolyze { class VoronoiVectorizer : public ImageVectorizer { public: VoronoiVectorizer(grid_type grid, bool relax=true) : m_relax(relax), m_grid_type(grid) {} virtual void vectorize_image(RenderContext &ctx, const pugi::xml_node &node, double min_feature_size_px); private: double m_relax; grid_type m_grid_type; }; class OpenCVContoursVectorizer : public ImageVectorizer { public: OpenCVContoursVectorizer() {} virtual void vectorize_image(RenderContext &ctx, const pugi::xml_node &node, double min_feature_size_px); }; class DevNullVectorizer : public ImageVectorizer { public: DevNullVectorizer() {} virtual void vectorize_image(RenderContext &, const pugi::xml_node &, double) {} }; void parse_img_meta(const pugi::xml_node &node, double &x, double &y, double &width, double &height); void draw_bg_rect(RenderContext &ctx, double width, double height); void handle_aspect_ratio(std::string spec, double &scale_x, double &scale_y, double &off_x, double &off_y, double cols, double rows); }