cgal/CGAL_ipelets/demo/CGAL_ipelets/bbox_restriction.cpp

90 lines
2.2 KiB
C++

// Copyright (c) 2009 INRIA Sophia-Antipolis (France).
// All rights reserved.
//
// This file is part of CGAL (www.cgal.org)
//
// $URL$
// $Id$
// SPDX-License-Identifier: LGPL-3.0-or-later OR LicenseRef-Commercial
//
//
// Author(s) : Sebastien Loriot
#include <CGAL/Exact_predicates_inexact_constructions_kernel.h>
#include <CGAL/CGAL_Ipelet_base.h>
// --------------------------------------------------------------------
namespace CGAL_bbox_restriction{
typedef CGAL::Exact_predicates_inexact_constructions_kernel Kernel;
const std::string sublabel[] ={
"Bounding box restriction", "Help"
};
const std::string helpmsg[] = {
"Restrict a set of objects to the bounding box of a set of points."
};
struct hilbertsortIpelet
: CGAL::Ipelet_base<Kernel,2>
{
hilbertsortIpelet()
: CGAL::Ipelet_base<Kernel,2>("Bounding box restriction",sublabel, helpmsg) {}
void protected_run(int);
};
void hilbertsortIpelet::protected_run(int fn)
{
if (fn==1) {
show_help();
return;
}
std::vector<Circle_2> cir_list;
std::vector<Circular_arc_2> arc_list;
std::vector<Polygon_2> poly_list;
std::vector<Segment_2> seg_list;
std::vector<Point_2> pt_list;
read_active_objects(
CGAL::dispatch_or_drop_output<Point_2,Circle_2,Polygon_2,Circular_arc_2,Segment_2>(
std::back_inserter(pt_list),std::back_inserter(cir_list),
std::back_inserter(poly_list),std::back_inserter(arc_list),
std::back_inserter(seg_list)
),true,true
);
if (pt_list.size()<2) {
print_error_message("No point selected to define a bounding box");
return;
}
CGAL::Bbox_2 bbox_2=pt_list.begin()->bbox();
for (std::vector<Point_2>::iterator it=pt_list.begin();it!=pt_list.end();++it)
bbox_2=bbox_2+it->bbox();
Iso_rectangle_2 bbox(bbox_2.xmin(),bbox_2.ymin(),bbox_2.xmax(),bbox_2.ymax());
draw_in_ipe(bbox);
draw_in_ipe(cir_list.begin(),cir_list.end(),bbox,false);
draw_in_ipe(seg_list.begin(),seg_list.end(),bbox,false);
draw_in_ipe(arc_list.begin(),arc_list.end(),bbox,false);
draw_in_ipe(poly_list.begin(),poly_list.end(),bbox,false);
}
}
CGAL_IPELET(CGAL_bbox_restriction::hilbertsortIpelet)