我正在尝试填充一个填充矩形的圆形区域(确切地说,光栅宽度尺寸为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+=12
和y+=20
,我会得到太多的空间,如果每个方格都有一个超过另一个并且它会产生太多的方块。
知道如何做到漂亮优雅吗?
答案 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();
};