使用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 相关文章推荐
用showModalDialog弹出页面后,提交表单总是弹出一个新窗口
Jul 18 Javascript
从零开始学习jQuery (十) jQueryUI常用功能实战
Feb 23 Javascript
让网页跳转到指定位置的jquery代码非书签
Sep 06 Javascript
jQuery中hasClass()方法用法实例
Jan 06 Javascript
jquery实现ajax加载超时提示的方法
Jul 23 Javascript
Angular2使用Angular-CLI快速搭建工程(二)
May 21 Javascript
Bootstrap Table使用整理(三)
Jun 09 Javascript
基于Vue2的独立构建与运行时构建的差别(详解)
Dec 06 Javascript
angularjs实现对表单输入改变的监控(ng-change和watch两种方式)
Aug 29 Javascript
小程序实现搜索框
Jun 19 Javascript
通过实例解析js可枚举属性与不可枚举属性
Dec 02 Javascript
使用Typescript开发微信小程序的步骤详解
Jan 12 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
Laravel 模型使用软删除-左连接查询-表起别名示例
2019/10/24 PHP
JavaScript 自动完成脚本整理(33个)
2009/10/20 Javascript
JS读取cookies信息(记录用户名)
2012/01/10 Javascript
Jquery实现鼠标移上弹出提示框、移出消失思路及代码
2013/05/19 Javascript
JQuery分别取得每行最后一列和最后一行的示例代码
2013/08/18 Javascript
鼠标移到图片上变大显示而不是放大镜效果
2014/06/15 Javascript
javascript模拟实现ajax加载框实例
2014/10/15 Javascript
Nodejs爬虫进阶教程之异步并发控制
2016/02/15 NodeJs
基于Bootstrap实现图片轮播效果
2016/05/22 Javascript
jquery判断checkbox是否选中及改变checkbox状态的实现方法
2016/05/26 Javascript
使用Angular缓存父页面数据的方法
2017/01/03 Javascript
vue如何实现observer和watcher源码解析
2017/03/09 Javascript
JavaScript数组排序reverse()和sort()方法详解
2017/12/24 Javascript
TensorFlow.js 微信小程序插件开始支持模型缓存的方法
2020/02/21 Javascript
[01:29]Ti4循环赛第三日精彩回顾
2014/07/13 DOTA
python发送邮件接收邮件示例分享
2014/01/21 Python
利用打码兔和超人打码自封装的打码类分享
2014/03/16 Python
详细解析Python中的变量的数据类型
2015/05/13 Python
通过Python来使用七牛云存储的方法详解
2015/08/07 Python
安装python3的时候就是输入python3死活没有反应的解决方法
2018/01/24 Python
Python批量发送post请求的实现代码
2018/05/05 Python
python 寻找list中最大元素对应的索引方法
2018/06/28 Python
Python框架Flask的基本数据库操作方法分析
2018/07/13 Python
Django实现web端tailf日志文件功能及实例详解
2019/07/28 Python
零基础学python应该从哪里入手
2020/08/11 Python
python如何调用php文件中的函数详解
2020/12/29 Python
HTML5 语音搜索(淘宝店语音搜素)
2013/01/03 HTML / CSS
.NET笔试题(20个问题)
2016/02/02 面试题
学期研究性学习个人的自我评价
2014/01/09 职场文书
挂科检讨书范文
2014/02/20 职场文书
委托书样本
2014/04/02 职场文书
《吃水不忘挖井人》教学反思
2014/04/15 职场文书
奥运会口号
2014/06/13 职场文书
2015年客房服务员工作总结
2015/05/15 职场文书
投诉信范文
2015/07/02 职场文书
canvas 中如何实现物体的框选
2022/08/05 Javascript