Тройка и трассировка пути или Raymarching
Привет всем, я хочу сделать страницу, которая использует ThreeJS и метод рендеринга трассировки пути. Threejs не имеет движка рендеринга с отслеживанием пути. Так что мне нужно его реализовать. Я пытался реализовать метод madebyevan.com/webgl-path-tracing/, но какой метод рендеринга threejs я должен использовать? и какие у тебя предложения?
Я обнаружил, что страница использует этот метод;
function main(nworker, iterationsPerMessage, width, height){
if(typeof(Worker) == 'undefined') {
alert('Your browser does not support web worker!');
return;
}
var canvas = document.createElement('canvas');
canvas.width = width;
canvas.height = height;
var ctx = canvas.getContext('2d');
document.body.appendChild(canvas);
var image = ctx.getImageData(0, 0, width, height);
var buffer = [];
var iterations = 0;
var start = new Date();
for(var i = 0; i < width*height*3; i++) {
buffer.push(0.0);
}
var workers = [];
for(i = 0; i < nworker;i++){
var worker = new Worker('worker.js');
worker.onmessage = function(message) {
iterations += iterationsPerMessage;
var td = new Date()-start;
document.title = iterations + ' i - ' + Math.round(iterations*100000/td)/100 + ' i/s';
var data = message.data;
if(typeof(data) == 'string') {
data = JSON.parse(data);
}
for(var j = 0; j < data.length; j++) {
buffer[j] += data[j];
}
for(var k=0,j=0;k < width*height*4;) {
image.data[k++] = buffer[j++]*255/iterations;
image.data[k++] = buffer[j++]*255/iterations;
image.data[k++] = buffer[j++]*255/iterations;
image.data[k++] = 255;
}
ctx.putImageData(image, 0, 0);
}
worker.postMessage([width, height, iterationsPerMessage]);
}
}