在paper.js

时间:2016-03-09 22:59:57

标签: javascript canvas geometry drawing paperjs

我正在尝试填充一个填充矩形的圆形区域(确切地说,光栅宽度尺寸为12x20)。

经过一些研究和实验,我找到了一个解决方案。要绘制一个圆,得到它的边界框并迭代每个像素,发现距离小于或等于圆R。

这里有一些代码示例,我正在使用three.js

let shapeSize = [12, 20];

let circleR = R / 2;
let circle = new Circle(position, circleR);
let bounds = circle.bounds;
for (let i = bounds.x; i <= bounds.x + bounds.width; i += 1) {
  for (let j = bounds.y; j <= bounds.y + bounds.height; j += 20) {
    let center = new Point(i, j);
    if (center.getDistance(position) <= circleR) {
      center = new Point(i, j);
      let shape = new Shape({center, alpha: 0.7, scale: 0.8});
      j += shapeSize[1] - 1; // this part smells 
    }
  }
}

形状是正方形,具有反射器尺寸12x20。

但是使用此代码示例,不可能得到一个填充正方形的圆圈。如果我增加i+=12y+=20,我会得到太多的空间,如果每个方格都有一个超过另一个并且它会产生太多的方块。

知道如何做到漂亮优雅吗?

1 个答案:

答案 0 :(得分:1)

正如JJ23所说,您可以将圆用作包含栅格网格的组的剪贴蒙版。
这是Sketch的示例,展示了如何使用Paper.js

// constants
var RADIUS       = 200;
var IMAGE        = '';
var IMAGE_WIDTH  = 12;
var IMAGE_HEIGHT = 20;

// create image
var raster    = new Raster(IMAGE);
// wait for image loading
raster.onLoad = function ()
{
    // draw raster grid as a group
    var group  = new Group();
    var stepsX = Math.ceil(RADIUS * 2 / IMAGE_WIDTH);
    var stepsY = Math.ceil(RADIUS * 2 / IMAGE_HEIGHT);
    for (var i = 0; i < stepsX; i++)
    {
        for (var j = 0; j < stepsY; j++)
        {
            // calculate grid point
            var point            = new Point(i * IMAGE_WIDTH, j * IMAGE_HEIGHT);
            // clone original raster
            var rasterClone      = raster.clone();
            // position it at grid point
            rasterClone.position = point;
            // add it to the group
            group.addChild(rasterClone);
        }
    }

    // draw circle
    var circle = new Path.Circle(group.position, RADIUS);
    // add it to the group as first child
    group.insertChild(0, circle);
    // enable clipping
    group.clipped = true;

    // position group at view center
    group.position = view.center;

    // delete original raster
    raster.remove();
};