fill(row, col, value, directions, border)

fill(row, col, value, directions, border)

Fills a specific cell and all connected cells in the quadrille with the specified value, based on the given directions and border options, using a flood fill algorithm.

Example

(click on any cell to perform flood fill based on selected options; press any key to reset)

code
Quadrille.cellLength = 20;  
let quadrille;  
let mode;  

function setup() {  
  createCanvas(400, 400);  
  mode = createSelect();  
  mode.option('flood fill 4-directions');  
  mode.option('flood fill 4-directions border');  
  mode.option('flood fill 8-directions');  
  mode.option('flood fill 8-directions border');  
  mode.selected('flood fill 4-directions');  
  reset();  
}  

function draw() {  
  background('black');  
  drawQuadrille(quadrille);  
}  

function mouseClicked() {  
  const row = quadrille.mouseRow;  
  const col = quadrille.mouseCol;  
  switch (mode.value()) {  
    case 'flood fill 4-directions':  
      quadrille.fill(row, col, 255, 4);  
      break;  
    case 'flood fill 4-directions border':  
      quadrille.fill(row, col, 255, 4, true);  
      break;  
    case 'flood fill 8-directions':  
      quadrille.fill(row, col, 255, 8);  
      break;  
    case 'flood fill 8-directions border':  
      quadrille.fill(row, col, 255, 8, true);  
      break;  
  }  
}  

function keyPressed() {  
  reset();  
}  

function reset() {  
  quadrille = createQuadrille(20, 20, 100, color('red'));  
  quadrille.rand(100, color('lime')).rand(100, color('blue'));
}  

Syntax

fill(row, col, value, directions, border)

Parameters

ParamDescription
rowNumber: row index of the cell to start filling [0..height]
colNumber: column index of the cell to start filling [0..width]
valueAny: A valid JavaScript value
directionsNumber: Number of directions for flood fill (4 or 8), default is 4
borderBoolean: Specifies whether to include the border of the flood fill area. Default is false