data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
data:image/s3,"s3://crabby-images/ff615/ff615d9c2671260a4ea6286c74bf6f204d1c8b0f" alt=""
Client: BEGOC
Agency: UBGM (URBIS)
Developer: POSSIBLE
Producer: Charles-Henry Contamine
Creative Director: Steven Delcourt
Project Leads: Nazim Aliyev and Kanan Gafarov
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
What?
"The 2015 European Games, also known as Baku 2015 or Baku 2015 European Games"
Provide a platform for the flame country-wide tour throughout Azerbaijan visiting 59 cities.
Running for a month, leaving a flame in each city it visits.
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
How?
Sitecore
UID skeleton (BUD Possible)
1 account
1 GFX
1 BE lead, 3 BE
1 UID lead, 3 UID
(BE/UID/GFX HEADOF)
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
How?
Wireframes, webpage designs - Invision
JIRA
Scrum (Weekly Sprints + Daily standups)
GIT - JIRA based tickets
integration branch - testing
master - final branches
master -> deploy
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Tools?
Threejs
TweenMax
Handlebars
Middleman
Grunt
SCSS,
etc..
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Before design
Code site / Make 3D terrain without design / 3d rendered scenes
-> create/setup UID skeleton
-> create dummy html / css styles
-> social logins (fb, instagram)
-> prototyping 3d terrain / globe
-> shot screens from prototype to designs
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
3x
Desktop/Tablet
Full 3d experience
Fallback with google maps. (funnystory.)
Mobile
google maps
User agent detection - BE side
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Basic threejs setup
scene = new THREE.Scene();
renderer = new THREE.WebGLRenderer({antialias: true, clearColor: 0x000000});
renderer.setSize( window.innerWidth, window.innerHeight );
camera = new THREE.PerspectiveCamera(90, 640 / 480, 1, 10000);
document.body.appendChild( renderer.domElement );
//add Lights!
initLights();
//add 3d objects.
init3DThings();
function render() {
renderer.render(scene, camera);
requestAnimationFrame(render);
}
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Terrain
data:image/s3,"s3://crabby-images/d4fe5/d4fe53e32678092da5b0bb44c43d874d4454aead" alt=""
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Terrain datasource
get elevation data by brightness
data:image/s3,"s3://crabby-images/c5a51/c5a51d3769431f6ff29497a664833946218674ae" alt=""
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Terrain image
data:image/s3,"s3://crabby-images/e2e27/e2e27a350e46f057d040a7cf1f17c08137d9a1df" alt=""
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Terrain size
data:image/s3,"s3://crabby-images/301d0/301d0637efeda8bdf0e6f47544cda8e29960d800" alt=""
Elevation data
function calculateElevationArray(data) {
...
pixels = ctx.getImageData(0, 0, imgW, imgH).data;
for (var x = 0; x < imgW; x++) {
for (var y = 0; y < imgH; y++) {
r = pixels[index];
g = pixels[index + 1];
b = pixels[index + 2];
a = pixels[index + 3];
index = (x * 4) + y * (4 * imgW);
sum = r + g + b;
if (sum > 43) {
elevationArray[x].push({
x: x - imgW / 2,
y: y - imgH / 2,
scale: sum,
active: true
});
} else {
... active: false
}
}
...
}
Terrain
data:image/s3,"s3://crabby-images/d4fe5/d4fe53e32678092da5b0bb44c43d874d4454aead" alt=""
Terrain wireframe
data:image/s3,"s3://crabby-images/bc505/bc505bb5040d25c08a6c3d979f8660a57add5131" alt=""
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Terrain (lines)
data:image/s3,"s3://crabby-images/82cc7/82cc70826ba05673cc445b957a0a1acd00883be4" alt=""
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Terrain (lines2)
data:image/s3,"s3://crabby-images/d2424/d24240391a1641f0da0324023530ed4bdd1d8dd4" alt=""
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Terrain (lines2)
data:image/s3,"s3://crabby-images/c8fe7/c8fe71886938ee5de16978ab1fd861dad466fc95" alt=""
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Terrain (particles)
data:image/s3,"s3://crabby-images/91460/9146095006b3c6d29f98e619bd88879e7bb38666" alt=""
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Terrain (particles)
data:image/s3,"s3://crabby-images/82f4a/82f4a6a5427ee8de8b97b3cc7c84f072ddfc77b6" alt=""
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Terrain ~ final
data:image/s3,"s3://crabby-images/c7748/c7748b8956a92b087a12a1bd142c771150d69522" alt=""
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Border
get border data from svg path
data:image/s3,"s3://crabby-images/75ff2/75ff240571e66d7488424e70898b6d5972edf67a" alt=""
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Border
var path = this, //svg path
length = path.getTotalLength(),
p = path.getPointAtLength(0),
diff = length / res,
size = 1.66;
for (var i = 1; i < res; i++) {
p = path.getPointAtLength(i * diff);
vertex.push(new THREE.Vector3(p.x * size, 0, p.y * size));
}
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Border
closedSpline = new THREE.ClosedSplineCurve3(vertex);
extrudeSettings = {
extrudePath: closedSpline
};
shape = new THREE.Shape(pts);
geometry = new THREE.ExtrudeGeometry(shape, extrudeSettings);
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Border
data:image/s3,"s3://crabby-images/9a6f4/9a6f4d0da83f505751d88803de5711e6dc9b84e4" alt=""
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Bonus, real 3d
data:image/s3,"s3://crabby-images/e391a/e391ac59042349cd9d01197fcd92a613555d3e2c" alt=""
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Bonus, real 3d, oculus
data:image/s3,"s3://crabby-images/39315/39315f19923bd27b96b6216c75600a1d8409cbbc" alt=""
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Bonus, real 3d, oculus
data:image/s3,"s3://crabby-images/7c8c4/7c8c4bd2cffd121b3dd086aa3c168dfc2487c71c" alt=""
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Optimization
Render only if necessary!
function setRenderTimeout(timeout, callFrom) {
needRender = true;
clearTimeout(renderTimer);
if (timeout > 0) {
renderTimer = setTimeout(function () {
needRender = false;
}, timeout);
}
}
function render() {
if (needRender) {
renderer.render(scene, camera);
}
requestAnimationFrame(render);
}
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Optimization
Don't use/call on every frame!!!
mesh.geometry.verticesNeedUpdate = true
mesh.computeFaceNormals()
mesh.material.needsUpdate = true
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Optimization
Use shaders:)
//FIRE
var vShader = $('#vertexshader2'),
fShader = $('#fragmentshader2');
uniforms = {
iGlobalTime: {type: 'f', value: 0.1}
};
shaderMaterial = new THREE.ShaderMaterial({
uniforms: uniforms,
vertexShader: vShader.text(),
fragmentShader: fShader.text()
});
mesh = new THREE.Mesh(new THREE.PlaneGeometry(50, 150, 1, 1), shaderMaterial);
scene.add(mesh);
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Best comment
data:image/s3,"s3://crabby-images/71662/7166238a8d3e92df23d8f0ccbf84a88363ce11a2" alt=""
data:image/s3,"s3://crabby-images/549ed/549ede6ded556290ce4efa3695d6b88751f9db13" alt=""
Thank you!
jozsef.szabadszallasi@possible.com
baku2015flame
By Szabadszállási József
baku2015flame
- 1,111