/**************************************************************************** * VCGLib o o * * Visual and Computer Graphics Library o o * * _ O _ * * Copyright(C) 2004-2009 \/)\/ * * Visual Computing Lab /\/| * * ISTI - Italian National Research Council | * * \ * * All rights reserved. * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 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 General Public License (http://www.gnu.org/licenses/gpl.txt) * * for more details. * * * ****************************************************************************/ #include #include #include #include #include #include #include #include #include using namespace vcg; using namespace std; static void buildRandRectSet(int rectNum, vector &rectVec) { math::MarsenneTwisterRNG rnd; float exp=3.0f; float ratioMin=0.2; float ratioMax=0.9; float sizeMin=0.1; float sizeMax=1.0f; rnd.initialize(time(0)); for(int i=0;i &rectVec) { math::MarsenneTwisterRNG rnd; float exp=5.0f; rnd.initialize(time(0)); for(int i=0;i > &polyVec) { vcg::math::MarsenneTwisterRNG rnd; rnd.initialize(time(0)); for(int i=0;i poly; for(int j=0;j<10;j++) poly.push_back(Point2f(0.5+0.5*rnd.generate01(),2.0f*M_PI*rnd.generate01())); std::sort(poly.begin(),poly.end()); float ratio = rnd.generateRange(0.2,0.9); float rot = rnd.generateRange(-M_PI,M_PI); float scale = pow(rnd.generateRange(0.3,0.9),1); for(size_t j=0;j trVec; vector trPolyVec; vector< vector > polySet; vector< vector > multiPolySet; Point2f finalSize; std::vector finalSizeVec; const Point2f containerSize(1000,1000); PolyDumperParam pp; std::vector contInd; vector rectVec; buildRandRectSet(10,rectVec); // RectPacker::Pack(rectVec,containerSize,trVec,finalSize); RectPacker::PackMulti(rectVec,containerSize,3,trVec,contInd,finalSizeVec); RectPacker::Stat s = RectPacker::stat(); printf("RectPacker attempt %i time %5.3f %5.3f\n",s.pack_attempt_num,s.pack_total_time,s.pack_attempt_time); // PolyDumper::rectSetToPolySet(rectVec,polySet); // PolyDumper::multiRectSetToSinglePolySet(rectVec,trVec,contInd,0,polySet,trPolyVec); // PolyDumper::dumpPolySetPNG("testpolyEq0.png",polySet,trPolyVec,pp); // PolyDumper::multiRectSetToSinglePolySet(rectVec,trVec,contInd,1,polySet,trPolyVec); // PolyDumper::dumpPolySetPNG("testpolyEq1.png",polySet,trPolyVec,pp); // PolyDumper::multiRectSetToSinglePolySet(rectVec,trVec,contInd,2,polySet,trPolyVec); // PolyDumper::dumpPolySetPNG("testpolyEq2.png",polySet,trPolyVec,pp); // buildRandPolySet(100,polySet); // PolyPacker::PackMultiAsObjectOrientedRect(polySet,containerSize,3,trVec,contInd,finalSizeVec); // PolyDumper::multiPolySetToSinglePolySet(polySet,trVec,contInd,0,multiPolySet,trPolyVec); // PolyDumper::dumpPolySetPNG("testpolyEq0.png",multiPolySet,trPolyVec,pp); // PolyDumper::multiPolySetToSinglePolySet(polySet,trVec,contInd,1,multiPolySet,trPolyVec); // PolyDumper::dumpPolySetPNG("testpolyEq1.png",multiPolySet,trPolyVec,pp); // PolyDumper::multiPolySetToSinglePolySet(polySet,trVec,contInd,2,multiPolySet,trPolyVec); // PolyDumper::dumpPolySetPNG("testpolyEq2.png",multiPolySet,trPolyVec,pp); // PolyDumper::dumpPolySetPNG("testpolyOO.png",polySet,trVec,pp); buildRandPolySet(100,polySet); PolyPacker::PackAsEqualSquares(polySet,containerSize,trVec,finalSize); PolyDumper::dumpPolySetPNG("testpolyEq.png",polySet,trVec,pp); PolyPacker::PackAsAxisAlignedRect(polySet,containerSize,trVec,finalSize); PolyDumper::dumpPolySetPNG("testpolyAA.png",polySet,trVec,pp); PolyPacker::PackAsObjectOrientedRect(polySet,containerSize,trVec,finalSize); PolyDumper::dumpPolySetPNG("testpolyOO.png",polySet,trVec,pp); return 0; }