亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

基于three.js實(shí)現(xiàn)簡易照片墻效果

 更新時間:2022年04月10日 12:49:22   作者:蕓軒  
這篇文章主要為大家詳細(xì)介紹了基于three.js實(shí)現(xiàn)簡易照片墻效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

學(xué)習(xí)three.js的過程中,寫的一個簡易照片墻,可以使用鼠標(biāo)滾輪上下瀏覽,采用的是移動相機(jī)的方式。

代碼貼出來,供學(xué)習(xí)這一塊的朋友們參考和指導(dǎo):

?<!DOCTYPE HTML>
<HTML>
<HEAD>
? ? <META charset="utf-8">
? ? <META name="viewport" content="width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
? ? <TITLE></TITLE>
? ? <STYLE>
? ? ? ? html, body {
? ? ? ? ? ? height: 100%;
? ? ? ? }
?
? ? ? ? body {
? ? ? ? ? ? background-color: #454545;
? ? ? ? ? ? margin: 0;
? ? ? ? ? ? overflow: hidden;
? ? ? ? ? ? background-size:cover;
? ? ? ? }
?
? ? ? ? .element {
? ? ? ? ? ? width: 240px;
? ? ? ? ? ? height: 320px;
? ? ? ? }
?
? ? ? ? .element img {
? ? ? ? ? ? position: absolute;
? ? ? ? ? ? border:none;
? ? ? ? }
?
? ? </STYLE>
?
?
</HEAD>
<BODY>
?
<script src="js/jquery-3.1.1.min.js"></script>
?
<script src="js/jquery.mousewheel.min.js"></script>
?
<SCRIPT src="js/three.min.js"></SCRIPT>
?
<SCRIPT src="js/CSS3DRenderer.js"></SCRIPT>
?
<DIV id="container"></DIV>
?
<DIV id="menu">
?
? ? <SCRIPT>
? ? ? ? var table = [];
?
? ? ? ? var camera, scene, renderer;
?
? ? ? ? createImages();
? ? ? ? init();
? ? ? ? animate();
?
? ? ? ? function init() {
? ? ? ? ? ? camera = new THREE.PerspectiveCamera( 40, window.innerWidth / window.innerHeight, 1, 10000 );
? ? ? ? ? ? camera.position.x = 0;
? ? ? ? ? ? camera.position.y = 0;
? ? ? ? ? ? camera.position.z = 3000;
? ? ? ? ? ? camera.lookAt({
? ? ? ? ? ? ? ? x : 0,
? ? ? ? ? ? ? ? y : 0,
? ? ? ? ? ? ? ? z : 0
? ? ? ? ? ? });
?
? ? ? ? ? ? scene = new THREE.Scene();
?
? ? ? ? ? ? for ( var i = 0; i < table.length ; i ++ ) {
? ? ? ? ? ? ? ? var element = document.createElement( 'div' );
? ? ? ? ? ? ? ? element.className = 'element';
? ? ? ? ? ? ? ? element.id = 'element';
?
? ? ? ? ? ? ? ? var photo = document.createElement('img');
? ? ? ? ? ? ? ? photo.className = 'photo';
? ? ? ? ? ? ? ? photo.id = table[ i ][0];
? ? ? ? ? ? ? ? photo.src='images/'+table[ i ][0]+'?t='+Math.floor((Math.random()*100)+1);
?
? ? ? ? ? ? ? ? element.appendChild( photo );
?
? ? ? ? ? ? ? ? var objectCSS = new THREE.CSS3DObject( element );
? ? ? ? ? ? ? ? objectCSS.position.x = ( table[ i ] [1] * 250 ) - 1750;
? ? ? ? ? ? ? ? objectCSS.position.y = - ( table[ i ] [2]* 330 ) + 1200;
? ? ? ? ? ? ? ? objectCSS.position.z = 0;
? ? ? ? ? ? ? ? scene.add( objectCSS );
? ? ? ? ? ? }
?
? ? ? ? ? ? renderer = new THREE.CSS3DRenderer();
? ? ? ? ? ? renderer.setSize( window.innerWidth, window.innerHeight );
? ? ? ? ? ? renderer.domElement.style.position = 'absolute';
? ? ? ? ? ? document.getElementById( 'container' ).appendChild( renderer.domElement );
?
? ? ? ? ? ? window.addEventListener( 'resize', onWindowResize, false );
? ? ? ? }
?
? ? ? ? function onWindowResize() {
?
? ? ? ? ? ? camera.aspect = window.innerWidth / window.innerHeight;
? ? ? ? ? ? camera.updateProjectionMatrix();
?
? ? ? ? ? ? renderer.setSize( window.innerWidth, window.innerHeight );
?
? ? ? ? }
?
? ? ? ? function animate() {
?
? ? ? ? ? ? renderer.render( scene, camera );
? ? ? ? ? ? requestAnimationFrame( animate );
?
? ? ? ? }
?
? ? ? ? $(window).mousewheel(function(event) {
? ? ? ? ? ? camera.position.y -= event.deltaY * event.deltaFactor;
? ? ? ? ? ? camera.position.z = 3000;
?
? ? ? ? ? ? var target = new THREE.Vector3();
? ? ? ? ? ? var _eye = new THREE.Vector3();
?
? ? ? ? ? ? _eye.subVectors( camera.position, target );
? ? ? ? ? ? camera.position.addVectors( target, _eye );
? ? ? ? ? ? camera.lookAt( _eye );
?
? ? ? ? });
?
? ? ? ? function createImages (){
? ? ? ? ? ? var files = [
? ? ? ? ? ? ? ? {"name":"0.jpg"},
? ? ? ? ? ? ? ? {"name":"1.jpg"},
? ? ? ? ? ? ? ? {"name":"2.jpg"}
? ? ? ? ? ? ];
? ? ? ? ? ? var row =1;
? ? ? ? ? ? var col = 1;
? ? ? ? ? ? for(var i = 0; i < files.length;i++)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? var file = [];
? ? ? ? ? ? ? ? file[0] = files[i]['name'];
? ? ? ? ? ? ? ? file[1] = col++;
? ? ? ? ? ? ? ? file[2] = row;
? ? ? ? ? ? ? ? table[i] = file;
? ? ? ? ? ? ? ? if(col > 13)
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? col = 1;
? ? ? ? ? ? ? ? ? ? row++;
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? }
?
?
? ? </SCRIPT>
</DIV>
</BODY>
</HTML>

效果圖如下:

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論