Compare commits
merge into: blobt:master
blobt:loadobj
blobt:master
pull from: blobt:loadobj
blobt:loadobj
blobt:master
4 Commits
Author | SHA1 | Message | Date |
---|---|---|---|
ubuntu20 | b2f3afdc2c |
灯光调整中
|
4 years ago |
ubuntu20 | cf07a5e500 |
tmp
|
4 years ago |
ubuntu20 | f91e49025e |
更换fxaa抗锯齿
|
4 years ago |
blobt | 99fed93096 |
tmp
|
4 years ago |
29 changed files with 8499 additions and 41 deletions
-
6README.md
-
0app/js/class/test.js
-
0app/js/index.js
-
0app/views/error.ejs
-
11app/views/index.ejs
-
BINdist/b3dd3229bb7d217104f5bbbe79a855e0.png
-
1dist/index.html
-
3gulpfile.babel.js
-
7495npm-shrinkwrap.json
-
2package.json
-
41server/app.js
-
90server/bin/www
-
16server/package.json
-
1server/public/js/cp.min.js
-
57server/public/js/index.js
-
9server/routes/index.js
-
9server/routes/users.js
-
0server/views/error.ejs
-
11server/views/index.ejs
-
656src/index.js
-
11tasks/browser.js
-
4tasks/build.js
-
7tasks/clean.js
-
10tasks/css.js
-
2tasks/default.js
-
10tasks/pages.js
-
42tasks/scripts.js
-
19tasks/server.js
-
27tasks/util/args.js
@ -0,0 +1,6 @@ |
|||||
|
# threejs |
||||
|
|
||||
|
### 初始化要安装的包 |
||||
|
```shell |
||||
|
npm install yargs gulp gulp-if gulp-concat webpack webpack-stream vinyl-named gulp-livereload gulp-plumber gulp-rename gulp-uglify gulp-util express cookie-parser morgan serve-favicon mockjs ejs --save-dev |
||||
|
``` |
@ -0,0 +1,11 @@ |
|||||
|
<!DOCTYPE html> |
||||
|
<html lang="en"> |
||||
|
<head> |
||||
|
<meta charset="UTF-8"> |
||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0"> |
||||
|
<title>Three Js</title> |
||||
|
</head> |
||||
|
<body> |
||||
|
<h1>Three Js!!</h1> |
||||
|
</body> |
||||
|
</html> |
Before Width: 108 | Height: 108 | Size: 28 KiB |
@ -0,0 +1,3 @@ |
|||||
|
import requireDir from 'require-dir'; |
||||
|
|
||||
|
requireDir('./tasks'); |
7495
npm-shrinkwrap.json
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
@ -0,0 +1,41 @@ |
|||||
|
var createError = require('http-errors'); |
||||
|
var express = require('express'); |
||||
|
var path = require('path'); |
||||
|
var cookieParser = require('cookie-parser'); |
||||
|
var logger = require('morgan'); |
||||
|
|
||||
|
var indexRouter = require('./routes/index'); |
||||
|
var usersRouter = require('./routes/users'); |
||||
|
|
||||
|
var app = express(); |
||||
|
|
||||
|
// view engine setup
|
||||
|
app.set('views', path.join(__dirname, 'views')); |
||||
|
app.set('view engine', 'ejs'); |
||||
|
|
||||
|
app.use(logger('dev')); |
||||
|
app.use(express.json()); |
||||
|
app.use(express.urlencoded({ extended: false })); |
||||
|
app.use(cookieParser()); |
||||
|
app.use(express.static(path.join(__dirname, 'public'))); |
||||
|
app.use(require('connect-livereload')()); |
||||
|
app.use('/', indexRouter); |
||||
|
app.use('/users', usersRouter); |
||||
|
|
||||
|
// catch 404 and forward to error handler
|
||||
|
app.use(function(req, res, next) { |
||||
|
next(createError(404)); |
||||
|
}); |
||||
|
|
||||
|
// error handler
|
||||
|
app.use(function(err, req, res, next) { |
||||
|
// set locals, only providing error in development
|
||||
|
res.locals.message = err.message; |
||||
|
res.locals.error = req.app.get('env') === 'development' ? err : {}; |
||||
|
|
||||
|
// render the error page
|
||||
|
res.status(err.status || 500); |
||||
|
res.render('error'); |
||||
|
}); |
||||
|
|
||||
|
module.exports = app; |
@ -0,0 +1,90 @@ |
|||||
|
#!/usr/bin/env node |
||||
|
|
||||
|
/** |
||||
|
* Module dependencies. |
||||
|
*/ |
||||
|
|
||||
|
var app = require('../app'); |
||||
|
var debug = require('debug')('server:server'); |
||||
|
var http = require('http'); |
||||
|
|
||||
|
/** |
||||
|
* Get port from environment and store in Express. |
||||
|
*/ |
||||
|
|
||||
|
var port = normalizePort(process.env.PORT || '3000'); |
||||
|
app.set('port', port); |
||||
|
|
||||
|
/** |
||||
|
* Create HTTP server. |
||||
|
*/ |
||||
|
|
||||
|
var server = http.createServer(app); |
||||
|
|
||||
|
/** |
||||
|
* Listen on provided port, on all network interfaces. |
||||
|
*/ |
||||
|
|
||||
|
server.listen(port); |
||||
|
server.on('error', onError); |
||||
|
server.on('listening', onListening); |
||||
|
|
||||
|
/** |
||||
|
* Normalize a port into a number, string, or false. |
||||
|
*/ |
||||
|
|
||||
|
function normalizePort(val) { |
||||
|
var port = parseInt(val, 10); |
||||
|
|
||||
|
if (isNaN(port)) { |
||||
|
// named pipe |
||||
|
return val; |
||||
|
} |
||||
|
|
||||
|
if (port >= 0) { |
||||
|
// port number |
||||
|
return port; |
||||
|
} |
||||
|
|
||||
|
return false; |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* Event listener for HTTP server "error" event. |
||||
|
*/ |
||||
|
|
||||
|
function onError(error) { |
||||
|
if (error.syscall !== 'listen') { |
||||
|
throw error; |
||||
|
} |
||||
|
|
||||
|
var bind = typeof port === 'string' |
||||
|
? 'Pipe ' + port |
||||
|
: 'Port ' + port; |
||||
|
|
||||
|
// handle specific listen errors with friendly messages |
||||
|
switch (error.code) { |
||||
|
case 'EACCES': |
||||
|
console.error(bind + ' requires elevated privileges'); |
||||
|
process.exit(1); |
||||
|
break; |
||||
|
case 'EADDRINUSE': |
||||
|
console.error(bind + ' is already in use'); |
||||
|
process.exit(1); |
||||
|
break; |
||||
|
default: |
||||
|
throw error; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* Event listener for HTTP server "listening" event. |
||||
|
*/ |
||||
|
|
||||
|
function onListening() { |
||||
|
var addr = server.address(); |
||||
|
var bind = typeof addr === 'string' |
||||
|
? 'pipe ' + addr |
||||
|
: 'port ' + addr.port; |
||||
|
debug('Listening on ' + bind); |
||||
|
} |
@ -0,0 +1,16 @@ |
|||||
|
{ |
||||
|
"name": "server", |
||||
|
"version": "0.0.0", |
||||
|
"private": true, |
||||
|
"scripts": { |
||||
|
"start": "node ./bin/www" |
||||
|
}, |
||||
|
"dependencies": { |
||||
|
"cookie-parser": "~1.4.4", |
||||
|
"debug": "~2.6.9", |
||||
|
"ejs": "~2.6.1", |
||||
|
"express": "~4.16.1", |
||||
|
"http-errors": "~1.6.3", |
||||
|
"morgan": "~1.9.1" |
||||
|
} |
||||
|
} |
@ -0,0 +1 @@ |
|||||
|
!function(t){function r(e){if(o[e])return o[e].exports;var n=o[e]={"exports":{},"id":e,"loaded":!1};return t[e].call(n.exports,n,n.exports,r),n.loaded=!0,n.exports}var o={};r.m=t,r.c=o,r.p="",r(0)}([function(t,r,o){t.exports=o(1)},function(t,r){"use strict"}]); |
@ -0,0 +1,57 @@ |
|||||
|
/******/ (function(modules) { // webpackBootstrap
|
||||
|
/******/ // The module cache
|
||||
|
/******/ var installedModules = {}; |
||||
|
|
||||
|
/******/ // The require function
|
||||
|
/******/ function __webpack_require__(moduleId) { |
||||
|
|
||||
|
/******/ // Check if module is in cache
|
||||
|
/******/ if(installedModules[moduleId]) |
||||
|
/******/ return installedModules[moduleId].exports; |
||||
|
|
||||
|
/******/ // Create a new module (and put it into the cache)
|
||||
|
/******/ var module = installedModules[moduleId] = { |
||||
|
/******/ exports: {}, |
||||
|
/******/ id: moduleId, |
||||
|
/******/ loaded: false |
||||
|
/******/ }; |
||||
|
|
||||
|
/******/ // Execute the module function
|
||||
|
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); |
||||
|
|
||||
|
/******/ // Flag the module as loaded
|
||||
|
/******/ module.loaded = true; |
||||
|
|
||||
|
/******/ // Return the exports of the module
|
||||
|
/******/ return module.exports; |
||||
|
/******/ } |
||||
|
|
||||
|
|
||||
|
/******/ // expose the modules object (__webpack_modules__)
|
||||
|
/******/ __webpack_require__.m = modules; |
||||
|
|
||||
|
/******/ // expose the module cache
|
||||
|
/******/ __webpack_require__.c = installedModules; |
||||
|
|
||||
|
/******/ // __webpack_public_path__
|
||||
|
/******/ __webpack_require__.p = ""; |
||||
|
|
||||
|
/******/ // Load entry module and return exports
|
||||
|
/******/ return __webpack_require__(0); |
||||
|
/******/ }) |
||||
|
/************************************************************************/ |
||||
|
/******/ ([ |
||||
|
/* 0 */ |
||||
|
/***/ (function(module, exports, __webpack_require__) { |
||||
|
|
||||
|
module.exports = __webpack_require__(1); |
||||
|
|
||||
|
|
||||
|
/***/ }), |
||||
|
/* 1 */ |
||||
|
/***/ (function(module, exports) { |
||||
|
|
||||
|
"use strict"; |
||||
|
|
||||
|
/***/ }) |
||||
|
/******/ ]); |
@ -0,0 +1,9 @@ |
|||||
|
var express = require('express'); |
||||
|
var router = express.Router(); |
||||
|
|
||||
|
/* GET home page. */ |
||||
|
router.get('/', function(req, res, next) { |
||||
|
res.render('index', { title: 'Express' }); |
||||
|
}); |
||||
|
|
||||
|
module.exports = router; |
@ -0,0 +1,9 @@ |
|||||
|
var express = require('express'); |
||||
|
var router = express.Router(); |
||||
|
|
||||
|
/* GET users listing. */ |
||||
|
router.get('/', function(req, res, next) { |
||||
|
res.send('respond with a resource'); |
||||
|
}); |
||||
|
|
||||
|
module.exports = router; |
@ -0,0 +1,11 @@ |
|||||
|
<!DOCTYPE html> |
||||
|
<html lang="en"> |
||||
|
<head> |
||||
|
<meta charset="UTF-8"> |
||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0"> |
||||
|
<title>Three Js</title> |
||||
|
</head> |
||||
|
<body> |
||||
|
<h1>Three Js!!</h1> |
||||
|
</body> |
||||
|
</html> |
@ -1,68 +1,644 @@ |
|||||
import "@babel/polyfill"; |
|
||||
import { MeshBasicMaterial } from 'three/src/materials/MeshBasicMaterial.js'; |
|
||||
import { WebGLRenderer } from 'three/src/renderers/WebGLRenderer.js'; |
|
||||
import { Scene } from 'three/src/scenes/Scene.js'; |
|
||||
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 { 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 v1 = new THREE.Vector3(2.3393851600186215, 11.576051832245172, -3.4251959648280117); |
||||
|
var v2 = new THREE.Vector3(11.766872261378083, 12.781233823342808, 13.780029939510671); |
||||
|
var v3 = new THREE.Vector3(11.766872261378083, 12.781233823342808, -13.780029939510671); |
||||
|
var v4 = new THREE.Vector3(2.3393851600186215, 11.576051832245172, 3.4251959648280117); |
||||
|
|
||||
|
var ui; |
||||
|
|
||||
|
var gui = new GUI(); |
||||
|
var params = { |
||||
|
exposure: 0.68 |
||||
|
}; |
||||
|
|
||||
|
var container = document.getElementById('container'); |
||||
|
|
||||
//创建场景
|
//创建场景
|
||||
var scene = new Scene(); |
|
||||
|
var scene = new THREE.Scene(); |
||||
|
|
||||
//创建模型和material
|
|
||||
var geometry = new THREE.SphereBufferGeometry(20, 10, 50); |
|
||||
var material = new MeshBasicMaterial({ |
|
||||
color: 0xffff00 |
|
||||
}); |
|
||||
|
var hemiLight = new THREE.HemisphereLight(0xffffff, 0xffffff, 0.0); |
||||
|
scene.add(hemiLight); |
||||
|
|
||||
|
addBulb(v2); |
||||
|
addBulb(v1); |
||||
|
addBulb(v3); |
||||
|
addBulb(v4); |
||||
|
|
||||
var mesh = new THREE.Mesh(geometry, material); |
|
||||
scene.add(mesh); |
|
||||
|
|
||||
var camera = new THREE.PerspectiveCamera(45, window.innerWidth / window.innerHeight, 0.1, 1000); |
|
||||
camera.position.set(0, 0, 100); |
|
||||
camera.lookAt(scene.position); |
|
||||
|
ui = gui.addFolder("环境光与穹顶灯"); |
||||
|
ui.add(params, 'exposure', 0, 1); |
||||
|
|
||||
var renderer = new WebGLRenderer(); |
|
||||
|
|
||||
renderer.setSize(window.innerWidth, window.innerHeight); |
|
||||
renderer.setClearColor("rgb(25, 25, 25)", 1); //设置背景颜色
|
|
||||
document.body.appendChild(renderer.domElement); |
|
||||
|
var textureLoader = new TextureLoader(); |
||||
|
var mtlLoader = new MTLLoader(); |
||||
|
var objLoader = new OBJLoader(); |
||||
|
|
||||
renderer.render(scene, camera); |
|
||||
|
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(); |
||||
|
materials.materials.dengkuang = makeDengkuang(); |
||||
|
|
||||
|
|
||||
|
objLoader.setMaterials(materials); |
||||
|
|
||||
|
objLoader.load('keting.obj', function (mesh) { |
||||
|
console.log(mesh); |
||||
|
mesh.scale.set(0.01, 0.01, 0.01); |
||||
|
scene.add(mesh); |
||||
|
} |
||||
|
); |
||||
|
|
||||
|
}); |
||||
|
|
||||
/*//光照 |
|
||||
var ambient = new THREE.AmbientLight(0x004444); //环境光
|
|
||||
var point = new THREE.PointLight(0xffffff); |
|
||||
point.position.set(400, 200, 301); //点光源位置
|
|
||||
|
|
||||
//布置场景
|
|
||||
// scene.add(ambient);
|
|
||||
// scene.add(point);
|
|
||||
|
//添加辅助坐标
|
||||
|
var axesHelper = new THREE.AxesHelper(15); |
||||
|
scene.add(axesHelper); |
||||
|
|
||||
// 辅助坐标系
|
|
||||
var axisHelper = new THREE.AxesHelper(250); |
|
||||
scene.add(axisHelper); |
|
||||
|
//创建相机
|
||||
|
var camera = new THREE.PerspectiveCamera(50, window.innerWidth / window.innerHeight, 0.1, 1000000); |
||||
|
camera.position.copy(v2); |
||||
|
|
||||
//创建摄像机
|
|
||||
var camera = new THREE.PerspectiveCamera(45, window.innerWidth / window.innerHeight, 0.1, 1000); |
|
||||
camera.position.set(0, 0, 100); |
|
||||
camera.lookAt(scene.position); |
|
||||
|
|
||||
//创建渲染器
|
//创建渲染器
|
||||
var renderer = new WebGLRenderer(); |
|
||||
|
var renderer = new THREE.WebGLRenderer(); |
||||
|
//renderer.physicallyCorrectLights = true;
|
||||
|
renderer.outputEncoding = THREE.sRGBEncoding; |
||||
|
renderer.shadowMap.enabled = true; |
||||
|
renderer.toneMapping = THREE.ReinhardToneMapping; |
||||
|
|
||||
|
renderer.setPixelRatio(window.devicePixelRatio); |
||||
renderer.setSize(window.innerWidth, window.innerHeight); |
renderer.setSize(window.innerWidth, window.innerHeight); |
||||
renderer.setClearColor("rgb(255, 255, 255)", 1); //设置背景颜色
|
|
||||
document.body.appendChild(renderer.domElement); |
|
||||
|
renderer.setClearColor("rgb(30, 30, 30)", 1); //设置背景颜色
|
||||
|
container.appendChild(renderer.domElement); |
||||
|
|
||||
|
//控制器
|
||||
|
var clock = new THREE.Clock(); |
||||
const controls = new OrbitControls(camera, renderer.domElement); |
const controls = new OrbitControls(camera, renderer.domElement); |
||||
|
controls.target.copy(v1); |
||||
|
// controls.enableZoom = true;
|
||||
|
// controls.enablePan = false;
|
||||
|
// controls.minDistance = 5;
|
||||
|
// controls.maxDistance = 15;
|
||||
|
// controls.enableDamping = true;
|
||||
|
// controls.dampingFactor = 0.25;
|
||||
|
// controls.rotation = 0.3;
|
||||
|
|
||||
|
//抗锯齿
|
||||
|
var composer; |
||||
|
var ssaaRenderPass; |
||||
|
var copyPass; |
||||
|
|
||||
|
composer = new EffectComposer(renderer); |
||||
|
|
||||
|
ssaaRenderPass = new SSAARenderPass(scene, camera); |
||||
|
ssaaRenderPass.unbiased = true; |
||||
|
composer.addPass(ssaaRenderPass); |
||||
|
copyPass = new ShaderPass(CopyShader); |
||||
|
composer.addPass(copyPass); |
||||
|
composer.setSize(window.innerWidth, window.innerHeight); |
||||
|
|
||||
// 渲染函数
|
// 渲染函数
|
||||
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); |
||||
|
|
||||
|
ssaaRenderPass.sampleLevel = 3; |
||||
|
composer.render(); |
||||
|
|
||||
|
//renderer.render(scene, camera); //执行渲染操作
|
||||
} |
} |
||||
|
|
||||
render(); |
render(); |
||||
|
|
||||
//监听鼠标事件,触发渲染函数,更新canvas画布渲染效果
|
|
||||
controls.addEventListener('change', render);*/ |
|
||||
|
|
||||
|
function addBulb(position) { |
||||
|
var bulbGeometry = new THREE.SphereBufferGeometry(0.10, 10, 8); |
||||
|
var bulbMat = new THREE.MeshStandardMaterial({ |
||||
|
emissive: 0xffffff, |
||||
|
emissiveIntensity: 12, |
||||
|
color: 0x000000 |
||||
|
}); |
||||
|
var bulbLight = new THREE.PointLight(0xddeeff, 8, 100, 2); |
||||
|
bulbLight.add(new THREE.Mesh(bulbGeometry, bulbMat)); |
||||
|
bulbLight.position.copy(position); |
||||
|
scene.add(bulbLight); |
||||
|
} |
||||
|
|
||||
|
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: 1.5, |
||||
|
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; |
||||
|
} |
||||
|
|
||||
|
function makeDengkuang() { |
||||
|
//diffuse map
|
||||
|
var diffuseMpa = textureLoader.load('./dengkuang_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('./dengkuang_Normal.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('./dengkuang_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('./dengkuang_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; |
||||
|
} |
@ -0,0 +1,11 @@ |
|||||
|
import gulp from 'gulp'; |
||||
|
import gulpif from 'gulp-if'; |
||||
|
import gutil from 'gulp-util'; |
||||
|
import args from './util/args'; |
||||
|
|
||||
|
gulp.task('browser', (cb)=>{ |
||||
|
if(!args.watch) return cb(); |
||||
|
gulp.watch('app/**/*.js', ['scripts']); |
||||
|
gulp.watch('app/**/*.ejs', ['pages']); |
||||
|
gulp.watch('app/**/*.css', ['css']); |
||||
|
}) |
@ -0,0 +1,4 @@ |
|||||
|
import gulp from 'gulp'; |
||||
|
import gulpSequence from 'gulp-sequence'; |
||||
|
|
||||
|
gulp.task('build', gulpSequence('clean', 'css', 'pages', 'scripts', ['browser', 'server'])); |
@ -0,0 +1,7 @@ |
|||||
|
import gulp from 'gulp'; |
||||
|
import del from 'del'; |
||||
|
import args from './util/args'; |
||||
|
|
||||
|
gulp.task('clean', ()=>{ |
||||
|
return del(['server/public', 'server/views']); |
||||
|
}) |
@ -0,0 +1,10 @@ |
|||||
|
import gulp from 'gulp'; |
||||
|
import gulpif from 'gulp-if'; |
||||
|
import livereload from 'gulp-livereload'; |
||||
|
import args from './util/args'; |
||||
|
|
||||
|
gulp.task('css',()=>{ |
||||
|
return gulp.src('app/**/*.css') |
||||
|
.pipe(gulp.dest('server/public')) |
||||
|
.pipe(gulpif(args.watch, livereload())) |
||||
|
}) |
@ -0,0 +1,2 @@ |
|||||
|
import gulp from 'gulp'; |
||||
|
gulp.task('default', ['build']); |
@ -0,0 +1,10 @@ |
|||||
|
import gulp from 'gulp'; |
||||
|
import gulpif from 'gulp-if'; |
||||
|
import livereload from 'gulp-livereload'; |
||||
|
import args from './util/args' |
||||
|
|
||||
|
gulp.task('pages',()=>{ |
||||
|
return gulp.src('app/**/*.ejs') |
||||
|
.pipe(gulp.dest('server')) |
||||
|
.pipe(gulpif(args.watch, livereload())) |
||||
|
}) |
@ -0,0 +1,42 @@ |
|||||
|
import gulp from 'gulp'; |
||||
|
import gulpif from 'gulp-if'; |
||||
|
import concat from 'gulp-concat'; |
||||
|
import webpack from 'webpack'; |
||||
|
import gulpWebpack from 'webpack-stream'; |
||||
|
import named from 'vinyl-named'; |
||||
|
import livereload from 'gulp-livereload'; |
||||
|
import plumber from 'gulp-plumber'; |
||||
|
import rename from 'gulp-rename'; |
||||
|
import uglify from 'gulp-uglify'; |
||||
|
import {log,colors} from 'gulp-util'; |
||||
|
import args from './util/args'; |
||||
|
|
||||
|
gulp.task('scripts',()=>{ |
||||
|
return gulp.src(['app/js/index.js']) |
||||
|
.pipe(plumber({ |
||||
|
errorHandle:function(){ |
||||
|
|
||||
|
} |
||||
|
})) |
||||
|
.pipe(named()) |
||||
|
.pipe(gulpWebpack({ |
||||
|
module:{ |
||||
|
loaders:[{ |
||||
|
test:/\.js$/, |
||||
|
loader:'babel' |
||||
|
}] |
||||
|
} |
||||
|
}),null,(err,stats)=>{ |
||||
|
log(`Finished '${colors.cyan('scripts')}'`,stats.toString({ |
||||
|
chunks:false |
||||
|
})) |
||||
|
}) |
||||
|
.pipe(gulp.dest('server/public/js')) |
||||
|
.pipe(rename({ |
||||
|
basename:'cp', |
||||
|
extname:'.min.js' |
||||
|
})) |
||||
|
.pipe(uglify({compress:{properties:false},output:{'quote_keys':true}})) |
||||
|
.pipe(gulp.dest('server/public/js')) |
||||
|
.pipe(gulpif(args.watch,livereload())) |
||||
|
}) |
@ -0,0 +1,19 @@ |
|||||
|
import gulp from 'gulp'; |
||||
|
import gulpif from 'gulp-if'; |
||||
|
import liveserver from 'gulp-live-server'; |
||||
|
import args from './util/args'; |
||||
|
|
||||
|
gulp.task('server',(cb)=>{ |
||||
|
if(!args.watch) return cb(); |
||||
|
|
||||
|
var server = liveserver.new(['--harmony', 'server/bin/www']); |
||||
|
server.start(); |
||||
|
|
||||
|
gulp.watch(['server/public/**/*.js', 'server/public/**/*.ejs'], function(file){ |
||||
|
server.notify.apply(server, [file]) |
||||
|
}) |
||||
|
|
||||
|
gulp.watch(['server/routes/**/*.js', 'server/app.js'], function(){ |
||||
|
server.start.bind(server)() |
||||
|
}) |
||||
|
}) |
@ -0,0 +1,27 @@ |
|||||
|
import yargs from 'yargs'; |
||||
|
const args = yargs |
||||
|
.option('production', { |
||||
|
boolean: true, |
||||
|
default: false, |
||||
|
description: 'min all script' |
||||
|
}) |
||||
|
.option('watch', { |
||||
|
boolean: true, |
||||
|
default: false, |
||||
|
description: 'watch all script' |
||||
|
}) |
||||
|
.option('verbose', { |
||||
|
boolean: true, |
||||
|
default: false, |
||||
|
description: 'log' |
||||
|
}) |
||||
|
.option('sourcemaps', { |
||||
|
description: 'force to create the sourcemaps' |
||||
|
}) |
||||
|
.option('port', { |
||||
|
string: true, |
||||
|
default: 8080, |
||||
|
description: 'server port' |
||||
|
}) |
||||
|
.argv |
||||
|
export default args; |
Write
Preview
Loading…
Cancel
Save
Reference in new issue