Reputation: 111
I'm trying to fill get a circle shaped area filled with rectangles (to be precise, Raster width dimensions 12x20).
After some research and experiments, I found one solution. To draw a circle, get its bounding box and iterate through every pixel to found that distance is smaller or equal to circle R.
Some code sample here, I'm using 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
}
}
}
Shape is square with a rester - size 12x20.
But with this code sample, it's impossible to get a circle filled with squares. If I increment i+=12
and y+=20
, I get too much space around, and if by one every square is over another and it generates too many squares.
Any idea how to do it nice and elegant?
Upvotes: 3
Views: 1177
Reputation: 4650
As JJ23 said, you can use the circle as a clip mask for a group containing your rasters grid.
Here is a Sketch demonstrating how to do it with 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();
};
Upvotes: 1