ctx alternatif. Utilisez StrokeStyle lors de l'utilisation de requestAnimationFrame()
P粉605385621
P粉605385621 2023-08-01 16:06:12
0
1
514
<p>J'essaie de dessiner un mouvement aléatoire simple comme toile d'arrière-plan pour ma page de destination et j'ai du mal à donner aux lignes une couleur unique. <br /><br /> J'ai aussi essayé de le changer après le film sans succès (on dirait juste un mélange de couleurs). </p><p><br /></p> <p><br /></p> <pre class="brush:js;toolbar:false;">const canvas = document.getElementById('myCanvas'); const ctx = toile.getContext('2d'); //ctx.canvas.width = window.innerWidth; //ctx.canvas.height = window.innerHeight*4; const numSteps = ctx.canvas.width / 2 + 10 ; const stepSize = 10 ; const startX = 0 ; const startY = toile.hauteur / 2; const timeInterval = 15 ; var Point = fonction (color_inp){ this.x = startX; this.y = startY; this.color = color_inp; } const couleurs = [ '#FF1493', // Rose '#FF00FF', // Magenta '#800080', // Violet '#4B0082', //Indigo '#0000FF', // Bleu '#00FFFF', //Cyan '#00FF00', // Vert '#FFFF00', // Jaune '#FF7F00', //Orange '#8B4513' // Marron selle ]; function drawRandomWalk(stPoint, étapes) { ctx.globalAlpha = 0,01 ; laissez stepCount = 0 ; ctx.beginPath(); ctx.StrokeStyle = stPoint.color; ctx.moveTo(stPoint.x, stPoint.y); setTimeout(drawStep, 10); fonction drawStep() { if (stepCount >= étapes) { retour; } ctx.moveTo(stPoint.x, stPoint.y); const direction = Math.random() < stPoint.y += stepSize * direction ; stPoint.x = startX + stepCount * 2 ; ctx.lineTo(stPoint.x, stPoint.y); ctx.lineWidth = 1; ctx.AVC(); stepCount++; requestAnimationFrame(drawStep); } } pour (const couleur des couleurs) { const startPoint = nouveau Point (couleur); drawRandomWalk(startPoint, numSteps); }</pré> <pre class="brush:html;toolbar:false;"><canvas id="myCanvas" width="600" height="600"></canvas></pre> <p><br /></p>
P粉605385621
P粉605385621

répondre à tous(1)
P粉327903045

Le problème est que chaque "stylo" qui trace une ligne partage un état - vous dessinez un long chemin composé de nombreux mouvements/lignes, encore et encore.

Si vous souhaitez obtenir l'effet de dégradé globalAlpha (qui repose sur la capacité de tracer des lignes encore et encore), vous devez tracer chaque dessin au stylo individuellement et le dessiner comme indiqué ci-dessous.

Je me suis débarrassé de la structure Point car elle n'est pas vraiment nécessaire.


const canvas = document.getElementById('myCanvas');
const ctx = canvas.getContext('2d');

const numSteps = ctx.canvas.width / 2 + 10;
const stepSize = 10;
const startX = 0;
const startY = canvas.height / 2;
const timeInterval = 15;

const colors = [
  '#FF1493', // Pink
  '#FF00FF', // Magenta
  '#800080', // Purple
  '#4B0082', // Indigo
  '#0000FF', // Blue
  '#00FFFF', // Cyan
  '#00FF00', // Green
  '#FFFF00', // Yellow
  '#FF7F00', // Orange
  '#8B4513'  // Saddle Brown
];



function drawRandomWalk(startX, startY, color, nSteps) {
  setTimeout(drawStep, 10);
  const steps = [[startX, startY]];
  
  function drawStep() {
    if (steps.length >= nSteps) {
      return;
    }
    // Draw current line
    ctx.globalAlpha = 0.01;
    ctx.beginPath();
    ctx.strokeStyle = color;
    ctx.lineWidth = 1;
    let x = 0, y = 0;
    for(let i = 0; i < steps.length; i++) {
      [x, y] = steps[i];
      if(i === 0) ctx.moveTo(x, y);
      else ctx.lineTo(x, y);
    }
    ctx.stroke();
    // Compute next point
    const direction = Math.random() < 0.5 ? -1 : 1;
    y += stepSize * direction;
    x = startX + steps.length * 2; 
    steps.push([x, y]);
    requestAnimationFrame(drawStep);
  }
}

for(const color of colors)
{
  drawRandomWalk(startX, startY, color, numSteps);
}
<canvas id="myCanvas" width="600" height="600"></canvas>


Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal