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

three.js 制作動態(tài)二維碼的示例代碼

 更新時間:2020年07月31日 15:14:59   作者:郭先生  
這篇文章主要介紹了three.js 制作動態(tài)二維碼的示例代碼,文中講解非常細致,幫助大家更好的理解和學習,感興趣的朋友可以了解下

今天郭先生說一下用canvas解析圖片流,然后制作一個動態(tài)二維碼的小案例,話不多說先上圖,這是郭先生的微信二維碼哦!

1. 解析圖片流

canvas = document.createElement('canvas');//創(chuàng)建canvas畫布
content = canvas.getContext('2d');//獲取畫布的上下文
canvas.width = 310;//設置尺寸
canvas.height = 310;
img = new Image();//創(chuàng)建一張圖片
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;//獲取畫布數(shù)據(jù)
};

imgData是什么樣的呢?如下圖

這是一個Uint8ClampedArray的類型化數(shù)組,這個數(shù)組出現(xiàn)最多的也是在imgData上。它會將負數(shù)歸入0,大于255的數(shù)歸入255,所以取模就不用了。我們再來看這個數(shù)組的長度是384400是怎么來的呢?因為我們設置了畫布長寬為310,而imgData四位代表一個rgba像素點,也就是imgData[0]是紅色通道,imgData[1]是綠色通道,imgData[2]是藍色通道,imgData[3]是透明通道…依次循環(huán),所以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個數(shù)組
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)//每個數(shù)組有310項,每項的值為'light'或者'black'
  }
}
var color1 = [];//設置color1為小平面顏色數(shù)組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的循環(huán)
  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);//小方塊網(wǎng)格
    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);//將所有小平面放到數(shù)組,便于操作。
  }
}
scene.add(group);

這部分代碼主要是計算部分,沒什么技術含量。

3. 實現(xiàn)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 制作動態(tài)二維碼的示例代碼的詳細內(nèi)容,更多關于three.js 制作動態(tài)二維碼的資料請關注腳本之家其它相關文章!

相關文章

  • 關于JavaScript中URL對象的一些妙用

    關于JavaScript中URL對象的一些妙用

    avaScript URL() 構造函數(shù)返回一個新創(chuàng)建的 URL 對象,表示由一組參數(shù)定義的 URL,利用該構造函數(shù)可以獲取 RL的查詢、參數(shù)等,下面這篇文章主要給大家介紹了關于JavaScript URL對象的一些妙用,需要的朋友可以參考下
    2021-10-10
  • 基于aotu.js實現(xiàn)微信自動添加通訊錄中的聯(lián)系人功能

    基于aotu.js實現(xiàn)微信自動添加通訊錄中的聯(lián)系人功能

    這篇文章主要介紹了利用aotu.js實現(xiàn)微信自動添加通訊錄中的聯(lián)系人,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05
  • JavaScript實現(xiàn)的商品搶購倒計時功能示例

    JavaScript實現(xiàn)的商品搶購倒計時功能示例

    這篇文章主要介紹了JavaScript實現(xiàn)的商品搶購倒計時功能,可實現(xiàn)分秒級別的實時顯示倒計時效果,涉及js日期時間計算與頁面元素動態(tài)操作相關技巧,需要的朋友可以參考下
    2017-04-04
  • JavaScript markdown 編輯器實現(xiàn)雙屏同步滾動

    JavaScript markdown 編輯器實現(xiàn)雙屏同步滾動

    這篇文章主要介紹了JavaScript markdown 編輯器實現(xiàn)雙屏同步滾動,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-08-08
  • JS實現(xiàn)圖片延遲加載并淡入淡出效果的簡單方法

    JS實現(xiàn)圖片延遲加載并淡入淡出效果的簡單方法

    我們大家都知道,對于一個網(wǎng)站最占用帶寬,最影響頁面顯示速度的東西就是圖片。圖片是很重要的,作為一個站長我們是千方百計的使用各種技巧來優(yōu)化圖片,但其實有一種簡單的方法,只需要幾行代碼就能達到這種效果。同時還附加一種淡入淡出的顯示效果,下面一起來看看。
    2016-08-08
  • Javascript 阻止javascript事件冒泡,獲取控件ID值

    Javascript 阻止javascript事件冒泡,獲取控件ID值

    Javascript學習日記-阻止javascript事件冒泡,獲取控件ID值
    2009-06-06
  • jsonp原理及使用

    jsonp原理及使用

    jsonp 全稱是JSON with Padding,是為了解決跨域請求資源而產(chǎn)生的解決方案。下面讓我們了解一下是如何使用的吧。
    2013-10-10
  • 超好玩js頁面效果之實現(xiàn)數(shù)值的動態(tài)變化

    超好玩js頁面效果之實現(xiàn)數(shù)值的動態(tài)變化

    這篇文章主要給大家介紹了關于超好玩js頁面效果之實現(xiàn)數(shù)值的動態(tài)變化的相關資料,文中通過示例代碼及圖文介紹的非常詳細,對大家學習或者使用js具有一定的參考學習價值,需要的朋友可以參考下
    2022-10-10
  • JavaScript 自定義彈出窗口的實現(xiàn)代碼

    JavaScript 自定義彈出窗口的實現(xiàn)代碼

    這篇文章主要介紹了JavaScript 自定義彈出窗口的實現(xiàn)代碼,實現(xiàn)一采用html編寫彈出窗口內(nèi)容,實現(xiàn)二采用JavaScript編寫彈出窗口內(nèi)容,結合示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-09-09
  • javascript實現(xiàn)C語言經(jīng)典程序題

    javascript實現(xiàn)C語言經(jīng)典程序題

    這篇文章主要介紹了javascript實現(xiàn)C語言經(jīng)典程序題的解題思路,感興趣的小伙伴們可以參考一下
    2015-11-11

最新評論