欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于JavaScript繪制動態(tài)花束的示例代碼

 更新時間:2022年06月24日 08:47:58   作者:肥學(xué)  
p5.js 是一個JavaScript的函數(shù)庫,它在制作之初就和Processing有同樣的目標(biāo)。本文將利用p5.js 制作出一束動態(tài)花束,感興趣的可以嘗試一下

演示

技術(shù)棧

這次用到了一個名叫p5.js的框架:

p5.js 是一個JavaScript的函數(shù)庫,它在制作之初就和Processing有同樣的目標(biāo)。就是讓藝術(shù)家,設(shè)計師,教育工作者和編程初學(xué)者能夠很容易,很輕松地學(xué)習(xí)和使用程序設(shè)計。并且它也能給現(xiàn)在的網(wǎng)頁帶來一些新的東西

它的結(jié)構(gòu):

 //初始化,只運行一次
 function setup () {}

 //繪制圖形,每一幀都讀取
 function draw() {}

一個小案例

function setup() {
  createCanvas(400, 400);
}
function draw() {
  if(mouseIsPressed){
    stroke(220);
  }else{
    stroke(0);
  }
  line(300,300,mouseX,mouseY);
}

效果是這樣的

源碼

css

* { margin:0; padding:0; } 
html, body { width:100%; height:100%; overflow: hidden; background:black;} 
canvas { display:block; }
#controls {
  z-index: 2;
  margin: 20px;
  position: absolute;
  top: 0; left: 0;
  color: white;
}

js

let size = 150;

class Flower{
  constructor(s, a1, a2){
    let l = pow(random(), 2)*size;
    let l2 = random();
    this.l2 = l2;
    this.x = cos(a1)*(l + l2*size/2);
    this.y = sin(a1)*(l + l2*size/2);
    
    this.hue = random();
    
    this.goalX = this.x;
    this.goalY = this.y;
    
    this.dx = 10;
    this.dy = 10;
    
    this.s = s*(l2*.5 + .5);
    this.a = a1;
    this.squash = 1 - (l/size)*.8;
    this.weights = [];
    for (let i = 0; i < 5; i++){
      this.weights[i] = random()*.5 + .5;
    }
  }
  update(){
    this.x += this.dx;
    this.y += this.dy;
    
    this.dx *= .95;
    this.dy *= .95;
    
    let mx = (width/2 + this.x) - mouseX;
    let my = (height/2 + this.y) - mouseY;
   
    let d = dist(width/2 + this.x, height/2 + this.y, mouseX, mouseY);
    let a = atan2(my, mx);
    
    if (d > 1){
      this.dx += cos(a)*size/d;
      this.dy += sin(a)*size/d;
    }
    
    this.x = (this.goalX + this.x)/2;
    this.y = (this.goalY + this.y)/2;
  }
  renderStem(){
    pushPop(() => {
      noFill();
      strokeWeight(this.l2*2 + 1);
      stroke(.35, 1, this.l2*.5 + .5);
      translate(this.x, size);
      let a = PI;
      if (this.x <= 0) a += PI/2;
      arc(0, 0, this.x*2, (this.y)*2 - size*2, a, a+PI/2);
    })
  }
  render(){
    pushPop(() => {
      noStroke();
      fill(this.l2*.2 + .8);
      translate(this.x, this.y);
      rotate(this.a);
      scale(this.s*this.squash, this.s);
      
      for (let j = 0; j < 2; j++)
      for (let i = 0; i < 5; i++){
        let a = i*TAU/5;
        let s = this.weights[i];
        let b = (this.l2*.2 + .8)*(s*.1 + .9)
        fill(this.hue, .1*this.l2, b);
        if (j == 0){
          s += .05;
          fill(0);
        }
        ellipse(cos(a)*.7*s, sin(a)*.7*s, 1);
      }
      fill(0);
      ellipse(0, 0, .7*(this.weights[0] + .05));
      fill(.15, 1, 1*(this.l2*.2 + .8));
      ellipse(0, 0, .7*this.weights[0]);
    })
  }
}

function setup (){
  pixelDensity(1);
  createCanvas();
  colorMode(HSB, 1, 1, 1);
  windowResized();
}

function init(){
  flowers = [];
  for (let i = 0; i < 50; i++){
    flowers.push(
      new Flower(random(20) + 20, random(PI*.8) + PI + PI*.1)
    );
  }
  flowers = flowers.sort((a, b) => a.s - b.s);
}

function draw(){
  background(0);
  translate(width/2, height/2);
  flowers.map(f => f.update());
  flowers.map(f => f.renderStem());
  flowers.map(f => f.render());
}

function windowResized(){
  resizeCanvas(windowWidth, windowHeight); 
  init();
}

let pushPop = f => {push();f();pop();}

以上就是基于JavaScript繪制動態(tài)花束的示例代碼的詳細(xì)內(nèi)容,更多關(guān)于JavaScript繪制花束的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • js修改原型的屬性使用介紹

    js修改原型的屬性使用介紹

    原型(prototype)定義了特定類型的所有實例都可以訪問的屬性和方法,很多些情況下需要重新對原型中的屬性賦值,下面為大家介紹下如何修改原型
    2014-01-01
  • Bootstrap圖片輪播組件使用實例解析

    Bootstrap圖片輪播組件使用實例解析

    圖片輪播組件是一個在網(wǎng)頁中很常見的技術(shù),這篇文章主要為大家詳細(xì)介紹了Bootstrap圖片輪播組件使用實例,感興趣的小伙伴們可以參考一下
    2016-06-06
  • 利用js+css+html實現(xiàn)固定table的列頭不動

    利用js+css+html實現(xiàn)固定table的列頭不動

    本文分享了利用js+css+html實現(xiàn)固定table的列頭不動的實例代碼。小編認(rèn)為具有很好的參考價值,感興趣的朋友可以看下
    2016-12-12
  • 原生js實現(xiàn)秒表計時器功能

    原生js實現(xiàn)秒表計時器功能

    這篇文章主要為大家詳細(xì)介紹了原生js實現(xiàn)秒表計時器功能,可以開始、暫停、清除,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • js如何清空input?file的值

    js如何清空input?file的值

    這篇文章主要介紹了js如何清空input?file的值問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • js日期時間格式化的方法實例

    js日期時間格式化的方法實例

    這篇文章主要給大家介紹了關(guān)于js日期時間格式化的相關(guān)資料,文中分別介紹了利用原生js以及Moment.js庫處理日期時間格式化的方法,需要的朋友可以參考下
    2021-07-07
  • 學(xué)習(xí)JavaScript設(shè)計模式之迭代器模式

    學(xué)習(xí)JavaScript設(shè)計模式之迭代器模式

    這篇文章主要為大家介紹了JavaScript設(shè)計模式中的迭代器模式,對JavaScript設(shè)計模式感興趣的小伙伴們可以參考一下
    2016-01-01
  • JS實現(xiàn)移動端按首字母檢索城市列表附源碼下載

    JS實現(xiàn)移動端按首字母檢索城市列表附源碼下載

    我們常見的手機通訊錄或微信通訊錄,聯(lián)系人信息是按字母順序排列的列表,通過點擊右側(cè)的字母,會迅速定位檢索到首字母對應(yīng)的聯(lián)系人。下面通過本文給大家分享JS實現(xiàn)移動端按首字母檢索城市列表功能,需要的的朋友參考下吧
    2017-07-07
  • 表單input項使用label同時引用Bootstrap庫導(dǎo)致input點擊效果區(qū)增大問題

    表單input項使用label同時引用Bootstrap庫導(dǎo)致input點擊效果區(qū)增大問題

    這篇文章主要介紹了表單input項使用label,同時引用Bootstrap庫,導(dǎo)致input點擊效果區(qū)增大問題的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-10-10
  • BootStrap中Datepicker控件帶中文的js文件

    BootStrap中Datepicker控件帶中文的js文件

    bootstrap-datepicker 是一個非常優(yōu)秀的時間選擇插件。這篇文章主要介紹了bootstrap-datepicker帶中文的js文件的相關(guān)資料,需要的朋友可以參考下
    2016-08-08

最新評論