WebGL 2D Rendering with PixiJS
data:image/s3,"s3://crabby-images/33798/337988a8402fa093de8dda9f69ef53ff375dc901" alt=""
Ego Slide
data:image/s3,"s3://crabby-images/b580c/b580c1d2fd541c950f1ad0d4dc6ad96fcfe4cf88" alt=""
f.strazzullo@extrategy.net
@TheStrazz86
https://github.com/francesco-strazzullo
https://medium.com/@TheStrazz86
data:image/s3,"s3://crabby-images/99ce6/99ce6bdf0c70d93cf13a0f630d8c397ea7322016" alt=""
https://slides.com/francescostrazzullo
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
https://taskomat.tech/it/
data:image/s3,"s3://crabby-images/5ea54/5ea54d813b2146bcd8599a998d226f91ecd81325" alt=""
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
data:image/s3,"s3://crabby-images/41da0/41da0a26f1711b2d76f55264d290d8f0f495e555" alt=""
http://codingjam.it/
( we have slack! )
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
data:image/s3,"s3://crabby-images/916e3/916e30567bbc0fcf946ca17556ce7d24d95d0b65" alt=""
WebGL
data:image/s3,"s3://crabby-images/99ce6/99ce6bdf0c70d93cf13a0f630d8c397ea7322016" alt=""
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
data:image/s3,"s3://crabby-images/388fd/388fd7dfdffd465075546782233e3d6b63732f31" alt=""
Really Fast Rendering
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
WebGL (Web Graphics Library) is a JavaScript API for rendering 3D graphics within any compatible web browser without the use of plug-ins
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
Wikipedia
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
data:image/s3,"s3://crabby-images/e3bde/e3bde1013f57969f3a622f9ac72b721a4e38b188" alt=""
With WebGL you can build very cool applications...
data:image/s3,"s3://crabby-images/99ce6/99ce6bdf0c70d93cf13a0f630d8c397ea7322016" alt=""
So why does no one use this API?
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
function buffer(node) {
var minNodeX = node.minX;
var minNodeY = node.minY;
var minNodeZ = node.minZ;
var nodeSize = node.blockSize;
var array = node.buffer;
// Get mins and maxes in node space.
var min2_x = Math.max(min_x - minNodeX, 0);
var max2_x = Math.min(max_x - minNodeX, nodeSize);
var min2_y = Math.max(min_y - minNodeY, 0);
var max2_y = Math.min(max_y - minNodeY, nodeSize);
var min2_z = Math.max(min_z - minNodeZ, 0);
var max2_z = Math.min(max_z - minNodeZ, nodeSize);
for (var z = min2_z; z < max2_z; ++z) {
var z_offset = nodeSize * nodeSize * z;
var fz = minNodeZ + z - ballz;
var fz2 = fz * fz;
for (var y = min2_y; y < max2_y; ++y) {
var y_offset = z_offset + nodeSize * y;
var fy = minNodeY + y - bally;
var fy2 = fy * fy;
for (var x = min2_x; x < max2_x; ++x) {
var fx = minNodeX + x - ballx;
var fx2 = fx * fx;
var dist = Math.sqrt(fx2 + fy2 + fz2);
var val = Math.pow(dist / radius, 2.0);
array[y_offset + x] *= Math.max(Math.min(val, 1.0), 0.0);
}
}
}
if (min2_x < max2_x && min2_y < max2_y && min2_z < max2_z) {
node.dirty = true;
}
}
tree.walkSubTree(min_x, max_x, min_y, max_y, min_z, max_z, uniform, buffer);
//tree.walkTree(uniform, buffer);
}
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
data:image/s3,"s3://crabby-images/c3e0f/c3e0f353daddab0077538dfe1e685fda8d4c07c3" alt=""
Complicated
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
2D Content
data:image/s3,"s3://crabby-images/99ce6/99ce6bdf0c70d93cf13a0f630d8c397ea7322016" alt=""
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
data:image/s3,"s3://crabby-images/388fd/388fd7dfdffd465075546782233e3d6b63732f31" alt=""
Web Applications
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
data:image/s3,"s3://crabby-images/37ec4/37ec484996a1778bd1cf61c09c73bf44154dbaf6" alt=""
Challenges
data:image/s3,"s3://crabby-images/99ce6/99ce6bdf0c70d93cf13a0f630d8c397ea7322016" alt=""
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
data:image/s3,"s3://crabby-images/02844/0284429e3b60fc84d69a8073e9155203281e6967" alt=""
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
data:image/s3,"s3://crabby-images/28654/2865402ae7ec9d888af93a3867b0ee422472e032" alt=""
What's next?
data:image/s3,"s3://crabby-images/99ce6/99ce6bdf0c70d93cf13a0f630d8c397ea7322016" alt=""
Cordova Integration
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
UI Kit
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
That's It!
data:image/s3,"s3://crabby-images/99ce6/99ce6bdf0c70d93cf13a0f630d8c397ea7322016" alt=""
Thanks!
data:image/s3,"s3://crabby-images/ec2ae/ec2aee920ba996db5cc781f2029f46fdc3cc099b" alt=""
data:image/s3,"s3://crabby-images/33798/337988a8402fa093de8dda9f69ef53ff375dc901" alt=""