Boost 多边形仅支持硬编码点数据

发布于 2025-01-11 09:16:52 字数 1916 浏览 0 评论 0原文

我正在尝试将多边形分割成一堆矩形。为此,我正在使用 boost 多边形库。 当我尝试从用户那里获取输入(例如此处的向量)时,程序会给出意想不到的结果,但当硬编码(在代码中注释)给出正确结果时,会给出相同的值。

#include <iostream>
#include <vector>
#include <boost/polygon/polygon.hpp>

namespace gtl = boost::polygon;
using namespace boost::polygon::operators;

int main() {

    typedef gtl::polygon_90_with_holes_data<int> Polygon;
    typedef gtl::polygon_traits<Polygon>::point_type Point;
    Point pts[7];
    std::vector <double> vec  {0.0,0.0, 0.0, 235.0, 170.0, 235.0, 170.0, 305.0, 310.0, 305.0, 310.0, 0.0, 0.0, 0.0};
  
    for (int i  = 0 ; i< 7 ; i++) {
        pts[i] = gtl::construct<Point>(vec[i],vec[i+1]);
    }

    /*
    pts[0] = gtl::construct<Point>(0.0 , 0.0) ;
    pts[1] = gtl::construct<Point>(0.0 , 235.0) ;
    pts[2] = gtl::construct<Point>(170.0 , 235.0) ;
    pts[3] = gtl::construct<Point>(170.0 , 305.0) ;
    pts[4] = gtl::construct<Point>(310.0 , 305.0) ;
    pts[5] = gtl::construct<Point>(310.0 , 0.0) ;
    pts[6] = gtl::construct<Point>(0.0 , 0.0) ;
    */

    Polygon poly;
    gtl::set_points(poly, pts, pts+7);

    std::vector< gtl::rectangle_data<int> > rects;
    get_rectangles(rects, poly);

    std::cout << rects.size() << " rectangle: \n";

    for(std::vector<gtl::rectangle_data<int> >::iterator it = rects.begin(); it !=
        rects.end(); ++it) {
            // Print out the corner coordinates
            std::cout << "x1: "<< gtl::xl(*it) << ", x2: " << gtl::xh(*it)
            << ", y1: "<< gtl::yl(*it) << ", y2: " << gtl::yh(*it) << std::endl;
    }
    return 0;
}

输出:

以向量作为

0 rectangle:

带有硬编码值的输入

2 rectangle: 
1: 0, x2: 170, y1: 0, y2: 235
x1: 170, x2: 310, y1: 0, y2: 305

I am trying to split polygons into bunch of rectangles. For that I am using boost polygon library.
When i try to take input from user (in vector for e.g. here) the program gives unintended result but same values when hard-coded (commented in the code) gives right result.

#include <iostream>
#include <vector>
#include <boost/polygon/polygon.hpp>

namespace gtl = boost::polygon;
using namespace boost::polygon::operators;

int main() {

    typedef gtl::polygon_90_with_holes_data<int> Polygon;
    typedef gtl::polygon_traits<Polygon>::point_type Point;
    Point pts[7];
    std::vector <double> vec  {0.0,0.0, 0.0, 235.0, 170.0, 235.0, 170.0, 305.0, 310.0, 305.0, 310.0, 0.0, 0.0, 0.0};
  
    for (int i  = 0 ; i< 7 ; i++) {
        pts[i] = gtl::construct<Point>(vec[i],vec[i+1]);
    }

    /*
    pts[0] = gtl::construct<Point>(0.0 , 0.0) ;
    pts[1] = gtl::construct<Point>(0.0 , 235.0) ;
    pts[2] = gtl::construct<Point>(170.0 , 235.0) ;
    pts[3] = gtl::construct<Point>(170.0 , 305.0) ;
    pts[4] = gtl::construct<Point>(310.0 , 305.0) ;
    pts[5] = gtl::construct<Point>(310.0 , 0.0) ;
    pts[6] = gtl::construct<Point>(0.0 , 0.0) ;
    */

    Polygon poly;
    gtl::set_points(poly, pts, pts+7);

    std::vector< gtl::rectangle_data<int> > rects;
    get_rectangles(rects, poly);

    std::cout << rects.size() << " rectangle: \n";

    for(std::vector<gtl::rectangle_data<int> >::iterator it = rects.begin(); it !=
        rects.end(); ++it) {
            // Print out the corner coordinates
            std::cout << "x1: "<< gtl::xl(*it) << ", x2: " << gtl::xh(*it)
            << ", y1: "<< gtl::yl(*it) << ", y2: " << gtl::yh(*it) << std::endl;
    }
    return 0;
}

output:

with vector as input

0 rectangle:

with hardcode value

2 rectangle: 
1: 0, x2: 170, y1: 0, y2: 235
x1: 170, x2: 310, y1: 0, y2: 305

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

楠木可依 2025-01-18 09:16:52

我建议避免出现问题并使代码更安全:

Live On Coliru

#include <boost/polygon/polygon.hpp>
#include <iostream>
#include <vector>

namespace gtl = boost::polygon;
//using namespace boost::polygon::operators;

int main() {
    using Polygon = gtl::polygon_90_with_holes_data<int>;
    using Point   = gtl::polygon_traits<Polygon>::point_type;

    std::vector const vec{0,   0,   0,   235, 170, 235, 170,
                          305, 310, 305, 310, 0,   0,   0};
    assert(vec.size() % 2 == 0);

    std::vector<Point> pts;
    for (size_t i = 0; i + 1 < vec.size(); i += 2) {
        pts.emplace_back(vec[i], vec[i + 1]);
    }

    Polygon poly;
    gtl::set_points(poly, pts.begin(), pts.end());

    std::vector<gtl::rectangle_data<int>> rects;
    get_rectangles(rects, poly);

    std::cout << rects.size() << " rectangle: \n";

    for (auto& r : rects) {
        // Print out the corner coordinates
        std::cout << "x1: " << gtl::xl(r) << ", x2: " << gtl::xh(r)
                  << ", y1: " << gtl::yl(r) << ", y2: " << gtl::yh(r)
                  << std::endl;
    }
}

打印

2 rectangle: 
x1: 0, x2: 170, y1: 0, y2: 235
x1: 170, x2: 310, y1: 0, y2: 305

I'd suggest avoiding problems and making the code much safer:

Live On Coliru

#include <boost/polygon/polygon.hpp>
#include <iostream>
#include <vector>

namespace gtl = boost::polygon;
//using namespace boost::polygon::operators;

int main() {
    using Polygon = gtl::polygon_90_with_holes_data<int>;
    using Point   = gtl::polygon_traits<Polygon>::point_type;

    std::vector const vec{0,   0,   0,   235, 170, 235, 170,
                          305, 310, 305, 310, 0,   0,   0};
    assert(vec.size() % 2 == 0);

    std::vector<Point> pts;
    for (size_t i = 0; i + 1 < vec.size(); i += 2) {
        pts.emplace_back(vec[i], vec[i + 1]);
    }

    Polygon poly;
    gtl::set_points(poly, pts.begin(), pts.end());

    std::vector<gtl::rectangle_data<int>> rects;
    get_rectangles(rects, poly);

    std::cout << rects.size() << " rectangle: \n";

    for (auto& r : rects) {
        // Print out the corner coordinates
        std::cout << "x1: " << gtl::xl(r) << ", x2: " << gtl::xh(r)
                  << ", y1: " << gtl::yl(r) << ", y2: " << gtl::yh(r)
                  << std::endl;
    }
}

Prints

2 rectangle: 
x1: 0, x2: 170, y1: 0, y2: 235
x1: 170, x2: 310, y1: 0, y2: 305
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文