three.js 制作动态二维码的示例代码


Posted in Javascript onJuly 31, 2020

今天郭先生说一下用canvas解析图片流,然后制作一个动态二维码的小案例,话不多说先上图,这是郭先生的微信二维码哦!

three.js 制作动态二维码的示例代码

1. 解析图片流

canvas = document.createElement('canvas');//创建canvas画布
content = canvas.getContext('2d');//获取画布的上下文
canvas.width = 310;//设置尺寸
canvas.height = 310;
img = new Image();//创建一张图片
img.src = require("../assets/images/base/wechat.png");//设置图片地址
img.onload = () => {
    //在图片加载后
  content.drawImage(img, 0, 0, canvas.width, canvas.height);//将图片添加到画布,并设置宽高
  imgData = content.getImageData(0, 0, canvas.width, canvas.height).data;//获取画布数据
};

imgData是什么样的呢?如下图

three.js 制作动态二维码的示例代码

这是一个Uint8ClampedArray的类型化数组,这个数组出现最多的也是在imgData上。它会将负数归入0,大于255的数归入255,所以取模就不用了。我们再来看这个数组的长度是384400是怎么来的呢?因为我们设置了画布长宽为310,而imgData四位代表一个rgba像素点,也就是imgData[0]是红色通道,imgData[1]是绿色通道,imgData[2]是蓝色通道,imgData[3]是透明通道…依次循环,所以310 * 310 * 4 = 384400。

2. 处理像素点,画出二维码

for (var i = 0; i < 31 * 31; i++) {
    //random_position为各个小平面块打乱时的位置信息,我设置小平面一共有31 * 31个
  random_position.push([Math.floor(Math.random() * 300 - 150), Math.floor(Math.random() * 300 - 150), Math.floor(Math.random() * 300 - 150)])
}
var color = new Array(310).fill('').map(d => []);//color设置成310个数组
for (var i = 0; i < 310; i++) {
  for (var j = 0; j < 310; j++) {
    let clr = imgData[(i * 310 + j) * 4] + imgData[(i * 310 + j) * 4 + 1] + imgData[(i * 310 + j) * 4 + 2];
    clr = clr > 382 ? 'light' : 'black'; //因为颜色是有深色块和浅色块组成,他们的分界就是rgb通道颜色值之和小于等于127+127+127之和。
    color[i].push(clr)//每个数组有310项,每项的值为'light'或者'black'
  }
}
var color1 = [];//设置color1为小平面颜色数组31 * 31。
color.filter((d, i) => (i + 6) % 10 == 0).forEach((dd, ii) => color1[ii] = dd.filter((d, i) => (i + 6) % 10 == 0));//每10个像素,筛选出1个像素作为小平面的颜色,选取的位置尽量在10个的中间选择,毕竟有的图片比较模糊。
for (var i = 0; i < color1.length; i++) {//31 * 31的循环
  for (var j = 0; j < color1[i].length; j++) {
    var geometry = new THREE.PlaneGeometry(10, 10);
    var material = new THREE.MeshBasicMaterial({
      color: 0xffffff,
      side: THREE.DoubleSide,
      transparent: true,
      opacity: color1[i][j] == 'black' ? 0 : 1,
    });
    var mesh = new THREE.Mesh(geometry, material);//小方块网格
    origin_position.push([j * 10 - 15 * 10, 15 * 10 - i * 10, 0]);//保存序列换后小方块的位置
    mesh.position.set(random_position[j + i * j][0], random_position[j + i * j][1], random_position[j + i * j][2]);//先将小方块的位置设置成打乱的位置,便于动画播放。
    mesh.name = 'plane';
    group.add(mesh);//将所有小平面放到数组,便于操作。
  }
}
scene.add(group);

这部分代码主要是计算部分,没什么技术含量。

3. 实现tween动画

var pos = { time: 0 };
tween1 = new TWEEN.Tween(pos).to({ time: 1 }, 3000);
tween2 = new TWEEN.Tween(pos).to({ time: 0 }, 3000);
tween1.easing(TWEEN.Easing.Quadratic.In);
tween2.easing(TWEEN.Easing.Quadratic.Out);
tween1.onUpdate(onUpdate);
tween2.onUpdate(onUpdate);
tween1.start();

function onUpdate() {
  let time = this._object.time;
  group.children.forEach((d, i) => {
    d.position.set(time * origin_position[i][0] + (1 - time) * random_position[i][0], time * origin_position[i][1] + (1 - time) * random_position[i][1], (1 - time) * random_position[i][2]);
  })
}

这部分只是用了tween的基础功能,请自行查看tween文档。

以上就是three.js 制作动态二维码的示例代码的详细内容,更多关于three.js 制作动态二维码的资料请关注三水点靠木其它相关文章!

Javascript 相关文章推荐
基于jquery DOM写的类似微博发布的效果
Oct 20 Javascript
用console.table()调试javascript
Sep 04 Javascript
用js读、写、删除Cookie代码续篇
Dec 03 Javascript
jQuery实现图片走马灯效果的原理分析
Jan 16 Javascript
jQuery+正则+文本框只能输入数字的实现方法
Oct 07 Javascript
JS实现留言板功能[楼层效果展示]
Dec 27 Javascript
vue下history模式刷新后404错误解决方法
Aug 18 Javascript
Vue.js 使用v-cloak后仍显示变量的解决方法
Nov 19 Javascript
Nuxt项目支持eslint+pritter+typescript的实现
May 20 Javascript
jQuery Ajax async=&gt;false异步改为同步时,解决导致浏览器假死的问题
Jul 22 jQuery
jQuery实现html可联动的百分比进度条
Mar 26 jQuery
vue3.0中setup使用(两种用法)
Dec 02 Vue.js
vue+vuex+axios从后台获取数据存入vuex,组件之间共享数据操作
Jul 31 #Javascript
vue抽出组件并传值实例
Jul 31 #Javascript
Vue通过Blob对象实现导出Excel功能示例代码
Jul 31 #Javascript
Vue.js中使用Vuex实现组件数据共享案例
Jul 31 #Javascript
原生JS实现记忆翻牌游戏
Jul 31 #Javascript
js实现跳一跳小游戏
Jul 31 #Javascript
js实现翻牌小游戏
Jul 31 #Javascript
You might like
常用的php ADODB使用方法集锦
2008/03/25 PHP
PHP 开源框架22个简单简介
2009/08/24 PHP
ThinkPHP登录功能的实现方法
2014/08/20 PHP
php创建session的方法实例详解
2015/01/27 PHP
Yii2使用$this-&gt;context获取当前的Module、Controller(控制器)、Action等
2017/03/29 PHP
深入理解JavaScript系列(2) 揭秘命名函数表达式
2012/01/15 Javascript
jquery插件实现鼠标经过图片右侧显示大图的效果(类似淘宝)
2013/02/04 Javascript
使用phantomjs进行网页抓取的实现代码
2014/09/29 Javascript
jquery实现网页的页面平滑滚动效果代码
2015/11/02 Javascript
JavaScript SHA512加密算法详细代码
2016/10/06 Javascript
JavaScript获取服务器时间的方法详解
2016/12/11 Javascript
vue-router 权限控制的示例代码
2017/09/21 Javascript
vue 2.5.1 源码学习 之Vue.extend 和 data的合并策略
2019/06/04 Javascript
基于JS实现table导出Excel并保留样式
2020/05/19 Javascript
在Echarts图中给坐标轴加一个标识线markLine
2020/07/20 Javascript
python实现统计代码行数的方法
2015/05/22 Python
详解在Python程序中解析并修改XML内容的方法
2015/11/16 Python
Python3中的列表,元组,字典,字符串相关知识小结
2017/11/10 Python
Python基于PyGraphics包实现图片截取功能的方法
2017/12/21 Python
Python实现生成随机数据插入mysql数据库的方法
2017/12/25 Python
浅谈Python对内存的使用(深浅拷贝)
2018/01/17 Python
python编程嵌套函数实例代码
2018/02/11 Python
Pycharm以root权限运行脚本的方法
2019/01/19 Python
python查找重复图片并删除(图片去重)
2019/07/16 Python
Python实现http接口自动化测试的示例代码
2020/10/09 Python
英国领先的酒类网上商城:TheDrinkShop
2017/03/16 全球购物
巴西香水和化妆品购物网站:The Beauty Box
2019/09/03 全球购物
大学生职业生涯规划书模板
2014/01/03 职场文书
校园安全标语
2014/06/07 职场文书
国际商务专业毕业生自我鉴定2014
2014/09/27 职场文书
2014小学语文教师个人工作总结
2014/12/03 职场文书
客房部经理岗位职责
2015/02/02 职场文书
皇城相府导游词
2015/02/06 职场文书
治庸问责工作总结
2015/08/11 职场文书
Python中使用Opencv开发停车位计数器功能
2022/04/04 Python
Spring Security动态权限的实现方法详解
2022/06/16 Java/Android