3

我想使用 Magick++ 或 imagemagick 命令行从图像中提取 n-gon。n 边形由顶点列表指定。因此,例如,我希望能够提取由点 a、b、c、d、e、f、g、h 定义的 n 边形,这些点定义了一个如下所示的区域:

      a---------h
      |         |
      |         g-f
      |           |
      b---c       |
          |       |
          |       |
          |       |
          d-------e

例如,来自 png 图像。我假设我必须使用图像蒙版进行某种复合操作,或者如果使用 Magick++ 定义 DrawableClipPath。但是,我找不到任何文档。任何帮助,将不胜感激。

ps 我的偏好是使用 C++ 和 Magick++ 来执行此操作,因为我还有其他处理要做,但我也很高兴使用命令行来执行此操作。

4

1 回答 1

3

您将使用Magick::DrawablePolygon和的组合Magick::Image.composite

创建一个新的蒙版图像,并绘制 n 边形

Magick::Image mask;
mask.draw( Magick::DrawablePolygon( std::list<Magick::Coordinate> ) );

然后只需将蒙版应用于目标图像,并组合现有源。

Magick::Image dest;
dest.composite( Magick::Image, Magick::Geometry, Magick::CompositeOperator );

例子:

#include <iostream>
#include <Magick++.h>

int main(int argc, const char ** argv)
{
    Magick::InitializeMagick(*argv);

    Magick::Image mask( Magick::Geometry(120,120), Magick::Color("white"));
    Magick::Image dest( Magick::Geometry(120,120), Magick::Color("white"));

    // Example source image
    Magick::Image source;
    source.read("rose:");
    source.resize(Magick::Geometry(200,120)); // Resize for fun

    mask.fillColor("black");

    // Define points
    std::list<Magick::Coordinate> points;
    points.push_back(Magick::Coordinate(10, 10)); // a
    points.push_back(Magick::Coordinate(10, 50)); // b
    points.push_back(Magick::Coordinate(30, 50)); // c
    points.push_back(Magick::Coordinate(30,100)); // d
    points.push_back(Magick::Coordinate(75,100)); // e
    points.push_back(Magick::Coordinate(75, 30)); // f
    points.push_back(Magick::Coordinate(60, 30)); // g
    points.push_back(Magick::Coordinate(60, 10)); // h

    // Draw Polygon "n-gon"
    mask.draw( Magick::DrawablePolygon(points) );

    // Extract n-gon from source image to destination image
    dest.clipMask(mask);
    Magick::Geometry offset(0,0,0,0);
    dest.composite( source, offset, Magick::OverCompositeOp );

    dest.write("n-gon.png"); // Output
}

正边形

于 2014-03-27T14:13:38.067 回答