|
@ -1,85 +1,100 @@ |
|
|
import * as THREE from 'three'; |
|
|
import * as THREE from 'three'; |
|
|
|
|
|
import { GUI } from 'three/examples/jsm/libs/dat.gui.module.js'; |
|
|
|
|
|
import { MeshStandardMaterial } from 'three'; |
|
|
import { TextureLoader } from 'three/src/loaders/TextureLoader.js'; |
|
|
import { TextureLoader } from 'three/src/loaders/TextureLoader.js'; |
|
|
import { WebGLRenderer } from 'three/src/renderers/WebGLRenderer.js'; |
|
|
import { WebGLRenderer } from 'three/src/renderers/WebGLRenderer.js'; |
|
|
import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls.js'; |
|
|
import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls.js'; |
|
|
|
|
|
import { MTLLoader } from 'three/examples/jsm/loaders/MTLLoader.js'; |
|
|
|
|
|
import { OBJLoader } from 'three/examples/jsm/loaders/OBJLoader.js' |
|
|
|
|
|
import { EffectComposer } from 'three/examples/jsm/postprocessing/EffectComposer.js'; |
|
|
|
|
|
import { RenderPass } from 'three/examples/jsm/postprocessing/RenderPass.js'; |
|
|
|
|
|
import { ShaderPass } from 'three/examples/jsm/postprocessing/ShaderPass.js'; |
|
|
|
|
|
import { CopyShader } from 'three/examples/jsm/shaders/CopyShader.js'; |
|
|
|
|
|
import { FXAAShader } from 'three/examples/jsm/shaders/FXAAShader.js'; |
|
|
|
|
|
import { SSAARenderPass } from 'three/examples/jsm/postprocessing/SSAARenderPass.js'; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var ui; |
|
|
|
|
|
// ref for lumens: http://www.power-sure.com/lumens.htm
|
|
|
|
|
|
var bulbLuminousPowers = { |
|
|
|
|
|
"110000 lm (1000W)": 110000, |
|
|
|
|
|
"3500 lm (300W)": 3500, |
|
|
|
|
|
"1700 lm (100W)": 1700, |
|
|
|
|
|
"800 lm (60W)": 800, |
|
|
|
|
|
"400 lm (40W)": 400, |
|
|
|
|
|
"180 lm (25W)": 180, |
|
|
|
|
|
"20 lm (4W)": 20, |
|
|
|
|
|
"Off": 0 |
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
// ref for solar irradiances: https://en.wikipedia.org/wiki/Lux
|
|
|
|
|
|
var hemiLuminousIrradiances = { |
|
|
|
|
|
"0.5 lx (Full Moon)": 0.5, |
|
|
|
|
|
"3.4 lx (City Twilight)": 3.4, |
|
|
|
|
|
"10 lx (Custom Nemo)": 10, |
|
|
|
|
|
}; |
|
|
|
|
|
var gui = new GUI(); |
|
|
|
|
|
var params = { |
|
|
|
|
|
exposure: 0.68, |
|
|
|
|
|
bulbPower: Object.keys(bulbLuminousPowers)[4], |
|
|
|
|
|
hemiIrradiance: Object.keys(hemiLuminousIrradiances)[1] |
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
var container = document.getElementById('container'); |
|
|
var container = document.getElementById('container'); |
|
|
|
|
|
|
|
|
//创建场景
|
|
|
//创建场景
|
|
|
var scene = new THREE.Scene(); |
|
|
var scene = new THREE.Scene(); |
|
|
|
|
|
|
|
|
var hemiLight = new THREE.HemisphereLight(0xddeeff, 0x0f0e0d, 2.8); |
|
|
|
|
|
|
|
|
var hemiLight = new THREE.HemisphereLight(0xddeeff, 0x0f0e0d, 0.8); |
|
|
scene.add(hemiLight); |
|
|
scene.add(hemiLight); |
|
|
|
|
|
|
|
|
var bulbLight = new THREE.PointLight(0xffee88, 10.8, 10, 2.9); |
|
|
|
|
|
bulbLight.position.set(0.0, 1.3, 0.0); |
|
|
|
|
|
|
|
|
var bulbGeometry = new THREE.SphereBufferGeometry(0.22, 16, 8); |
|
|
|
|
|
var bulbMat = new THREE.MeshStandardMaterial({ |
|
|
|
|
|
emissive: 0xffffff, |
|
|
|
|
|
emissiveIntensity: 12, |
|
|
|
|
|
color: 0x000000 |
|
|
|
|
|
}); |
|
|
|
|
|
var bulbLight = new THREE.PointLight(0xddeeff, 1, 100, 2); |
|
|
|
|
|
bulbLight.add(new THREE.Mesh(bulbGeometry, bulbMat)); |
|
|
|
|
|
bulbLight.position.set(0.0, 25.0, -22.0); |
|
|
scene.add(bulbLight); |
|
|
scene.add(bulbLight); |
|
|
|
|
|
|
|
|
|
|
|
ui = gui.addFolder("灯光"); |
|
|
|
|
|
ui.add(params, 'hemiIrradiance', Object.keys(hemiLuminousIrradiances)); |
|
|
|
|
|
ui.add(params, 'bulbPower', Object.keys(bulbLuminousPowers)); |
|
|
|
|
|
ui.add(params, 'exposure', 0, 1); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var textureLoader = new TextureLoader(); |
|
|
var textureLoader = new TextureLoader(); |
|
|
|
|
|
var mtlLoader = new MTLLoader(); |
|
|
|
|
|
var objLoader = new OBJLoader(); |
|
|
|
|
|
|
|
|
//创建地板
|
|
|
|
|
|
var diffuseTexture = textureLoader.load("hardwood2_diffuse.jpg"); |
|
|
|
|
|
diffuseTexture.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
diffuseTexture.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
diffuseTexture.anisotropy = 4; |
|
|
|
|
|
diffuseTexture.repeat.set(10, 24); |
|
|
|
|
|
diffuseTexture.encoding = THREE.sRGBEncoding; |
|
|
|
|
|
|
|
|
|
|
|
var bumpTexture = textureLoader.load("hardwood2_bump.jpg"); |
|
|
|
|
|
bumpTexture.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
bumpTexture.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
bumpTexture.anisotropy = 4; |
|
|
|
|
|
bumpTexture.repeat.set(10, 24); |
|
|
|
|
|
bumpTexture.encoding = THREE.sRGBEncoding; |
|
|
|
|
|
|
|
|
|
|
|
var roughnessTexture = textureLoader.load("hardwood2_roughness.jpg"); |
|
|
|
|
|
roughnessTexture.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessTexture.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessTexture.anisotropy = 4; |
|
|
|
|
|
roughnessTexture.repeat.set(10, 24); |
|
|
|
|
|
roughnessTexture.encoding = THREE.sRGBEncoding; |
|
|
|
|
|
|
|
|
|
|
|
var floorMat = new THREE.MeshStandardMaterial({ |
|
|
|
|
|
roughness: 0.8, |
|
|
|
|
|
color: 0xffffff, |
|
|
|
|
|
metalness: 0.12, |
|
|
|
|
|
bumpScale: 0.005, |
|
|
|
|
|
side: THREE.DoubleSide, |
|
|
|
|
|
map: diffuseTexture, |
|
|
|
|
|
bumpMap: bumpTexture, |
|
|
|
|
|
roughnessMap:roughnessTexture |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
mtlLoader.setPath('./'); |
|
|
|
|
|
mtlLoader.load('dimian.mtl', function (materials) { |
|
|
|
|
|
materials.preload(); |
|
|
|
|
|
|
|
|
|
|
|
materials.materials.dimian = makeDimian(); |
|
|
|
|
|
materials.materials.tijiao = makeTijiao(); |
|
|
|
|
|
materials.materials.qiangti = makeQiangti(); |
|
|
|
|
|
materials.materials.chuangkuang = makeChuangkuang(); |
|
|
|
|
|
materials.materials.glass = makeGlass(); |
|
|
|
|
|
materials.materials.chuanglianbu = makeChuanglianbu(); |
|
|
|
|
|
materials.materials.chuangsha = makeChuangsha(); |
|
|
|
|
|
materials.materials.heikon = makeHeikon(); |
|
|
|
|
|
materials.materials.jinshuxian = makeJinshuxian(); |
|
|
|
|
|
materials.materials.qiangbu = makeQiangbu(); |
|
|
|
|
|
materials.materials.dalishi = makeDalishi(); |
|
|
|
|
|
|
|
|
floorMat.needsUpdate = true; |
|
|
|
|
|
|
|
|
|
|
|
var floorGeometry = new THREE.PlaneBufferGeometry(20, 20); |
|
|
|
|
|
var floorMesh = new THREE.Mesh(floorGeometry, floorMat); |
|
|
|
|
|
floorMesh.receiveShadow = true; |
|
|
|
|
|
floorMesh.rotation.x = - Math.PI / 2.0; |
|
|
|
|
|
scene.add(floorMesh); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//创建墙
|
|
|
|
|
|
var matArrayB = [];//外墙
|
|
|
|
|
|
matArrayB.push(new THREE.MeshPhongMaterial({color: 0xafc0ca})); //前 0xafc0ca :灰色
|
|
|
|
|
|
matArrayB.push(new THREE.MeshPhongMaterial({color: 0x9cb2d1})); //后 0x9cb2d1:淡紫
|
|
|
|
|
|
matArrayB.push(new THREE.MeshPhongMaterial({color: 0xd6e4ec})); //上 0xd6e4ec: 偏白色
|
|
|
|
|
|
matArrayB.push(new THREE.MeshPhongMaterial({color: 0xd6e4ec})); //下
|
|
|
|
|
|
matArrayB.push(new THREE.MeshPhongMaterial({color: 0xafc0ca})); //左 0xafc0ca :灰色
|
|
|
|
|
|
matArrayB.push(new THREE.MeshPhongMaterial({color: 0xafc0ca})); //右
|
|
|
|
|
|
|
|
|
|
|
|
function createCubeWall(width, height, depth,angle,material,x,y,z){ |
|
|
|
|
|
var cubeGeometry = new THREE.BoxGeometry(width, height, depth ); |
|
|
|
|
|
var cube = new THREE.Mesh( cubeGeometry, material ); |
|
|
|
|
|
cube.position.x = x; |
|
|
|
|
|
cube.position.y = height / 2; |
|
|
|
|
|
cube.position.z = z; |
|
|
|
|
|
cube.rotation.y += angle*Math.PI; //-逆时针旋转,+顺时针
|
|
|
|
|
|
scene.add(cube); |
|
|
|
|
|
|
|
|
objLoader.setMaterials(materials); |
|
|
|
|
|
|
|
|
|
|
|
objLoader.load('ket.obj', function (mesh) { |
|
|
|
|
|
|
|
|
|
|
|
mesh.scale.set(0.01, 0.01, 0.01); |
|
|
|
|
|
scene.add(mesh); |
|
|
} |
|
|
} |
|
|
createCubeWall(0.05, 1.6, 4.5,0,matArrayB,2,0,0.225); |
|
|
|
|
|
createCubeWall(0.05, 1.6, 4,0.5,matArrayB,0,0,-2); |
|
|
|
|
|
|
|
|
); |
|
|
|
|
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//添加辅助坐标
|
|
|
//添加辅助坐标
|
|
@ -87,27 +102,516 @@ var axesHelper = new THREE.AxesHelper( 15 ); |
|
|
scene.add(axesHelper); |
|
|
scene.add(axesHelper); |
|
|
|
|
|
|
|
|
//创建相机
|
|
|
//创建相机
|
|
|
var camera = new THREE.PerspectiveCamera(50, window.innerWidth / window.innerHeight, 0.1, 100); |
|
|
|
|
|
|
|
|
var camera = new THREE.PerspectiveCamera(50, window.innerWidth / window.innerHeight, 0.1, 1000000); |
|
|
camera.position.x = -4; |
|
|
camera.position.x = -4; |
|
|
camera.position.z = 3; |
|
|
camera.position.z = 3; |
|
|
camera.position.y = 1; |
|
|
camera.position.y = 1; |
|
|
|
|
|
|
|
|
//创建渲染器
|
|
|
//创建渲染器
|
|
|
var renderer = new WebGLRenderer(); |
|
|
|
|
|
renderer.physicallyCorrectLights = true; |
|
|
|
|
|
|
|
|
var renderer = new THREE.WebGLRenderer(); |
|
|
|
|
|
//renderer.physicallyCorrectLights = true;
|
|
|
renderer.outputEncoding = THREE.sRGBEncoding; |
|
|
renderer.outputEncoding = THREE.sRGBEncoding; |
|
|
renderer.shadowMap.enabled = true; |
|
|
renderer.shadowMap.enabled = true; |
|
|
renderer.toneMapping = THREE.ReinhardToneMapping; |
|
|
renderer.toneMapping = THREE.ReinhardToneMapping; |
|
|
|
|
|
|
|
|
renderer.setPixelRatio(window.devicePixelRatio); |
|
|
renderer.setPixelRatio(window.devicePixelRatio); |
|
|
renderer.setSize(window.innerWidth, window.innerHeight); |
|
|
renderer.setSize(window.innerWidth, window.innerHeight); |
|
|
renderer.setClearColor("rgb(30, 30, 30)", 1); //设置背景颜色
|
|
|
renderer.setClearColor("rgb(30, 30, 30)", 1); //设置背景颜色
|
|
|
container.appendChild(renderer.domElement); |
|
|
container.appendChild(renderer.domElement); |
|
|
|
|
|
|
|
|
|
|
|
//控制器
|
|
|
|
|
|
var clock = new THREE.Clock(); |
|
|
const controls = new OrbitControls(camera, renderer.domElement); |
|
|
const controls = new OrbitControls(camera, renderer.domElement); |
|
|
|
|
|
// controls.enableZoom = true;
|
|
|
|
|
|
// controls.enablePan = false;
|
|
|
|
|
|
// controls.minDistance = 5;
|
|
|
|
|
|
// controls.maxDistance = 15;
|
|
|
|
|
|
// controls.enableDamping = true;
|
|
|
|
|
|
// controls.dampingFactor = 0.25;
|
|
|
|
|
|
// controls.rotation = 0.3;
|
|
|
|
|
|
|
|
|
|
|
|
var targetMat = new THREE.MeshBasicMaterial({ color: '#ff0000' }); |
|
|
|
|
|
var targetGeo = new THREE.BoxGeometry(4, 17, 4); |
|
|
|
|
|
var camTarget = new THREE.Mesh(targetGeo, targetMat); |
|
|
|
|
|
camTarget.position.set(0, 0, 0); |
|
|
|
|
|
//scene.add(camTarget);
|
|
|
|
|
|
|
|
|
|
|
|
//抗锯齿
|
|
|
|
|
|
var composer; |
|
|
|
|
|
var fxaaPass; |
|
|
|
|
|
var renderPass; |
|
|
|
|
|
var pixelRatio; |
|
|
|
|
|
|
|
|
|
|
|
renderPass = new RenderPass(scene, camera); |
|
|
|
|
|
fxaaPass = new ShaderPass(FXAAShader); |
|
|
|
|
|
pixelRatio = renderer.getPixelRatio(); |
|
|
|
|
|
fxaaPass.material.uniforms['resolution'].value.x = 1 / (container.offsetWidth * pixelRatio); |
|
|
|
|
|
fxaaPass.material.uniforms['resolution'].value.y = 1 / (container.offsetHeight * pixelRatio); |
|
|
|
|
|
|
|
|
|
|
|
composer = new EffectComposer(renderer); |
|
|
|
|
|
composer.addPass(renderPass); |
|
|
|
|
|
composer.addPass(fxaaPass); |
|
|
|
|
|
|
|
|
// 渲染函数
|
|
|
// 渲染函数
|
|
|
function render() { |
|
|
function render() { |
|
|
renderer.render(scene, camera); //执行渲染操作
|
|
|
|
|
|
|
|
|
controls.update(clock.getDelta); |
|
|
|
|
|
//controls.target.copy(camTarget.position).add(new THREE.Vector3(0, 7, 0));
|
|
|
|
|
|
renderer.toneMappingExposure = Math.pow(params.exposure, 5.0); // to allow for very bright scenes.
|
|
|
|
|
|
bulbLight.power = bulbLuminousPowers[params.bulbPower]; |
|
|
|
|
|
//bulbMat.emissiveIntensity = bulbLight.intensity / Math.pow(0.02, 2.0); // convert from intensity to irradiance at bulb surface
|
|
|
|
|
|
hemiLight.intensity = hemiLuminousIrradiances[params.hemiIrradiance]; |
|
|
requestAnimationFrame(render); |
|
|
requestAnimationFrame(render); |
|
|
|
|
|
|
|
|
|
|
|
//fxaa
|
|
|
|
|
|
composer.render(); |
|
|
|
|
|
//renderer.render(scene, camera); //执行渲染操作
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
render(); |
|
|
render(); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function makeDimian() { |
|
|
|
|
|
//diffuse map
|
|
|
|
|
|
var diffuseMpa = textureLoader.load('./ket_dimian_BaseColor.png'); |
|
|
|
|
|
diffuseMpa.wrapS = 1000; |
|
|
|
|
|
diffuseMpa.wrapT = 1000; |
|
|
|
|
|
diffuseMpa.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
diffuseMpa.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//bump map
|
|
|
|
|
|
var bumpMap = textureLoader.load('./ket_dimian_Height.png'); |
|
|
|
|
|
bumpMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
bumpMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//matelness map
|
|
|
|
|
|
var matelMap = textureLoader.load('./ket_dimian_Metallic.png'); |
|
|
|
|
|
matelMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
matelMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//roughness map
|
|
|
|
|
|
var roughnessMap = textureLoader.load('./ket_dimian_Roughness.png'); |
|
|
|
|
|
roughnessMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
roughnessMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var ret = new MeshStandardMaterial({ |
|
|
|
|
|
map: diffuseMpa, |
|
|
|
|
|
bumpMap: bumpMap, |
|
|
|
|
|
metalnessMap: matelMap, |
|
|
|
|
|
roughnessMap: roughnessMap, |
|
|
|
|
|
//metalness: 0.02,
|
|
|
|
|
|
//roughness: 0.13,
|
|
|
|
|
|
bumpScale: 0.06 |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
var ui = gui.addFolder("地面"); |
|
|
|
|
|
ui.add(ret, "metalness", 0.0, 1); |
|
|
|
|
|
ui.add(ret, "roughness", 0.0, 1); |
|
|
|
|
|
return ret; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function makeTijiao() { |
|
|
|
|
|
//diffuse map
|
|
|
|
|
|
var diffuseMpa = textureLoader.load('./ket_tijiao_BaseColor.png'); |
|
|
|
|
|
diffuseMpa.wrapS = 1000; |
|
|
|
|
|
diffuseMpa.wrapT = 1000; |
|
|
|
|
|
diffuseMpa.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
diffuseMpa.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//bump map
|
|
|
|
|
|
var bumpMap = textureLoader.load('./ket_tijiao_Height.png'); |
|
|
|
|
|
bumpMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
bumpMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//matelness map
|
|
|
|
|
|
var matelMap = textureLoader.load('./ket_tijiao_Metallic.png'); |
|
|
|
|
|
matelMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
matelMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//roughness map
|
|
|
|
|
|
var roughnessMap = textureLoader.load('./ket_tijiao_Roughness.png'); |
|
|
|
|
|
roughnessMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
roughnessMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var ret = new MeshStandardMaterial({ |
|
|
|
|
|
map: diffuseMpa, |
|
|
|
|
|
bumpMap: bumpMap, |
|
|
|
|
|
metalnessMap: matelMap, |
|
|
|
|
|
roughnessMap: roughnessMap, |
|
|
|
|
|
bumpScale: 0.06 |
|
|
|
|
|
}); |
|
|
|
|
|
return ret; |
|
|
|
|
|
} |
|
|
|
|
|
function makeQiangti() { |
|
|
|
|
|
//diffuse map
|
|
|
|
|
|
var diffuseMpa = textureLoader.load('./ket_qiangti_BaseColor.png'); |
|
|
|
|
|
diffuseMpa.wrapS = 1000; |
|
|
|
|
|
diffuseMpa.wrapT = 1000; |
|
|
|
|
|
diffuseMpa.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
diffuseMpa.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//bump map
|
|
|
|
|
|
var bumpMap = textureLoader.load('./ket_qiangti_Height.png'); |
|
|
|
|
|
bumpMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
bumpMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//matelness map
|
|
|
|
|
|
var matelMap = textureLoader.load('./ket_qiangti_Metallic.png'); |
|
|
|
|
|
matelMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
matelMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//roughness map
|
|
|
|
|
|
var roughnessMap = textureLoader.load('./ket_qiangti_Roughness.png'); |
|
|
|
|
|
roughnessMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
roughnessMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var ret = new MeshStandardMaterial({ |
|
|
|
|
|
map: diffuseMpa, |
|
|
|
|
|
bumpMap: bumpMap, |
|
|
|
|
|
metalnessMap: matelMap, |
|
|
|
|
|
roughnessMap: roughnessMap, |
|
|
|
|
|
bumpScale: 0.06 |
|
|
|
|
|
}); |
|
|
|
|
|
return ret; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function makeChuangkuang() { |
|
|
|
|
|
//diffuse map
|
|
|
|
|
|
var diffuseMpa = textureLoader.load('./ket_chuangkuang_BaseColor.png'); |
|
|
|
|
|
diffuseMpa.wrapS = 1000; |
|
|
|
|
|
diffuseMpa.wrapT = 1000; |
|
|
|
|
|
diffuseMpa.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
diffuseMpa.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//bump map
|
|
|
|
|
|
var bumpMap = textureLoader.load('./ket_chuangkuang_Height.png'); |
|
|
|
|
|
bumpMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
bumpMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//matelness map
|
|
|
|
|
|
var matelMap = textureLoader.load('./ket_chuangkuang_Metallic.png'); |
|
|
|
|
|
matelMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
matelMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//roughness map
|
|
|
|
|
|
var roughnessMap = textureLoader.load('./ket_chuangkuang_Roughness.png'); |
|
|
|
|
|
roughnessMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
roughnessMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var ret = new MeshStandardMaterial({ |
|
|
|
|
|
map: diffuseMpa, |
|
|
|
|
|
bumpMap: bumpMap, |
|
|
|
|
|
metalnessMap: matelMap, |
|
|
|
|
|
roughnessMap: roughnessMap, |
|
|
|
|
|
bumpScale: 0.06 |
|
|
|
|
|
}); |
|
|
|
|
|
return ret; |
|
|
|
|
|
} |
|
|
|
|
|
function makeChuangsha() { |
|
|
|
|
|
//diffuse map
|
|
|
|
|
|
var diffuseMpa = textureLoader.load('./ket_chuangsha_BaseColor.png'); |
|
|
|
|
|
diffuseMpa.wrapS = 1000; |
|
|
|
|
|
diffuseMpa.wrapT = 1000; |
|
|
|
|
|
diffuseMpa.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
diffuseMpa.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//bump map
|
|
|
|
|
|
var bumpMap = textureLoader.load('./ket_chuangsha_Height.png'); |
|
|
|
|
|
bumpMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
bumpMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//matelness map
|
|
|
|
|
|
var matelMap = textureLoader.load('./ket_chuangsha_Metallic.png'); |
|
|
|
|
|
matelMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
matelMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//roughness map
|
|
|
|
|
|
var roughnessMap = textureLoader.load('./ket_chuangsha_Roughness.png'); |
|
|
|
|
|
roughnessMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
roughnessMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var ret = new MeshStandardMaterial({ |
|
|
|
|
|
transparent:true, |
|
|
|
|
|
opacity:0.91, |
|
|
|
|
|
map: diffuseMpa, |
|
|
|
|
|
bumpMap: bumpMap, |
|
|
|
|
|
metalnessMap: matelMap, |
|
|
|
|
|
roughnessMap: roughnessMap, |
|
|
|
|
|
}); |
|
|
|
|
|
return ret; |
|
|
|
|
|
} |
|
|
|
|
|
function makeGlass() { |
|
|
|
|
|
//diffuse map
|
|
|
|
|
|
var diffuseMpa = textureLoader.load('./ket_glass_BaseColor.png'); |
|
|
|
|
|
diffuseMpa.wrapS = 1000; |
|
|
|
|
|
diffuseMpa.wrapT = 1000; |
|
|
|
|
|
diffuseMpa.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
diffuseMpa.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//bump map
|
|
|
|
|
|
var bumpMap = textureLoader.load('./ket_glass_Height.png'); |
|
|
|
|
|
bumpMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
bumpMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//matelness map
|
|
|
|
|
|
var matelMap = textureLoader.load('./ket_glass_Metallic.png'); |
|
|
|
|
|
matelMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
matelMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//roughness map
|
|
|
|
|
|
var roughnessMap = textureLoader.load('./ket_glass_Roughness.png'); |
|
|
|
|
|
roughnessMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
roughnessMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var ret = new MeshStandardMaterial({ |
|
|
|
|
|
transparent:true, |
|
|
|
|
|
alphaMap: diffuseMpa, |
|
|
|
|
|
bumpMap: bumpMap, |
|
|
|
|
|
metalnessMap: matelMap, |
|
|
|
|
|
roughnessMap: roughnessMap, |
|
|
|
|
|
bumpScale: 0.06 |
|
|
|
|
|
}); |
|
|
|
|
|
return ret; |
|
|
|
|
|
} |
|
|
|
|
|
function makeChuanglianbu() { |
|
|
|
|
|
//diffuse map
|
|
|
|
|
|
var diffuseMpa = textureLoader.load('./ket_chuanglianbu_BaseColor.png'); |
|
|
|
|
|
diffuseMpa.wrapS = 1000; |
|
|
|
|
|
diffuseMpa.wrapT = 1000; |
|
|
|
|
|
diffuseMpa.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
diffuseMpa.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//bump map
|
|
|
|
|
|
var bumpMap = textureLoader.load('./ket_chuanglianbu_Height.png'); |
|
|
|
|
|
bumpMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
bumpMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//matelness map
|
|
|
|
|
|
var matelMap = textureLoader.load('./ket_chuanglianbu_Metallic.png'); |
|
|
|
|
|
matelMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
matelMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//roughness map
|
|
|
|
|
|
var roughnessMap = textureLoader.load('./ket_chuanglianbu_Roughness.png'); |
|
|
|
|
|
roughnessMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
roughnessMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var ret = new MeshStandardMaterial({ |
|
|
|
|
|
map: diffuseMpa, |
|
|
|
|
|
bumpMap: bumpMap, |
|
|
|
|
|
metalnessMap: matelMap, |
|
|
|
|
|
roughnessMap: roughnessMap, |
|
|
|
|
|
bumpScale: 0.06 |
|
|
|
|
|
}); |
|
|
|
|
|
return ret; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function makeHeikon() { |
|
|
|
|
|
//diffuse map
|
|
|
|
|
|
var diffuseMpa = textureLoader.load('./ket_heikon_BaseColor.png'); |
|
|
|
|
|
diffuseMpa.wrapS = 1000; |
|
|
|
|
|
diffuseMpa.wrapT = 1000; |
|
|
|
|
|
diffuseMpa.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
diffuseMpa.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//bump map
|
|
|
|
|
|
var bumpMap = textureLoader.load('./ket_heikon_Height.png'); |
|
|
|
|
|
bumpMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
bumpMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//matelness map
|
|
|
|
|
|
var matelMap = textureLoader.load('./ket_heikon_Metallic.png'); |
|
|
|
|
|
matelMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
matelMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//roughness map
|
|
|
|
|
|
var roughnessMap = textureLoader.load('./ket_heikon_Roughness.png'); |
|
|
|
|
|
roughnessMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
roughnessMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var ret = new MeshStandardMaterial({ |
|
|
|
|
|
map: diffuseMpa, |
|
|
|
|
|
bumpMap: bumpMap, |
|
|
|
|
|
metalnessMap: matelMap, |
|
|
|
|
|
roughnessMap: roughnessMap, |
|
|
|
|
|
bumpScale: 0.06 |
|
|
|
|
|
}); |
|
|
|
|
|
return ret; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function makeJinshuxian() { |
|
|
|
|
|
//diffuse map
|
|
|
|
|
|
var diffuseMpa = textureLoader.load('./ket_jinshuxian_BaseColor.png'); |
|
|
|
|
|
diffuseMpa.wrapS = 1000; |
|
|
|
|
|
diffuseMpa.wrapT = 1000; |
|
|
|
|
|
diffuseMpa.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
diffuseMpa.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//bump map
|
|
|
|
|
|
var bumpMap = textureLoader.load('./ket_jinshuxian_Height.png'); |
|
|
|
|
|
bumpMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
bumpMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//matelness map
|
|
|
|
|
|
var matelMap = textureLoader.load('./ket_jinshuxian_Metallic.png'); |
|
|
|
|
|
matelMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
matelMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//roughness map
|
|
|
|
|
|
var roughnessMap = textureLoader.load('./ket_jinshuxian_Roughness.png'); |
|
|
|
|
|
roughnessMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
roughnessMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var ret = new MeshStandardMaterial({ |
|
|
|
|
|
map: diffuseMpa, |
|
|
|
|
|
bumpMap: bumpMap, |
|
|
|
|
|
metalnessMap: matelMap, |
|
|
|
|
|
roughnessMap: roughnessMap, |
|
|
|
|
|
bumpScale: 0.06 |
|
|
|
|
|
}); |
|
|
|
|
|
return ret; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function makeQiangbu() { |
|
|
|
|
|
//diffuse map
|
|
|
|
|
|
var diffuseMpa = textureLoader.load('./ket_qiangbu_BaseColor.png'); |
|
|
|
|
|
diffuseMpa.wrapS = 1000; |
|
|
|
|
|
diffuseMpa.wrapT = 1000; |
|
|
|
|
|
diffuseMpa.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
diffuseMpa.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//bump map
|
|
|
|
|
|
var bumpMap = textureLoader.load('./ket_qiangbu_Height.png'); |
|
|
|
|
|
bumpMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
bumpMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//matelness map
|
|
|
|
|
|
var matelMap = textureLoader.load('./ket_qiangbu_Metallic.png'); |
|
|
|
|
|
matelMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
matelMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//roughness map
|
|
|
|
|
|
var roughnessMap = textureLoader.load('./ket_qiangbu_Roughness.png'); |
|
|
|
|
|
roughnessMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
roughnessMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var ret = new MeshStandardMaterial({ |
|
|
|
|
|
//color: 0xff0000,
|
|
|
|
|
|
map: diffuseMpa, |
|
|
|
|
|
bumpMap: bumpMap, |
|
|
|
|
|
metalnessMap: matelMap, |
|
|
|
|
|
roughnessMap: roughnessMap, |
|
|
|
|
|
bumpScale: 0.06 |
|
|
|
|
|
}); |
|
|
|
|
|
return ret; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function makeDalishi() { |
|
|
|
|
|
//diffuse map
|
|
|
|
|
|
var diffuseMpa = textureLoader.load('./ket_dalishi_BaseColor.png'); |
|
|
|
|
|
diffuseMpa.wrapS = 1000; |
|
|
|
|
|
diffuseMpa.wrapT = 1000; |
|
|
|
|
|
diffuseMpa.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
diffuseMpa.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//bump map
|
|
|
|
|
|
var bumpMap = textureLoader.load('./ket_dalishi_Height.png'); |
|
|
|
|
|
bumpMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
bumpMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
bumpMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//matelness map
|
|
|
|
|
|
var matelMap = textureLoader.load('./ket_dalishi_Metallic.png'); |
|
|
|
|
|
matelMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
matelMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
matelMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
//roughness map
|
|
|
|
|
|
var roughnessMap = textureLoader.load('./ket_dalishi_Roughness.png'); |
|
|
|
|
|
roughnessMap.wrapS = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.wrapT = THREE.RepeatWrapping; |
|
|
|
|
|
roughnessMap.repeat.copy(new THREE.Vector2(1, 1)); |
|
|
|
|
|
roughnessMap.offset.copy(new THREE.Vector2(0, 0)); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var ret = new MeshStandardMaterial({ |
|
|
|
|
|
//color: 0xff0000,
|
|
|
|
|
|
map: diffuseMpa, |
|
|
|
|
|
bumpMap: bumpMap, |
|
|
|
|
|
metalnessMap: matelMap, |
|
|
|
|
|
roughnessMap: roughnessMap, |
|
|
|
|
|
bumpScale: 0.01 |
|
|
|
|
|
}); |
|
|
|
|
|
return ret; |
|
|
|
|
|
} |