3dexperiments/src/index.js

118 lines
3.2 KiB
JavaScript
Raw Normal View History

import Engine from './engine'
import Camera from './engine/camera'
import Resource from './engine/resource'
2018-11-27 19:10:53 +00:00
import loadMesh from './engine/mesh/loader'
import { Environment } from './engine/environment'
2019-12-28 15:57:19 +00:00
import { LODTerrain } from './engine/components/terrain/lod'
import { Skybox } from './engine/components/skybox'
import { SimplexHeightMap } from './engine/components/terrain/heightmap'
import { Material, Texture } from './engine/mesh/material'
import { GUIRenderer, GUIImage, Dim4 } from './engine/gui'
let game = new Engine()
let env = new Environment()
let gui = new GUIRenderer()
async function pipeline () {
2019-02-12 10:03:18 +00:00
let entity = await loadMesh(game.gl, 'test')
let shader = await game.shaders.createShaderFromFiles(game.gl, 'basic', false)
let terrainShader = await game.shaders.createShaderFromFiles(game.gl, 'terrain', false)
let skyboxShader = await game.shaders.createShaderFromFiles(game.gl, 'skybox', false)
2019-02-12 10:03:18 +00:00
entity.setRotation([0.0, 0.0, -90.0])
2018-11-27 19:10:53 +00:00
// Initialize GUI
await gui.initialize(game)
let itms = [
new GUIImage(await Texture.createTexture2D(game.gl, await Resource.loadImage('noisy.png'), false, game.gl.LINEAR),
new Dim4(-0.9, 0.0, 0.9, 0.0), new Dim4(0.1, 0.0, 0.1, 0.0))
]
// Create a height map based on OpenSimplex noise
let hmap = new SimplexHeightMap(1, 1, 256, 50)
// Create a terrain instance
2019-12-28 15:57:19 +00:00
let terrain = new LODTerrain([0.0, 0.0, 0.0], 1024, 1024, 850, 4)
// Terrain material
let material = new Material(['grass-1024.jpg'])
await material.loadTextures(game.gl)
2019-12-28 15:57:19 +00:00
// test code
for (let i in entity.children) {
entity.children[i].mesh.material = material
}
// Set generator and material for terrain
2019-12-28 15:57:19 +00:00
terrain.setGenerator(hmap)
terrain.setMaterial(material)
// Create and initialize the camera
2019-02-26 16:22:33 +00:00
let cam = new Camera([-200.0, 1.0, 0.0])
cam.updateProjection(game.gl)
// Create skybox
let skybox = new Skybox('skybox', cam.farPlane / 2)
// Load textures and generate a mesh
await skybox.initialize(game.gl)
// Update function for camera and terrain
game.addUpdateFunction(function (dt) {
if (game.input.isDown('w')) {
cam.processKeyboard(0, dt)
} else if (game.input.isDown('s')) {
cam.processKeyboard(1, dt)
}
if (game.input.isDown('a')) {
cam.processKeyboard(2, dt)
} else if (game.input.isDown('d')) {
cam.processKeyboard(3, dt)
}
// Panning
if (game.input.mouseMoved && game.input.mouse.btn0) {
cam.processMouseMove(game.input.mouseOffset)
}
2019-02-12 10:03:18 +00:00
2019-12-28 16:35:25 +00:00
// Update detail levels
terrain.update(game.gl, cam)
terrain.updateLODMesh(game.gl)
})
// Render function for the triangle
game.addRenderFunction(function (gl) {
shader.use(gl)
cam.draw(gl, shader)
entity.draw(gl, shader)
// Use terrain shader
terrainShader.use(gl)
// Set environment variables in shader
env.draw(gl, terrainShader)
// Set the viewport uniforms
cam.draw(gl, terrainShader)
// Draw terrain
terrain.draw(gl, terrainShader)
// Draw the skybox
skyboxShader.use(gl)
skybox.draw(gl, skyboxShader, cam)
})
game.addRenderFunction(function (gl) {
gui.draw(gl, itms)
})
game.startGameLoop()
}
2019-02-12 10:03:18 +00:00
// Start the game, catch any errors thrown
pipeline().catch(function (e) {
console.error(e)
})