Skip to content

Nimo-19/MaxRectsBinPack

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

rects-bin-pack npm runkit

MaxRects Algorithm JavaScript implementation

demo

usage

  • init bin pack
    /**
    * MaxRectanglesBinPack
    * @param {Number} width The container width
    * @param {Number} height The container height
    * @param {Boolean} [allowRotate=false] Whether to allow rotate the rects
    */
    const pack = new MaxRectsBinPack.MaxRectsBinPack(512, 256, false);
    
  • add rectangles
    const rectangles = [{
        width: 20,
        height: 100,
        id: '1'
    }, {
        width: 200,
        height: 70,
        id: '2'
    }, {
        width: 30,
        height: 70,
        id: '3'
    }];
    /**
     * Insert a set of rectangles
     * @param  {Rect[]} rectangles The set of rects, allow custum property
     * @param  {Number} method The pack rule, allow value is BestShortSideFit, BestLongSideFit, BestAreaFit, BottomLeftRule, ContactPointRule
     * @return {Rect[]} The result of bin pack.
     */
    const result = pack.insert2(rectangles, MaxRectsBinPack.BestShortSideFit)
    

Dev

  • run npm install to install dependencies
  • run npm run dev to watch and develop
  • run npm run build to build

License

MIT License

About

MaxRects Algorithm JavaScript implementation

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 100.0%