Skip to content
Snippets Groups Projects
LoadFile.js 36.8 KiB
Newer Older
Laura Cappelli's avatar
Laura Cappelli committed
var a = 3.36275; //costante moltiplicativa per la calibrazione
var b = 58.2353; //costante additiva per la calibrazione
var pixelDim; //dimensione dei pixel responsive
var maxAbsolute; //massimo conteggio della matrice nOfCounts
var globalxMinRange = 0, globalxMaxRange = 55;
var xDim = 0, yDim = 0; //numero di pixel nelle due dimensioni
var DataMatrix, nOfCounts; //matrici con i dati
Laura Cappelli's avatar
Laura Cappelli committed
var rePrint = false; //variabile per ricolorare con il max relativo
var newOrigin; //nuovo origine nel caso di zoom
var zPixel1 = { xp: 0, yp: 0 }; //pixel1 dello zoom
var zPixel2 = { xp: 0, yp: 0 }; //pixel2 dello zoom
var dataCompleteChart = "Channel,Counts\n";
var dataCompleteChartCalibrated = "Energy,Counts\n";
var calibrated = false; //variabile per il controllo sulla calibrazione
//INIZIO DELLO SCRIPT
$(document).ready(function () {
    //creazione dell'albero e gestione barre laterali
    setImportFile();
    compressingSidenavSettings();
    compressingSidenavFS();
    //abilitazione drag&drop
    var droppableArea = document.querySelector('.droppable');
    makeDroppable(droppableArea, callback);
});
//funzione che definisce tutti gli elementi responsabili dell'apertura di un file.
//Sono definiti quindi l'albero e il bottone per l'importazione da locale
function setImportFile() {
    //genero e leggo il contenuto della directory "filesystem"
    var jsonResponse;
Laura Cappelli's avatar
Laura Cappelli committed
    var xmlListingFile = new XMLHttpRequest();
    xmlListingFile.open("GET", "https://baltig.infn.it/api/v4/projects/819/repository/tree?recursive=1&path=XRF-File-System", true);
    //xmlListingFile.setRequestHeader('PRIVATE-TOKEN', 'kEzw3Lo1-T7ZaacK1s9z');
Laura Cappelli's avatar
Laura Cappelli committed
    xmlListingFile.onreadystatechange = function () {
        if (xmlListingFile.readyState === 4) {
            if (xmlListingFile.status === 200) {
                jsonResponse = JSON.parse(xmlListingFile.responseText);
Laura Cappelli's avatar
Laura Cappelli committed
            }
        }
    };
    xmlListingFile.send(null);
    generateTree(jsonResponse);
    //ora genero l'albero e definisco l'evento in caso di selezione di un nodo
    /*  $('#FileTreeview').treeview({data: generateTree(jsonResponse)});
      $('#FileTreeview').on('nodeSelected', function(e, node){
        if(node['url'] != undefined){
          //openFileFromServer(node['url']);
        }
      });*/
    //bottone per l'importazione locale
    var fileInputButton = document.getElementById('myImport');
    fileInputButton.onchange = function () {
        var fileName = fileInputButton.files[0];
        var readerObject = new FileReader();
        readerObject.readAsBinaryString(fileName);
        readerObject.onload = function () {
            var fileString = readerObject.result;
            readData(fileString);
        };
    };
//funzione che genera automaticamente l'albero
function generateTree(jsonDoc) {
    var tree = [{
            text: "XRF-File-System",
            nodes: []
        }];
    //scorro ogni elemento dell'albero
    for (var i = 0; i < jsonDoc.length; i++) {
        if (jsonDoc[i].type == "tree") {
            var Folder = {
                text: jsonDoc[i].name,
                nodes: []
            };
            //posiziono la cartella nella posizione coorretta:
            //seleziono nel path della cartella corrente il path della
            //cartella genitore
            var parentPath = jsonDoc[i].path.split("/");
            alert("Path: " + jsonDoc[i].path + " parentPath: " + parentPath.pop());
    ;
    /*
    var tree: any = [];
    var first: boolean = true;
    var oldFolderParent: string = "";
    var oldFolder: string = "";
    
  
    //inizio leggendo tutti gli elementi da inserire nell'albero (caratterizzati
    //dall'avere un url di riferimento)
    var entry: string[] = jsonDoc.getElementsByTagName("d:href");
    
    //per ogni elemento controllo se si tratta di una cartella o di un documento
    for (var i:number = 0; i < entry.length; i++) {
      var path: string[] = entry[i].childNodes[0].nodeValue.split("");
      
      //cartella, creo l'oggetto corrsipondente
      if (path[path.length-1] == "/") {
        var folderName: string[] = entry[i].childNodes[0].nodeValue.split("/");
        var Folder = {
          text: folderName[folderName.length-2],
          nodes: []
        }
  
        //posiziono la radice del file system, ne memorizzo il path e il padre
        if (first) {
          tree.push(Folder);
          first=false;
          oldFolder = entry[i].childNodes[0].nodeValue;
          oldFolderParent =
            oldFolder.slice(0, oldFolder.lastIndexOf(folderName[folderName.length-2]));
          
        //per ogni cartella determino la relazione con la cartella precedente
        } else {
          var newFolder: string = entry[i].childNodes[0].nodeValue;
          var newFolderParent: string =
            newFolder.slice(0, newFolder.lastIndexOf(folderName[folderName.length-2]));
  
          //cartella sorella con quella memorizzata
          if(newFolderParent == oldFolderParent){
            oldFolder = newFolder;
            insertOBJinFS(Folder, tree, folderName, 0);
          //cartella figlia di quella memorizzata
          } else if(newFolderParent == oldFolder){
            oldFolder = newFolder;
            oldFolderParent = newFolderParent;
            insertOBJinFS(Folder, tree, folderName, 0);
          //nessuno dei casi precedenti
          } else {
            //arretro nell'albero fino a trovare lo stesso padre. Per fare questo
            //tolgo al padre memorizzato in precedenza prima "/" poi il nome dell'
            //ultima cartella
            while(newFolderParent != oldFolderParent){
              oldFolderParent = oldFolderParent.slice(0, oldFolderParent.length-1);
              oldFolderParent = oldFolderParent.slice(0, (oldFolderParent.lastIndexOf("/")+1));
            }
            oldFolder = newFolder;
            insertOBJinFS(Folder, tree, folderName, 0);
          }
        }
  
      //documento, creo l'oggetto corrispondente e lo inserisco nell'albero
      } else {
        var fileName: string[] = entry[i].childNodes[0].nodeValue.split("/");
        var filePath: string =
          "https://oc-chnet.cr.cnaf.infn.it:8443"
          + entry[i].childNodes[0].nodeValue;
        var File = {
          text: fileName[fileName.length-1],
          icon: "glyphicon glyphicon-file",
          selectedIcon: "glyphicon glyphicon-file",
          url: filePath
        }
        insertOBJinFS(File, tree, fileName, 1);
      }
    }*/
    //return tree;
Laura Cappelli's avatar
Laura Cappelli committed
}
//funzione che posiziona l'oggetto passato in input nell'albero
function insertOBJinFS(objfs, tree, objfsName, type) {
    //determino la profondità dell'oggetto (se è un file devo aggiungere 1 a causa si "/")
    var depth = objfsName.length;
    if (type)
        depth++;
    //in base alla profondità determino a quale oggetto agganciare quello in input
    var treePosition;
    switch (depth) {
        case 8:
            treePosition = tree;
            break;
        case 9:
            treePosition = tree[tree.length - 1].nodes;
            break;
        case 10:
            treePosition =
                tree[tree.length - 1].nodes[tree[tree.length - 1].nodes.length - 1].nodes;
            treePosition =
                tree[tree.length - 1].nodes[tree[tree.length - 1].nodes.length - 1].nodes[tree[tree.length - 1].nodes[tree[tree.length - 1].nodes.length - 1].nodes.length - 1].nodes;
            treePosition =
                tree[tree.length - 1].nodes[tree[tree.length - 1].nodes.length - 1].nodes[tree[tree.length - 1].nodes[tree[tree.length - 1].nodes.length - 1].nodes.length - 1].nodes[tree[tree.length - 1].nodes[tree[tree.length - 1].nodes.length - 1].nodes[tree[tree.length - 1].nodes[tree[tree.length - 1].nodes.length - 1].nodes.length - 1].nodes.length - 1].nodes;
            break;
        default: break;
    }
    treePosition[treePosition.length - 1].nodes.push(objfs);
}
//funzione che dato l'url di un file, lo apre e lo legge passandone il contenuto
//alla funzione readData(). Questa funzione è invocata quando viene selezionato
//un file dall'albero
function openFileFromServer(url) {
    var fileName = url.split("/");
    console.log("Try to open " + fileName[fileName.length - 1] + " ...");
    var txtFile = new XMLHttpRequest();
    txtFile.open("GET", url, true);
    txtFile.onreadystatechange = function () {
        if (txtFile.readyState === 4) {
            if (txtFile.status === 200) {
Laura Cappelli's avatar
Laura Cappelli committed
                readData((txtFile.responseText));
    txtFile.send(null);
}
//funzione per la compressione della sidenav dx
function compressingSidenavSettings() {
    var setLabel = $('.btn-settings');
    var isClosedSettings = false;
    setLabel.click(function () { setLabel_cross(); });
    function setLabel_cross() {
        if (isClosedSettings == true) {
            isClosedSettings = false;
            $('#mySidenavSet').css('width', "0");
            $('#wrapper').css('marginRight', "0");
            $('#setbtn').css('marginRight', "-2px");
            $('#mySidenavSet').css('width', "250px");
            $('#wrapper').css('marginRight', "250px");
            $('#setbtn').css('marginRight', "248px");
}
//funzione per la compressione della sidenav sx
function compressingSidenavFS() {
    var fsLabel = $('.fs-label');
    var isClosedfs = false;
    fsLabel.click(function () { fsLabel_cross(); });
    function fsLabel_cross() {
        if (isClosedfs == true) {
            isClosedfs = false;
            fsLabel.removeClass('is-open');
            fsLabel.addClass('is-closed');
            $('#mySidenavfs').css('width', "0");
            $('#wrapper').css('marginLeft', "0");
            $('#fsbtn').css('marginLeft', "-2px");
        }
        else {
            isClosedfs = true;
            fsLabel.removeClass('is-closed');
            fsLabel.addClass('is-open');
            $('#mySidenavfs').css('width', "250px");
            $('#wrapper').css('marginLeft', "250px");
            $('#fsbtn').css('marginLeft', "248px");
Laura Cappelli's avatar
Laura Cappelli committed
}
//funzione che definisce l'area su cui si può eseguire il drag&drop
function makeDroppable(droppableArea, callback) {
    //creo l'elemento "input type file" non visibile e lo aggiungo a "droppableArea"
Laura Cappelli's avatar
Laura Cappelli committed
    var input = document.createElement('input');
    input.setAttribute('type', 'file');
    input.setAttribute('multiple', true);
    input.style.display = 'none';
    droppableArea.appendChild(input);
Laura Cappelli's avatar
Laura Cappelli committed
    //questo evento è chiamato quando i file sono trascinati ma non ancora lasciati
    droppableArea.addEventListener('dragover', function (e) {
Laura Cappelli's avatar
Laura Cappelli committed
        e.preventDefault(); //impediamo l'apertura del file
        e.stopPropagation();
        e.dataTransfer.dropEffect = 'copy';
        droppableArea.classList.add('dragover');
Laura Cappelli's avatar
Laura Cappelli committed
    });
    //l'evento è chiamato quando un file lascia la zona predefinita per il drag&drop
    droppableArea.addEventListener('dragleave', function (e) {
Laura Cappelli's avatar
Laura Cappelli committed
        e.preventDefault();
        e.stopPropagation();
        droppableArea.classList.remove('dragover');
Laura Cappelli's avatar
Laura Cappelli committed
    });
    //questo evento si innesca quando il drop è effettivamente avvenuto
    droppableArea.addEventListener('drop', function (e) {
Laura Cappelli's avatar
Laura Cappelli committed
        e.preventDefault();
        e.stopPropagation();
        droppableArea.classList.remove('dragover');
        callback.call(null, e.dataTransfer.files);
Laura Cappelli's avatar
Laura Cappelli committed
    });
}
//funzione chiamata in caso di drag&drop responsabile dell'apertura del file droppato,
//della sua lettura e del passaggio del suo contenuto alla funzione readData()
function callback(files) {
    console.log("Try to open " + files[files.length - 1].name + " ...");
    var readerObject = new FileReader();
    readerObject.readAsBinaryString(files[files.length - 1]);
    readerObject.onload = function () {
        var fileString = readerObject.result;
        readData(fileString);
    };
}
//la funzione prepara i dati per il grafico completo
function setDataForCompleteChart() {
    //per ogni pixel sommo i conteggi di tutti i canali rilevati
    var dataForChart = new Array(16384);
    for (var i = 0; i < 16384; i++) {
        dataForChart[i] = 0;
    for (var i = 0; i < xDim; i++) {
        for (var j = 0; j < yDim; j++) {
            for (var k = 0; k < 16384; k++) {
                dataForChart[k] += DataMatrix[i][j][k];
            }
        }
    }
    //riempio le stringhe con i dati per il grafico
    for (var i = 0; i < 16348; i++) {
        dataCompleteChart += (i + 1) + "," + dataForChart[i] + "\n";
        dataCompleteChartCalibrated += round3(((i + 1) * a - b) / 1000) + "," + dataForChart[i] + "\n";
    }
}
//La funzione riceve in input un vettore di cui somma gli elementi compresi tra 
//gli indici from e to 
function sumVect(vect, from, to) {
    var sum = 0;
    for (var i = from; i < to; i++) {
        sum += vect[i];
    }
    return sum;
}
//La funzione riceve in input la matrice e gli estremi della sottomatrice di cui
//calcola il massimo
function findMax(matrix, pixel1, pixel2) {
    var max = 0;
    for (var i = pixel1.xp; i <= pixel2.xp; i++) {
        for (var j = pixel1.yp; j <= pixel2.yp; j++) {
            if (matrix[i][j] > max) {
                max = matrix[i][j];
            }
        }
    }
    return max;
}
//Funzione per arrotondare il numero in input alla terza cifra decimale
function round3(val) {
    return (Math.round(val * Math.pow(10, 3)) / Math.pow(10, 3));
}
//la funzione findPosition definisce la posizione del cursore del mouse
//relativa al canvas nel momento in cui avviene l'evento passato in input 
function findPosition(event, pixel) {
    var scrollTOP = (document.documentElement.scrollTop) ?
        document.documentElement.scrollTop : document.body.scrollTop;
    var scrollLEFT = (document.documentElement.scrollLeft) ?
        document.documentElement.scrollLeft : document.body.scrollLeft;
    var allX = event.clientX + scrollLEFT;
    var allY = event.clientY + scrollTOP;
    var elParent = document.getElementById('myCanvas');
    var objX = 0, objY = 0;
    while (elParent) {
        objX += elParent.offsetLeft;
        objY += elParent.offsetTop;
        elParent = elParent.offsetParent;
    }
    pixel.xp = Math.floor((allX - objX - 1) / pixelDim) + newOrigin.xp;
    pixel.yp = Math.floor((allY - objY - 1) / pixelDim) + newOrigin.yp;
Laura Cappelli's avatar
Laura Cappelli committed
}
//la funzione findPosDown memorizza la posizione del pixel cliccato
function findPosDown(event) {
    findPosition(event, zPixel1);
}
//la funzione findPosUp memorizza la posizione del pixel quando il mouse viene
//rilasciato, ordina le coordinate, aggiorna l'origine e la pagina.
function findPosUp(event) {
    findPosition(event, zPixel2);
    var tmp;
    if (zPixel1.xp > zPixel2.xp) {
        tmp = zPixel1.xp;
        zPixel1.xp = zPixel2.xp;
        zPixel2.xp = tmp;
    }
    if (zPixel1.yp > zPixel2.yp) {
        tmp = zPixel1.yp;
        zPixel1.yp = zPixel2.yp;
        zPixel2.yp = tmp;
    }
    //se è stato cliccato un punto disegno il grafico, altrimenti disegno anche il
    //canvas e aggiorno l'origine
    if (zPixel1.xp != zPixel2.xp || zPixel1.yp != zPixel2.yp) {
        newOrigin = { xp: zPixel1.xp, yp: zPixel1.yp };
        drawImg(zPixel1, zPixel2, globalxMinRange, globalxMaxRange);
    }
    drawChart(zPixel1, zPixel2, globalxMinRange, globalxMaxRange);
}
// La funzione readData() prende in ingresso il file di input memorizzato nella 
// stringa "fileString". La funzione riempie la matrice "DataMatrix" con i dati
// in modo che essi siano memorizzati in un formato più leggibile. Sono ricavate
// anche altre variabili necessarie per il resto del codice.
Laura Cappelli's avatar
Laura Cappelli committed
function readData(fileString) {
    newOrigin = { xp: 0, yp: 0 }; //origine nel caso di zoom
    var passo = 0; //dimensione di un pixel in micorn
    var readMode; //direzione di lettura
    //coordinate minime e massime in entrambe le dimensioni
    var xMin = 0, yMin = 0, xMax = 0, yMax = 0;
    //array con il contenuto del file di input suddiviso per righe
Laura Cappelli's avatar
Laura Cappelli committed
    var fileStringArray = fileString.split("\n");
    //scorro l'array soffermandomi solo sulle righe "intestazione delle x". Devo
    //determinare ascisse e cordinate minime e massime, il passo e la direzione di
    //scansione
Laura Cappelli's avatar
Laura Cappelli committed
    for (var i = 0; i < fileStringArray.length; i++) {
        if (parseInt(fileStringArray[i]) > 17000 && fileStringArray[i][0] == '5') {
            if (xMin == 0) {
                xMin = parseInt(fileStringArray[i]);
                yMin = parseInt(fileStringArray[i + 1]);
                i++;
            }
            else {
                if (parseInt(fileStringArray[i]) == xMin) {
                    readMode = 'c';
                    passo = Math.abs(yMin - fileStringArray[i + 1]);
                    //se sto leggendo per colonne determino xMax leggendo dalla fine
Laura Cappelli's avatar
Laura Cappelli committed
                    for (var j = fileStringArray.length; j > i; j--) {
                        //se la riga è "intestazione x" memorizzo xMax e lo confronto con xMin
                        if (parseInt(fileStringArray[j]) > 17000 && fileStringArray[j][0] == '5') {
Laura Cappelli's avatar
Laura Cappelli committed
                            xMax = parseInt(fileStringArray[j]);
                            if (xMax < xMin) {
                                var t = xMax;
                                xMax = xMin;
                                xMin = t;
                            }
                            break;
                        }
                    }
                }
                else {
                    readMode = 'r';
                    passo = Math.abs(xMin - fileStringArray[i]);
                    //se sto leggendo per righe determino yMax leggendo dalla fine
Laura Cappelli's avatar
Laura Cappelli committed
                    for (var j = fileStringArray.length; j > i; j--) {
                        //se la riga è "intestazione y" memorizzo yMax e lo confronto con yMin
                        if (parseInt(fileStringArray[j]) > 17000 && fileStringArray[j][0] == '6') {
Laura Cappelli's avatar
Laura Cappelli committed
                            yMax = parseInt(fileStringArray[j]);
                            if (yMax < yMin) {
                                var t = yMax;
                                yMax = yMin;
                                yMin = t;
                            }
                            break;
                        }
                    }
                }
                break;
            }
        }
    } //alert(xMin + " " + xMax + " " + yMin + " " + yMax + " " + passo);
    //A seconda della direzione di lettura determino o yMin e yMax, o xMin e xMax    
Laura Cappelli's avatar
Laura Cappelli committed
    for (var i = 2; i < fileStringArray.length; i++) {
        if (readMode == 'c') {
            //mi soffermo sulle righe "intestazione y"
            if (parseInt(fileStringArray[i]) > 17000 && fileStringArray[i][0] == '6') {
Laura Cappelli's avatar
Laura Cappelli committed
                if (yMin > parseInt(fileStringArray[i])) {
                    yMin = parseInt(fileStringArray[i]);
                }
                if (yMax < parseInt(fileStringArray[i])) {
                    yMax = parseInt(fileStringArray[i]);
                }
            }
            //alla terza colonna posso uscire perché ho già tutte le informazioni
Laura Cappelli's avatar
Laura Cappelli committed
            if (parseInt(fileStringArray[i]) == xMin + (passo * 2)) {
                break;
            }
        }
Laura Cappelli's avatar
Laura Cappelli committed
            //mi soffermo sulle righe "intestazione x"
            if (parseInt(fileStringArray[i]) > 17000 && fileStringArray[i][0] == '5') {
Laura Cappelli's avatar
Laura Cappelli committed
                if (xMin > parseInt(fileStringArray[i])) {
                    xMin = parseInt(fileStringArray[i]);
                }
                if (xMax < parseInt(fileStringArray[i])) {
                    xMax = parseInt(fileStringArray[i]);
                }
            }
            //alla terza colonna posso uscire perché ho già tutte le informazioni
Laura Cappelli's avatar
Laura Cappelli committed
            if (parseInt(fileStringArray[i]) == yMin + 2000) {
                break;
            }
        }
    } //alert(xMin + " " + xMax + " " + yMin + " " + yMax + " " + passo);
    //Risolvo gli shift
Laura Cappelli's avatar
Laura Cappelli committed
    for (var i = 0; i < fileStringArray.length; i++) {
        //se leggo per colonne allora aggiungo 1 alle y di tutte le colonne dispari
Laura Cappelli's avatar
Laura Cappelli committed
        if (readMode == 'c' && parseInt(fileStringArray[i]) > 17000 &&
            fileStringArray[i][0] == '5' && (parseInt(fileStringArray[i]) / 1000) % 2 != 0) {
            fileStringArray[i + 1] = (parseInt(fileStringArray[i + 1]) + passo).toString();
Laura Cappelli's avatar
Laura Cappelli committed
        }
        else if (readMode == 'r' && parseInt(fileStringArray[i]) > 17000 &&
            fileStringArray[i][0] == '5' && (parseInt(fileStringArray[i + 1]) / 1000) % 2 != 0) {
            fileStringArray[i] = (parseInt(fileStringArray[i]) + passo).toString();
Laura Cappelli's avatar
Laura Cappelli committed
        }
    }
    //Definisco le dimensioni della matrice DataMatrix e la inizializzo
Laura Cappelli's avatar
Laura Cappelli committed
    if (readMode == 'c') {
        xDim = (xMax - xMin) / passo + 1;
        yDim = (yMax - yMin) / passo - 2;
    }
    else {
        xDim = (xMax - xMin) / passo - 2;
        yDim = (yMax - yMin) / passo + 1;
    }
    //alert(xDim + " " + yDim);
    DataMatrix = new Array(xDim);
    for (var i = 0; i < xDim; i++) {
        DataMatrix[i] = new Array(yDim);
        for (var j = 0; j < yDim; j++) {
            DataMatrix[i][j] = new Array(16384);
            for (var k = 0; k < 16384; k++) {
                DataMatrix[i][j][k] = 0;
            }
        }
    }
    //riempio la matrice DataMatrix eliminando i bordi
Laura Cappelli's avatar
Laura Cappelli committed
    for (var i = 0; i < fileStringArray.length; i++) {
        var x, y, write;
        //riga "intestazione x": memorizzo le x e le y del punto e avanzo al conteggio
        if (parseInt(fileStringArray[i]) > 17000 && fileStringArray[i][0] == '5') {
Laura Cappelli's avatar
Laura Cappelli committed
            x = (parseInt(fileStringArray[i]) - xMin);
            y = (parseInt(fileStringArray[i + 1]) - yMin);
Laura Cappelli's avatar
Laura Cappelli committed
            if (x != 0) {
                x /= passo;
            }
            if (y != 0) {
                y /= passo;
            }
            i++;
            //non è un pixel del bordo e sto leggendo per colonne: i successivi valori
            //sono da considerare
            if (readMode == 'c' && y != 0 && y != 1 && y != (yMax - yMin) / passo &&
                y != (yMax - yMin) / passo + 1) {
Laura Cappelli's avatar
Laura Cappelli committed
                write = true;
                y -= 2; //aggiorno la y con i bordi tagliati
Laura Cappelli's avatar
Laura Cappelli committed
            }
            else if (readMode == 'r' && x != 0 && x != 1 && x != (xMax - xMin) / passo &&
                x != (xMax - xMin) / passo + 1) {
Laura Cappelli's avatar
Laura Cappelli committed
                write = true;
                x -= 2; //aggiorno la x con i bordi tagliati
Laura Cappelli's avatar
Laura Cappelli committed
            }
            else {
                write = false;
            }
        }
        else if (parseInt(fileStringArray[i]) < 17000 && write == true) {
            //inserisco il conteggio nella matrice (occhio all'orientamento)
Laura Cappelli's avatar
Laura Cappelli committed
            DataMatrix[xDim - x - 1][yDim - y - 1][parseInt(fileStringArray[i])] += 1;
        }
    }
    //calcolo il numero di conteggi per pixel e li salvo nella matrice nOfCounts
    nOfCounts = new Array(xDim);
    for (var i = 0; i < xDim; i++) {
        nOfCounts[i] = new Array(yDim);
        for (var j = 0; j < yDim; j++) {
            nOfCounts[i][j] = sumVect(DataMatrix[i][j], 0, DataMatrix[i][j].length);
        }
    }
    //calcolo il conteggio massimo della matrice
    maxAbsolute = findMax(nOfCounts, { xp: 0, yp: 0 }, { xp: xDim - 1, yp: yDim - 1 });
    //definisco i dati per il grafico completo
Laura Cappelli's avatar
Laura Cappelli committed
    setDataForCompleteChart();
    console.log("File open with succes");
Laura Cappelli's avatar
Laura Cappelli committed
    drawImg({ xp: 0, yp: 0 }, { xp: xDim - 1, yp: yDim - 1 }, 0, 55);
    drawChart({ xp: 0, yp: 0 }, { xp: xDim - 1, yp: yDim - 1 }, 0, 55);
}
//la funzione drawImg disegna il canvas con l'immagine desiderata ed è responsabile
//della gestione di tutti gli eventi ad essa associati
Laura Cappelli's avatar
Laura Cappelli committed
function drawImg(pixel1, pixel2, xMinRange, xMaxRange) {
    //dimensioni pixel
Laura Cappelli's avatar
Laura Cappelli committed
    var nPixelX = pixel2.xp - pixel1.xp + 1;
    var nPixelY = pixel2.yp - pixel1.yp + 1;
    var mappaPannelDim = document.querySelector('#mappa-pannel').getBoundingClientRect();
    var mappaWidth = mappaPannelDim.right - mappaPannelDim.left - 20;
    var mappaHeigth = mappaPannelDim.bottom - mappaPannelDim.top - 50;
    var dimPixelx = Math.floor(mappaWidth / nPixelX);
    var dimPixely = Math.floor(mappaHeigth / nPixelY);
Laura Cappelli's avatar
Laura Cappelli committed
    pixelDim = (dimPixelx < dimPixely) ? dimPixelx : dimPixely;
    document.getElementById("myCanvas").height = nPixelY * pixelDim;
    document.getElementById("myCanvas").width = nPixelX * pixelDim;
    var ctx = document.getElementById('myCanvas').getContext('2d'); //contesto del canvas
Laura Cappelli's avatar
Laura Cappelli committed
    if (xMaxRange - xMinRange >= 55) {
        var max; //massimo relativo o assoluto
Laura Cappelli's avatar
Laura Cappelli committed
        if (rePrint)
            max = findMax(nOfCounts, pixel1, pixel2);
        else
            max = maxAbsolute;
        max = (max * document.getElementById("SaturationSlider").value) / 100; //saturazione
        drawCanvas(nOfCounts, max); //disegno
Laura Cappelli's avatar
Laura Cappelli committed
    }
    else {
        var xMinRangeCh = Math.floor((((xMinRange * 1000) + b) / a) - 1); //16
        var xMaxRangeCh = Math.floor((((xMaxRange * 1000) + b) / a) - 1); //16371
        //calcolo il numero di conteggi solo dei canali selezionati
Laura Cappelli's avatar
Laura Cappelli committed
        var nOfCountsRelative;
        nOfCountsRelative = new Array(xDim);
        for (var i = 0; i < xDim; i++) {
            nOfCountsRelative[i] = new Array(yDim);
            for (var j = 0; j < yDim; j++) {
                nOfCountsRelative[i][j] = sumVect(DataMatrix[i][j], xMinRangeCh, xMaxRangeCh);
Laura Cappelli's avatar
Laura Cappelli committed
            }
        }
        //calcolo il massimo
        var max;
        if (rePrint) {
Laura Cappelli's avatar
Laura Cappelli committed
            max = findMax(nOfCountsRelative, pixel1, pixel2);
Laura Cappelli's avatar
Laura Cappelli committed
            max = findMax(nOfCountsRelative, { xp: 0, yp: 0 }, { xp: xDim - 1, yp: yDim - 1 });
        }
        max = (max * document.getElementById("SaturationSlider").value) / 100; //saturazione
        drawCanvas(nOfCountsRelative, max); //disegno
Laura Cappelli's avatar
Laura Cappelli committed
    }
    //La funzione, ricevuti dati e massimo, disegna la mappa nel canvas
Laura Cappelli's avatar
Laura Cappelli committed
    function drawCanvas(noc, max) {
        //controllo il valore della trasparenza
        var setTrsp = 1 - document.getElementById("TrasparencySlider").value / 100;
        //scorro tutti i pixel: ne determino il colore e li disegno      
Laura Cappelli's avatar
Laura Cappelli committed
        var color = "";
        for (var i = pixel1.xp; i <= pixel2.xp; i++) {
            for (var j = pixel1.yp; j <= pixel2.yp; j++) {
                var intensity = noc[i][j] / max;
                if (intensity < 1 / 5)
                    color = "rgba(0, 0, " + Math.floor(intensity * 5 * 255) + "," + setTrsp + ")";
Laura Cappelli's avatar
Laura Cappelli committed
                else if (1 / 5 <= intensity && intensity < 2 / 5)
                    color = "rgba(0, " + Math.floor((intensity - 1 / 5) * 5 * 255) + ",255, " + setTrsp + ")";
Laura Cappelli's avatar
Laura Cappelli committed
                else if (2 / 5 <= intensity && intensity < 3 / 5)
                    color = "rgba(0, 255, " + (255 - Math.floor((intensity - 2 / 5) * 5 * 255)) + ", " + setTrsp + ")";
Laura Cappelli's avatar
Laura Cappelli committed
                else if (3 / 5 <= intensity && intensity < 4 / 5)
                    color = "rgba(" + Math.floor((intensity - 3 / 5) * 5 * 255) + ",255,0," + setTrsp + ")";
Laura Cappelli's avatar
Laura Cappelli committed
                else
                    color = "rgba(255," + (255 - Math.floor((intensity - 4 / 5) * 5 * 255)) + ", 0, " + setTrsp + ")";
Laura Cappelli's avatar
Laura Cappelli committed
                ctx.fillStyle = color;
                ctx.fillRect((i - pixel1.xp) * pixelDim, (j - pixel1.yp) * pixelDim, pixelDim, pixelDim);
            }
        }
        rePrint = false; //annullo rePrint
Laura Cappelli's avatar
Laura Cappelli committed
    }
    $("#SaturationSlider").mouseup(function () {
Laura Cappelli's avatar
Laura Cappelli committed
        drawImg(pixel1, pixel2, xMinRange, xMaxRange);
    });
    $("#rePlot").click(function () {
Laura Cappelli's avatar
Laura Cappelli committed
        rePrint = true;
        document.getElementById("SaturationSlider").value = "100";
Laura Cappelli's avatar
Laura Cappelli committed
        drawImg(pixel1, pixel2, xMinRange, xMaxRange);
    });
    $("#TrasparencySlider").mouseup(function () {
Laura Cappelli's avatar
Laura Cappelli committed
        drawImg(pixel1, pixel2, xMinRange, xMaxRange);
    });
    $("#reset").click(function () {
Laura Cappelli's avatar
Laura Cappelli committed
        newOrigin = { xp: 0, yp: 0 };
        rePrint = false;
        calibrated = false;
        globalxMinRange = 0;
        globalxMaxRange = 55;
        document.getElementById("SaturationSlider").value = "100";
        document.getElementById("TrasparencySlider").value = "0";
Laura Cappelli's avatar
Laura Cappelli committed
        document.getElementById("spinBoxMin").setAttribute("value", "-");
        document.getElementById("spinBoxMax").setAttribute("value", "-");
        drawImg({ xp: 0, yp: 0 }, { xp: xDim - 1, yp: yDim - 1 }, 0, 55);
        drawChart({ xp: 0, yp: 0 }, { xp: xDim - 1, yp: yDim - 1 }, 0, 55);
    });
    $("#ExportImage").click(function () {
        var img = document.getElementById("myCanvas").toDataURL("image/png");
        $("#ExportImage").attr("href", img);
Laura Cappelli's avatar
Laura Cappelli committed
        //document.write('<img src="'+img+'"/>');
Laura Cappelli's avatar
Laura Cappelli committed
}
//la funzione drawChart (input: estremi dell'immagine, estremi dell'intervallo)
//disegna il grafico richiesto relativo alla mappa visualizzata
Laura Cappelli's avatar
Laura Cappelli committed
function drawChart(pixel1, pixel2, xMinRange, xMaxRange) {
    //definisco la variabile "grafico", i bottoni relativi al grafico, il tag
    //select e le due spinbox con il relativo botton
    var g;
    var box1 = document.getElementById("spinBoxMin");
    var box2 = document.getElementById("spinBoxMax");
    //disegno il grafico completo
    if (pixel1.xp == 0 && pixel1.yp == 0 && pixel2.xp == xDim - 1 && pixel2.yp == yDim - 1) {
Laura Cappelli's avatar
Laura Cappelli committed
        if (!calibrated) {
            var chartTitle = "Chart from (0, 0) to (" + (xDim - 1) + ", " + (yDim - 1) + ")";
Laura Cappelli's avatar
Laura Cappelli committed
            g = setChart(dataCompleteChart, chartTitle);
        }
        else {
            var chartTitle = "Calibrated chart from (0, 0) to (" + (xDim - 1) + ", " + (yDim - 1) + ")";
Laura Cappelli's avatar
Laura Cappelli committed
            g = setChart(dataCompleteChartCalibrated, chartTitle);
        }
    }
    else {
        //determino i conteggi dei pixel da disegnare
Laura Cappelli's avatar
Laura Cappelli committed
        var dataForChart = new Array(16384);
        for (var i = 0; i < 16384; i++) {
            dataForChart[i] = 0;
        }
        for (var i = pixel1.xp; i <= pixel2.xp; i++) {
            for (var j = pixel1.yp; j <= pixel2.yp; j++) {
                for (var k = 0; k < 16384; k++) {
                    dataForChart[k] += DataMatrix[i][j][k];
                }
            }
        }
        if (!calibrated) {
            var dataChart = "Channel,Counts\n";
            for (var i = 0; i < 16348; i++) {
                dataChart += i + "," + dataForChart[i] + "\n";
            }
            if (pixel1.xp == pixel2.xp && pixel1.yp == pixel2.yp) {
                var chartTitle = "Chart pixel (" + pixel1.xp + ", " + (yDim - pixel1.yp - 1) + ")";
Laura Cappelli's avatar
Laura Cappelli committed
            }
            else {
                var chartTitle = "Chart from (" + pixel1.xp + "," + pixel2.xp + ") to (" +
                    (yDim - pixel1.yp - 1) + ", " + (yDim - pixel2.yp - 1) + ")";
Laura Cappelli's avatar
Laura Cappelli committed
            }
            g = setChart(dataChart, chartTitle);
        }
        else {
            var dataChartCalibrated = "Energy,Counts\n";
            for (var i = 0; i < 16348; i++) {
                dataChartCalibrated += round3(((i + 1) * a - b) / 1000) + "," + dataForChart[i] + "\n";
Laura Cappelli's avatar
Laura Cappelli committed
            }
            if (pixel1.xp == pixel2.xp && pixel1.yp == pixel2.yp) {
                var chartTitle = "Calibrated chart pixel (" + pixel1.xp + ", " + (yDim - pixel1.yp - 1) + ")";
Laura Cappelli's avatar
Laura Cappelli committed
            }
            else {
                var chartTitle = "Calibrated chart from (" + pixel1.xp + ", " + pixel2.xp +
                    ") to (" + (yDim - pixel1.yp - 1) + ", " + (yDim - pixel2.yp - 1) + ")";
Laura Cappelli's avatar
Laura Cappelli committed
            }
            g = setChart(dataChartCalibrated, chartTitle);
        }
    }
    $('#setlinearButton').on('click', function () {
Laura Cappelli's avatar
Laura Cappelli committed
        g.updateOptions({ logscale: false });
    });
    $('#setlogButton').on('click', function () {
Laura Cappelli's avatar
Laura Cappelli committed
        g.updateOptions({ logscale: true });
    });
    $('#setEnergyButton').on('click', function () {
Laura Cappelli's avatar
Laura Cappelli committed
        calibrated = true;
        drawChart(pixel1, pixel2, 0, 55);
        box1.setAttribute("value", "0");
        box2.setAttribute("value", "55");
    });
    $('#setChannelsButton').on('click', function () {
Laura Cappelli's avatar
Laura Cappelli committed
        calibrated = false;
        drawChart(pixel1, pixel2, 0, 55);
        box1.setAttribute("value", "-");
        box2.setAttribute("value", "-");
    });
    $('#ExportGraph').on('click', function () {
Laura Cappelli's avatar
Laura Cappelli committed
        var img = document.getElementById("chartToImg");
        Dygraph.Export.asPNG(g, img);
        document.getElementById("ExportGraph").href = img.src.replace('image/png', 'image/octet-stream');
    });
    $('#readSpinbox').on('click', function () {
Laura Cappelli's avatar
Laura Cappelli committed
        peackSelection(0, 0);
    });
    $('#chart').on('click', function () {
Laura Cappelli's avatar
Laura Cappelli committed
        var r;
        r = g.xAxisRange();
        if (!calibrated) {
            r[0] = Math.floor((((r[0] + 1) * a) - b) / 1000);
            r[1] = Math.floor((((r[1] + 1) * a) - b) / 1000);
        }
        else {
            r[0] = round3(r[0]);
            r[1] = round3(r[1]);
            box1.setAttribute("value", r[0].toString());
            box2.setAttribute("value", r[1].toString());
        }
        globalxMinRange = r[0];
        globalxMaxRange = r[1];
        drawImg(pixel1, pixel2, r[0], r[1]);
    });
    $('#elementSelect').on('change', function () {
Laura Cappelli's avatar
Laura Cappelli committed
        var element = document.getElementById("elementSelect").value;
        switch (element) {
            case "1":
                peackSelection(3.6, 3.8);
                box1.setAttribute("value", "3.60");
                box2.setAttribute("value", "3.80");
                break;
            case "2":
                peackSelection(10.4, 10.7);
                box1.setAttribute("value", "10.40");
                box2.setAttribute("value", "10.70");
                break;
            case "3":
                peackSelection(9.8, 10.15);
                box1.setAttribute("value", "9.80");
                box2.setAttribute("value", "10.15");
                break;
            case "4":
                peackSelection(6.3, 6.5);
                box1.setAttribute("value", "6.30");
                box2.setAttribute("value", "6.50");
                break;
            case "5":
                peackSelection(7.85, 8.2);
                box1.setAttribute("value", "7.85");
                box2.setAttribute("value", "8.20");
                break;
            case "6":
                peackSelection(8.5, 8.72);
                box1.setAttribute("value", "8.50");
                box2.setAttribute("value", "8.72");
                break;
            case "7":
                peackSelection(4.35, 4.65);
                box1.setAttribute("value", "4.35");
                box2.setAttribute("value", "4.65");
                break;
            case "8":
                peackSelection(3.2, 3.42);
                box1.setAttribute("value", "3.20");
                box2.setAttribute("value", "3.42");
                break;
            case "9":
                peackSelection(6.8, 7.05);
                box1.setAttribute("value", "6.80");
                box2.setAttribute("value", "7.05");
                break;
            default:
                peackSelection(0, 55);
                box1.setAttribute("value", "0");
                box2.setAttribute("value", "55");
                break;
        }
    });
    //la funzione setChart riceve in input i dati e il titolo del grafico da disegnare
    //il quale è restituito il output
    function setChart(dataString, charTitle) {
        var xArrayRange; //estremi asse x da visualizzare
        var xLab;
        if (!calibrated) {
            xArrayRange = [0, 16383];
            xLab = "ADC Channel";
Laura Cappelli's avatar
Laura Cappelli committed
        }
        else {
            xArrayRange = [xMinRange, xMaxRange];
            xLab = "Energy (keV)";
Laura Cappelli's avatar
Laura Cappelli committed
        }
        //dimensioni grafico
        var chartDim = document.querySelector('#chart-pannel').getBoundingClientRect();
        var chartWidth = chartDim.right - chartDim.left - 50;
        $('#chart').css('width', chartWidth);
        var chartHeight = chartDim.bottom - chartDim.top - 100;
        $('#chart').css('height', chartHeight);
        //disegno il grafico
        var graphs = new Dygraph(document.getElementById("chart"), dataString, {
            title: charTitle,
            ylabel: 'Counts',
            xlabel: xLab,
            //legend: 'always',
            labelsDivStyles: { 'textAlign': 'right' },
            dateWindow: xArrayRange,
            showRangeSelector: true,
            logscale: false
        });
        //dimensioni responsive alle sideNav
        $('#fsbtn').on('click', function () {
            setTimeout(function () {
                g = setChart(dataString, charTitle);
                drawImg(pixel1, pixel2, xMinRange, xMaxRange);
            }, 400);
        });
        $('#setbtn').on('click', function () {
            setTimeout(function () {
                g = setChart(dataString, charTitle);
                drawImg(pixel1, pixel2, xMinRange, xMaxRange);
            }, 400);
        });
        return graphs;
Laura Cappelli's avatar
Laura Cappelli committed
    }
    //la funzione, dati gli estremi dell'intervallo da rappresentare, aggiorna mappa e grafico
    function peackSelection(xMinRange, xMaxRange) {
        //se l'intervallo è [0, 0] devo leggere dalle i valori dalle spinbox
        if (xMinRange == 0 && xMaxRange == 0) {
            xMinRange = box1.value;
            xMaxRange = box2.value;
        }
        globalxMinRange = xMinRange;
        globalxMaxRange = xMaxRange;
        newOrigin = { xp: 0, yp: 0 };
        rePrint = false;
        calibrated = true;
        drawImg({ xp: 0, yp: 0 }, { xp: xDim - 1, yp: yDim - 1 }, globalxMinRange, globalxMaxRange);
        drawChart({ xp: 0, yp: 0 }, { xp: xDim - 1, yp: yDim - 1 }, globalxMinRange, globalxMaxRange);
Laura Cappelli's avatar
Laura Cappelli committed
    }
}