使用p5.js临摹动态图形


Posted in Javascript onOctober 23, 2019

一、临摹

最近正在学习用代码绘图,于是按照下面的动态图形自己临摹了一幅图形

使用p5.js临摹动态图形

临摹结果
观察发现,整个图案都是由基础的正六边形组成

首先创建一个画布

function setup() {
 createCanvas(400, 400);
}

画六边形的函数为

function polygon(x, y, radius, npoints) {//绘制正多边形函数
 let angle = TWO_PI / npoints;
 beginShape();
 for (let a = 0; a < TWO_PI; a += angle) {  
  let sx = x + sin(a) * radius;
  let sy = y + cos(a) * radius;
  vertex(sx, sy);
 }
 endShape(CLOSE);
}

x,y分别表示六边形的位置,radius表示图形的边长,npoints表示图形的边数

发现六边形一直在绕着自己的中心旋转,并未发生其他变换,因此只需要将六边形批量创建,并使它不断旋转即可。

通过循环以及平移函数画出六边形

通过translate函数不断更改六边形的中心位置,

使用p5.js临摹动态图形

通过时间函数,达到不断旋转的效果

完整代码如下

function setup() {
 createCanvas(400, 400);
}
function draw() {
 background(10,10,10);
 var t=millis()/2000;
fill(123,0,0);
   for(var j=0;j<=4;j++){
  for(var h=0;h<=4;h++){
     push();
     translate(width *(0.1+j*0.2),height*(0.17+h*0.34));
    rotate(t);
     polygon(0,0,40 ,6);    
     pop();
    }  
 }
 for(var i=0;i<=5;i++){
   for(var k=0;k<=5;k++){
   
     push();
     translate(width *i*0.2,height*k*0.34);
    rotate(t); 
      polygon(0,0,40 ,6);     
     pop();
   }
  }
  
 }

function polygon(x, y, radius, npoints) {//绘制正多边形函数
 let angle = TWO_PI / npoints;
 beginShape();
 for (let a = 0; a < TWO_PI; a += angle) {  
  let sx = x + sin(a) * radius;
  let sy = y + cos(a) * radius;
  vertex(sx, sy);
 }
 endShape(CLOSE);
}

效果图

使用p5.js临摹动态图形

图形改编

只做了微小的改变,颜色可以随机切换,且有一个由小变大的过程

使用p5.js临摹动态图形

代码如下

function setup() {
 createCanvas(400, 400);
}
function draw() {
 background(0,10,200);
var t=5*millis()/1000;

//fill(211,0,0);
   for(var j=0;j<=4;j++){
  for(var h=0;h<=4;h++){
     push();
     translate(width *(0.1+j*0.2),height*(0.17+h*0.34));
     rotate(frameCount / 22.0);
     let c2=random(100,255);
   
   fill(0,c2,0);  
    if (t<50)
    {polygon(0,0,t ,6);}
     if(t>50)
    {
     fill(255,0,0);
     polygon(0,0,50 ,6);
    }

     pop();
    }
  
 }
 for(var i=0;i<=5;i++){
   for(var k=0;k<=5;k++){
   
     push();
     translate(width *(0+i*0.2),height*(0+k*0.34));
     rotate(frameCount / 22.0);
     let c2=random(100,255);
  
   fill(0,c2,0);  
    if (t<50)
    {polygon(0,0,t ,6);}
    if(t>50)
    {
     fill(0,255,0);
      polygon(0,0,50 ,6);
     }
    
     pop();
   }
  }
  
 }

function polygon(x, y, radius, npoints) {//绘制正多边形函数
 let angle = TWO_PI / npoints;
 beginShape();
 for (let a = 0; a < TWO_PI; a += angle) {  
  let sx = x + sin(a) * radius;
  let sy = y + cos(a) * radius;
  vertex(sx, sy);
 }
 endShape(CLOSE);
}

总结

本次实验让我对代码编程有了初步的了解,逐渐学回了分析问题和解决问题,虽然目前解决的都还是很简单的问题。做的图形也不够有创意,这门课程很有意思,希望后面自己可以抽出更多的时间来进行学习。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery 的 $(&quot;#id&quot;).html() 无内容的解决方法
Jun 07 Javascript
基于javascript简单实现对身份证校验
Jan 25 Javascript
Bootstrap实现水平排列的表单
Jul 04 Javascript
AngularJS使用ng-repeat指令实现下拉框
Aug 23 Javascript
如何防止INPUT按回车自动提交表单FORM
Dec 06 Javascript
js 判断数据类型的几种方法
Jan 13 Javascript
如何使用bootstrap框架 bootstrap入门必看!
Apr 13 Javascript
jQuery解析json格式数据示例
Sep 01 jQuery
Vue 前端实现登陆拦截及axios 拦截器的使用
Jul 17 Javascript
vue3实现v-model原理详解
Oct 09 Javascript
微信小程序利用for循环解决内容变更问题
Mar 05 Javascript
解决在Vue中使用axios POST请求变成OPTIONS的问题
Aug 14 Javascript
浅析vue-cli3配置webpack-bundle-analyzer插件【推荐】
Oct 23 #Javascript
p5.js临摹动态图形实现方法详解
Oct 23 #Javascript
jQuery实现轮播图源码
Oct 23 #jQuery
JavaScript实现图片轮播特效
Oct 23 #Javascript
jQuery实现图片随机切换、抽奖功能(实例代码)
Oct 23 #jQuery
微信小程序实现多行文字超出部分省略号显示功能
Oct 23 #Javascript
Vue实现数据请求拦截
Oct 23 #Javascript
You might like
PHP中CheckBox多选框上传失败的代码写法
2017/02/13 PHP
php注册系统和使用Xajax即时验证用户名是否被占用
2017/08/31 PHP
PHP接入微信H5支付的方法示例
2019/10/28 PHP
用javascript获取textarea中的光标位置
2008/05/06 Javascript
刷新页面实现方式总结(HTML,ASP,JS)
2008/11/13 Javascript
半角全角相互转换的js函数
2009/10/16 Javascript
用javascript判断IE版本号简单实用且向后兼容
2013/09/11 Javascript
Jquery getJSON方法详细分析
2013/12/26 Javascript
JavaScript函数获取事件源的小例子
2014/05/14 Javascript
JavaScript获取伪元素(Pseudo-Element)属性的方法技巧
2015/03/13 Javascript
js实现简单折叠、展开菜单的方法
2015/08/28 Javascript
JS实现alert中显示换行的方法
2015/12/17 Javascript
javascript运算符语法全面概述
2016/07/14 Javascript
Bootstrap CSS布局之代码
2016/12/17 Javascript
bootstrap选项卡使用方法解析
2017/01/11 Javascript
JS轮播图中缓动函数的封装
2020/11/25 Javascript
jQuery EasyUI之验证框validatebox实例详解
2017/04/10 jQuery
使用Bootstrap + Vue.js实现表格的动态展示、新增和删除功能
2017/11/27 Javascript
基于axios封装fetch方法及调用实例
2018/02/05 Javascript
vue+echarts实现动态绘制图表及异步加载数据的方法
2018/10/17 Javascript
ES6 如何改变JS内置行为的代理与反射
2019/02/11 Javascript
Vue 数组和对象更新,但是页面没有刷新的解决方式
2019/11/09 Javascript
Js实现粘贴上传图片的原理及示例
2020/12/09 Javascript
[49:59]KG vs Mineski 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/16 DOTA
python中将字典转换成其json字符串
2014/07/16 Python
Python 文本文件内容批量抽取实例
2018/12/10 Python
python批量爬取下载抖音视频
2019/06/17 Python
Win下PyInstaller 安装和使用教程
2019/12/25 Python
浅谈tensorflow中dataset.shuffle和dataset.batch dataset.repeat注意点
2020/06/08 Python
德国家具在线:Fashion For Home
2017/03/11 全球购物
门卫岗位职责
2013/11/15 职场文书
校园主题婚礼活动策划方案
2014/09/15 职场文书
授权委托书(法人单位用)
2014/09/29 职场文书
公安机关纪律作风整顿剖析
2014/10/10 职场文书
公司食堂管理制度
2015/08/05 职场文书
关于国庆节的广播稿
2015/08/19 职场文书