91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

基于three.js怎么實現簡易照片墻效果

發布時間:2022-04-11 10:14:58 來源:億速云 閱讀:433 作者:iii 欄目:開發技術

本篇內容主要講解“基于three.js怎么實現簡易照片墻效果”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“基于three.js怎么實現簡易照片墻效果”吧!

代碼:

 <!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>

效果圖如下:

基于three.js怎么實現簡易照片墻效果

到此,相信大家對“基于three.js怎么實現簡易照片墻效果”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

色达县| 青冈县| 德惠市| 昌平区| 洞头县| 福州市| 抚宁县| 乐亭县| 西林县| 通城县| 南京市| 紫云| 娄底市| 临城县| 大方县| 宜昌市| 奎屯市| 兰溪市| 富顺县| 南开区| 磐石市| 宿州市| 曲水县| 肃宁县| 富裕县| 汾西县| 土默特右旗| 保德县| 孟村| 彰化县| 哈巴河县| 大庆市| 栾城县| 沙湾县| 筠连县| 忻城县| 镇原县| 成武县| 木兰县| 福贡县| 沛县|