最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Three.js杂记(十)——贴图

    正文概述 掘金(空城机)   2021-03-28   704

    纹理贴图

    • 贴图介绍
    • 简单的纹理贴图
    • canvas纹理贴图
    • video视频纹理贴图
      • 视频作为Three.js纹理贴图(VideoTexture)
    • 凹凸贴图bumpMap和法线贴图normalMap

    贴图介绍

    纹理贴图是Threejs一个很重要的内容,游戏、产品720展示、物联网3D可视化等项目程序员加载模型的同时同时需要处理纹理贴图。
    Three.js杂记(十)——贴图

    简单的纹理贴图

    通过纹理贴图加载器TextureLoader的load()方法加载一张图片可以返回一个纹理对象Texture纹理对象Texture可以作为模型材质颜色贴图.map属性的值。

    材质的颜色贴图属性.map设置后,模型会从纹理贴图上采集像素值,这时候一般来说不需要在设置材质颜色.color。.map贴图之所以称之为颜色贴图就是因为网格模型会获得颜色贴图的颜色值RGB。
    例子:
    使用平铺的方式,将草地图片贴到PlaneGeometry上,图片如下:

    Three.js杂记(十)——贴图

    代码:

    <div id="app"></div>
    <script type="text/javascript">
    	var scene = new THREE.Scene();
    	camera = new THREE.PerspectiveCamera(45, window.innerWidth / window.innerHeight, 1, 1000);
    	render = new THREE.WebGLRenderer({
    		antialias: true
    	});
    	render.setPixelRatio(window.devicePixelRatio);
    	render.setSize(window.innerWidth, window.innerHeight)
    	/********************************************************/
    	var app = document.getElementById("app");
    	app.appendChild(render.domElement);
    		
    	var geometry = new THREE.PlaneGeometry(20, 20, 32); //平面
    	var textureLoader = new THREE.TextureLoader(); // 纹理加载器
    	var texture = textureLoader.load('./img/grass/grass.png'); 
    	// 设置阵列模式   默认ClampToEdgeWrapping  RepeatWrapping:阵列  镜像阵列:MirroredRepeatWrapping
    	texture.wrapS = THREE.RepeatWrapping;
    	texture.wrapT = THREE.RepeatWrapping;
    	// uv两个方向纹理重复数量
    	texture.repeat.set(10, 10);
    	var material = new THREE.MeshBasicMaterial({
    		map: texture, // 设置纹理贴图
    		side: THREE.DoubleSide
    	});
    	var plane = new THREE.Mesh(geometry, material);
    	scene.add(plane);
    
    	// 相机
    	camera.position.set(20, 20, 40); //设置相机位置
    	camera.lookAt(new THREE.Vector3(0, 0, 0))
    	/********************************************************/
    	function animate(){
    		render.render(scene, camera);
    		window.requestAnimationFrame(animate);
    	}
    	animate();
    </script>
    

    效果:
    Three.js杂记(十)——贴图

    此时纹理贴图是静止状态,如果想要一个运动的纹理贴图,可以设置texture.offset位置

    function animate(){
    	// 设置纹理偏移
    	texture.offset.x -= 0.06
    	render.render(scene, camera);
    	window.requestAnimationFrame(animate);
    }
    animate();
    

    效果:
    Three.js杂记(十)——贴图

    canvas纹理贴图

    在使用贴图的过程中,贴图上可以使用不同的材质

    通过Three.js类CanvasTexture可以分别实现把Canvas画布作为纹理贴图使用。

    Canvas画布作为Three.js纹理贴图(CanvasTexture)
    Canvas画布可以通过2D API绘制各种各样的几何形状,可以通过Canvas绘制一个轮廓后然后作为Three.js网格模型、精灵模型等模型对象的纹理贴图。

    核心代码:

    var textureLoader = new THREE.TextureLoader(); // 纹理加载器
    var texture = new THREE.CanvasTexture(canvas); 
    

    使用canvas当作贴图的图片,首先先创建好canvas的内容,不需要将canvas加入dom树中

    var canvas = document.createElement("canvas");
    canvas.width = 512;
    canvas.height = 128;
    var c = canvas.getContext('2d');
    // 矩形区域填充背景
    c.fillStyle = "#ff0000";
    c.fillRect(0, 0, 512, 128);
    c.beginPath();
    // 文字
    c.beginPath();
    c.translate(256, 64);
    c.fillStyle = "#fff"; //文本填充颜色
    c.font = "bold 28px 宋体"; //字体样式设置
    c.textBaseline = "middle"; //文本与fillText定义的纵坐标
    c.textAlign = "center"; //文本居中(以fillText定义的横坐标)
    c.fillText("空城机  ( ̄ε(# ̄)☆╰╮o( ̄皿 ̄///)", 0, 0);
    
    var geometry = new THREE.PlaneGeometry(40, 20, 32); 
    var textureLoader = new THREE.TextureLoader(); // 纹理加载器
    var texture = new THREE.CanvasTexture(canvas);  // canvas做画布
    
    // 设置阵列模式   默认ClampToEdgeWrapping  RepeatWrapping:阵列  镜像阵列:MirroredRepeatWrapping
    texture.wrapS = THREE.RepeatWrapping;
    texture.wrapT = THREE.RepeatWrapping;
    // uv两个方向纹理重复数量
    texture.repeat.set(1, 1);
    
    var material = new THREE.MeshBasicMaterial({
    	map: texture, // 设置纹理贴图
    	side: THREE.DoubleSide  // 双面
    });
    var box = new THREE.Mesh(geometry, material);
    scene.add(box);
    

    效果:
    Three.js杂记(十)——贴图

    video视频纹理贴图

    通过Three.js类VideoTexture可以分别实现把视频作为纹理贴图使用。

    视频作为Three.js纹理贴图(VideoTexture)

    视频本质上就是一帧帧图片流构成,把视频作为Threejs模型的纹理贴图使用,就是从视频中提取一帧一帧的图片作为模型的纹理贴图,然后不停的更新的纹理贴图就可以产生视频播放的效果。

    使用视频当作贴图的图片,首先先创建好video的内容,不需要将video加入dom树中
    代码:

    let video = document.createElement('video'); //创建video对象
    video.src = "../img/灭世 第二季1.mp4"; // 设置视频地址
    video.autoplay = "autoplay"; //要设置播放
    video.loop = "loop";  //循环播放
    

    核心代码:

    var textureLoader = new THREE.TextureLoader(); // 纹理加载器
    var texture = new THREE.VideoTexture(video);  //视频当作贴图
    

    效果:(因上传图片大小限制,删减了gif图的帧数,造成下图显示效果卡顿)
    Three.js杂记(十)——贴图

    凹凸贴图bumpMap和法线贴图normalMap

    一个复杂的曲面模型,往往模型顶点数量比较多,模型文件比较大,为了降低模型文件大小,法线贴图.normalMap算法自然就产生了,复杂的三维模型3D美术可以通过减面操作把精模简化为简模,然后把精模表面的复杂几何信息映射到法线贴图.normalMap上
    Three.js杂记(十)——贴图
    在之前的一篇文章中,其实就已经使用贴图制作了一个旋转的地球模型了,具体可参考:Three.js杂记(九)—— 练习:地球

    之前的地球上并没有什么山脉突起,只是一个平面图。而现在,可以使用发现贴图,来造成山脉的效果
    法线贴图:
    Three.js杂记(十)——贴图

    代码:

    var textureLoader = new THREE.TextureLoader(); // 纹理加载器
    var texture = textureLoader.load('./img/earth/css_globe_diffuse.jpg'); // 加载图片,返回Texture对象
    // 加载法线贴图
    var textureNormal = textureLoader.load('./img/earth/earth_normal_2048.jpg');
    
    var material = new THREE.MeshPhongMaterial({
    	map: texture, // 设置纹理贴图
    	normalMap: textureNormal, //法线贴图
        //设置深浅程度,默认值(1,1)。
        normalScale: new THREE.Vector2(1.2, 1.2),
    });
    var sphere = new THREE.Mesh(geometry, material);
    scene.add(sphere);
    

    效果:
    Three.js杂记(十)——贴图


    起源地下载网 » Three.js杂记(十)——贴图

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元