This is a 3D Browser Game or Threejs+Cannon virtual experience engine.

This source codes allows SketchUp or CG Artist Game Level designers and ThreeJs developers to build browser mobile/android games quickly and easily by using the ThreeJs virtual experience (metaverse) engine.


Features:

This source code uses threejs and cannon library, the engine\assets\js\engine.js is written to efficiently handle and manage city scale environment.


System Requirements:

To launch the virtual city you need live server or upload on webhosting server.


Custom Avatar

To add characters, you can use your own Ready Player Me avatar url or create your own custom character, rig character at Mixamo, copy at engine/assets/models/players, and then register the character in the engine/assets/js/avatars.js JSON.

[

{name:'avatarName', height: 1.8, weight: 97, offset: .12},

]

avatar name: name of your avatar in fbx or glb file

avatar height: the avatar model height in meters

avatar weight: the avatar mass in kilograms

avatar offset: adjust the avatar offset from the floor, ensure the avatar feet touches the floor just right not floating and not sinking.  


Custom Environment (City & Objects)

To replace city, you can use your own custom model in fbx or gltf format (texture embedded), copy the models to the engine/assets/models/objects folder and add the model file names in the engine/assets/js/levels.js JSON.

JSON example:

{name: 'modelName', type: 'modelType', loader: 'fileExtension', x: [0, 1], y: [0, 0], z: [0, 1], o:[{x:0,y:0,z:0},{x:0,y:90,z:0}], s:[1, 1], si:0, kg:[5, 5], sl:null, sh:'metalimpact', pc:'.5-1', px:1.2, ds:40},

model name: name of the fbx or glb file

model type: objectmesh, trimesh etc...

file extension: GLTF, GLB or FBX only

model positions: x:[0,1],y:[0,0],z:[0,1

 the model can clone in multiple positions for example x:[0,1] is placed in x axis 0 and x axis 1 or x:[0,1,2,3,4,5] is place in axis 0, 1, ... and 5

model orientation: o:[{x:0,y:0,z:0},{x:0,y:90,z:0}]

model scale: s:[1, .5]

 the model can cloned in different scale for instance a tree model example s:[1, .5] the first tree model clone is full scale (1) and the second tree model clone is half scale (.5)

model mass (kg): kg:[5,5]

 the model can be of different mass in kilo grams for example kg:[0,1] the zero (0) is static and one (1) kilo gram is a kilogram or kg:[10,0,40,30,2] has different masses.

model proximity (meters): ds:40

Screenshot:


Enjoy!

Updated 7 days ago
StatusReleased
PlatformsHTML5
Release date May 23, 2022
Rating
Rated 5.0 out of 5 stars
(1 total ratings)
AuthorVeinSyct
GenreSimulation
Made withSublime Text, 3ds Max, Blender, SketchUp, Adobe Photoshop, Three.js
Tags3D, Experimental, First-Person, FPS, Local multiplayer, Multiplayer, Open World, Singleplayer, Third Person, Walking simulator
Average sessionA few minutes
LanguagesEnglish
InputsMouse, Touchscreen
MultiplayerLocal multiplayer
Player count1 - 16
LinksVirtual Experience

Also available on

Development log