gpt4 book ai didi

javascript - 圆圈在 paper.js 的 Canvas 上填充点

转载 作者:行者123 更新时间:2023-11-29 15:29:46 32 4
gpt4 key购买 nike

我正在尝试填充一个由矩形填充的圆形区域(准确地说,栅格宽度尺寸为 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 , 我周围的空间太多了,如果每个方 block 都在另一个方 block 之上,就会产生太多方 block 。

知道如何优雅地做到这一点吗?

最佳答案

正如 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();
};

关于javascript - 圆圈在 paper.js 的 Canvas 上填充点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35904397/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com