La libreria itaCharts è una libreria wrapper per ChartJS che permette di creare diversi tipi di grafico.
Concettualmente la libreria è divisa in 3 classi principali:
Oltre a queste tre classi è presente una quarta classe di supporto su cui non dovrebbe mai essere necessario intervenire:
Per usare la libreria è sufficiente fare l'include della classe base, quindi:
require_once ITA_LIB_PATH . '/itaCharts/itaCharts.class.php';
La classe rappresenta un grafico nel suo insieme ed è formata dai seguenti metodi:
Il costruttore della classe prende in input un parametro:
Il metodo permette di impostare le etichette che poi andranno sull'asse delle ascisse (per i grafici cartesiani). Questo metodo prende i seguenti parametri:
NB: Il grafico dovrà avere tanti label quanti sono gli elementi presenti nei singoli dataset (tutti i dataset devono avere lo stesso numero di elementui).
Il metodo permette di aggiungere al grafico un dataset. Questo metodo prende i seguenti parametri:
Il metodo permette di resettare tutti i dati del grafico, annullando label e dataset.
Il metodo permette di definire quale tipo di grafico si va a creare. Questo metodo prende i seguenti parametri:
Permette di impostare le opzioni del grafico. Questo metodo prende i seguenti parametri:
Permette di impostare parametri addizionali liberi. Questo metodo prende il seguente parametro:
Permette di aggiungere del codice al termine della creazione del chart, in modo da poter applicare plugin o fare altre operazioni avanzate. Questo metodo prende il seguente parametro:
—-
La classe rappresenta un dataset del grafico ed include oltre ai dati in quanto tale anche le opzioni relative al dataset. La classe è formata dai seguenti metodi:
Al momento dell'inizializzazione dell'oggetto verranno valorizzati dei parametri di base per le opzioni del dataset.
Il metodo permette di impostare il nome del dataset. Questo metodo prende i seguenti parametri:
Il metodo permette di impostare il colore di riempimento dei dati del dataset. Questo metodo prende i seguenti parametri:
Metodo identico a setBackgroundColor(), setta il colore nel caso di mouse hover.
Il metodo permette di impostare il colore delle linee esterne del dataset. Ricalca esattamente la stessa logica di funzionamento del metodo setBackgroundColor.
N.B: Se solo uno dei due metodi fra setBorderColor e setBackgroundColor viene richiamato il valore dell'altro viene assegnato automaticamente. Nel dettaglio i colori vengono ripresi dall'elemento che è stato settato mentre la trasparenza viene fissata a 0.8 per il bordo e 0.5 per il colore di riempimento.
Metodo identico a setBorderColor(), setta il colore del bordo in caso di mouse hover
Il metodo permette di impostare la larghezza del bordo del dataset. Questo metodo prende i seguenti parametri:
Metodo identico a setBorderWidth(), setta la larghezza del bordo in caso di mouse hover
Il metodo permette di definire se l'area sottesa ad una curva nei grafici a linee viene colorata o meno. Questo metodo prende i seguenti parametri:
Il metodo permette di caricare i dati veri e propri. Questo metodo prende i seguenti parametri:
Il metodo permette di settare che tipo di intepolazione usare nei grafici a linea. Questo metodo prende i seguenti parametri:
Il metodo non dovrebbe venir richiamato direttamente dall'utente, restituisce una rappresentazione json del dataset e delle sue opzioni che verrà poi usata da ChartJS.
La classe rappresenta le opzioni del grafico. Ogni grafico può avere un solo oggetto itaChartsOptions abbinato, questo è facoltativo e nel caso non venisse passato verranno prese le opzioni di default. L'oggetto è formato dai seguenti metodi:
Per l'oggetto al momento della creazione vengono valorizzate tutte le opzioni disponibili dal wrapper impostate con i valori di default.
Il metodo permette di impostare se il grafico sarà responsive e andrà quindi a modificare le proprie dimensioni in accordo con la dimensione dell'elemento padre. Questo metodo prende i seguenti parametri:
Il metodo permette di impostare i valori di padding del grafico, questi rappresentano essenzialmente la cornice interna che viene lasciata fra il grafico e gli altri elementi della pagina. Questo metodo prende i seguenti parametri:
Nota: ChartJS lavora con i canvas, il padding è effettivamente uno spazio trasparente all'interno dell'immagine generata dal canvas e non il classico padding html.
Il metodo permette di definire se deve venir mostrata o meno la legenda del grafico. Questo metodo prende i seguenti parametri:
Il metodo permette di definire tutta una serie di aspetti grafici della legenda. Questo metodo prende i seguenti parametri:
Il metodo permette di definire se deve venir mostrato o meno il titolo del grafico. Questo metodo prende i seguenti parametri:
Il metodo permette di impostare il titolo del grafico. Questo metodo prende i seguenti parametri:
Il metodo permette di definire dove verrà mostrato il titolo del grafico. Questo metodo prende i seguenti parametri:
Permette di impostare tutta una serie di opzioni relative al titolo del grafico. Questo metodo prende i seguenti parametri:
Permette di impostare tutta una serie di parametri relativi all'asse X del grafico. Questo metodo prende i seguenti parametri:
Il metodo è speculare a setXAxis() ma relativamente all'asse X, si rimanda alla documentazione di quest'ultimo.
Permette di aggiungere ulteriori opzioni in modo libero. Questo metodo prende il seguente parametro:
$options = new stdClass; $options->rotation = $pi; $options->circumference = 15;
Per un esempio d'uso si può fare riferimento /apps/CityBase/cwbZzzChartTest.php Di seguito si riportano alcuni esempi estratti da tale file
$months = array('Gennaio','Febbraio','Marzo','Aprile','Maggio','Giugno','Luglio','Agosto','Settembre','Ottobre','Novembre','Dicembre'); //CREAZIONE DI 3 DATASET RANDOM $dataSet0 = new itaChartsDataSet(); $dataSet0->setData(array(rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10))); $dataSet0->setLabel("Dati 2015"); $dataSet0->setInterpolation(itaChartsDataSet::ITA_CHARTS_INTERPOLATION_NONE); $dataSet1 = new itaChartsDataSet(); $dataSet1->setBorderColor('#AA0000', '0.8'); $dataSet1->setData(array(rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10))); $dataSet1->setFill(false); $dataSet1->setLabel("Dati 2016"); $dataSet1->setInterpolation(itaChartsDataSet::ITA_CHARTS_INTERPOLATION_MONOTONE); $dataSet2 = new itaChartsDataSet(); $dataSet2->setBorderColor('#00AA00', '0.8'); $dataSet2->setBackgroundColor('#00CC00', '0.6'); $dataSet2->setBorderWidth(2); $dataSet2->setData(array(rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10))); $dataSet2->setFill(false); $dataSet2->setLabel("Dati 2017"); $dataSet2->setInterpolation(itaChartsDataSet::ITA_CHARTS_INTERPOLATION_CUBIC); //CREAZIONE DI UN GRAFICO A LINEA A PARITRE DAI TRE DATASET CREATI E CON OPZIONI CUSTOM $options = new itaChartsOptions(); $options->setTitle("Grafico di test"); $lineChart = new itaCharts('cwbZzzChartTest_chart'); $lineChart->setLabels($months); $lineChart->addDataSet($dataSet0); $lineChart->addDataSet($dataSet1); $lineChart->addDataSet($dataSet2); $lineChart->setChartType(itaCharts::ITA_CHARTS_TYPE_LINE); $lineChart->setOptions($options); $lineChart->render();
Per questo esempio si andranno ad usare i dataset creati nell'esempio precedente.
//CREAZIONE DI UN ISTOGRAMMA A PARTIRE DAI TRE DATASET CREATI $barChart = new itaCharts('cwbZzzChartTest_chart2'); $barChart->setLabels($months); $barChart->addDataSet($dataSet0); $barChart->addDataSet($dataSet1); $barChart->addDataSet($dataSet2); $barChart->setChartType(itaCharts::ITA_CHARTS_TYPE_BAR); $barChart->render();
Per questo esempio si creerà un dataset ex-novo. Notare che in questo dataset viene assegnato un colore differente per ogni valore, in caso contrario il grafico a torta sarebbe risultato tutto dello stesso colore.
//CREAZIONE DI UN SINGOLO DATASET PER UN GRAFICO A TORTA $dataSetPie = new itaChartsDataSet(); $colors = array(); for($i=0;$i<12;$i++){ $colors[] = 'rgba('.rand(0,255).','.rand(0,255).','.rand(0,255).',0.5)'; } $dataSetPie->setBackgroundColor($colors); $dataSetPie->setData(array(rand(0,100),rand(0,100),rand(0,100),rand(0,100),rand(0,100),rand(0,100),rand(0,100),rand(0,100),rand(0,100),rand(0,100),rand(0,100),rand(0,100))); $dataSetPie->setBorderWidth(2); $dataSetPie->setLabel("Dati 2017"); //CREAZIONE DI UN GRAFICO A TORTA $pieChart = new itaCharts('cwbZzzChartTest_chart3'); $pieChart->setLabels($months); $pieChart->addDataSet($dataSetPie); $pieChart->setChartType(itaCharts::ITA_CHARTS_TYPE_DOUGHNUT); $pieChart->render();
In questo esempio viene mostrato un istogramma con due dataset, in questo caso le barre però non vengono affiancate far loro ma vengono impilate una sull'altra. Questo effetto è ottenuto impostando stacked=true sia per l'asse x che per l'asse y sulle opzioni del grafico.
//CREAZIONE DELLE OPZIONI PER UN ISTOGRAMMA CON DATASET IMPILATI $optionsStacked = new itaChartsOptions(); $optionsStacked->setXAxis(true, null, null, true); //L'ULTIMO PARAMETRO IMPOSTATO A TRUE PERMETTE DI SOVRAPPORRE LE BARRE $optionsStacked->setYAxis(true, null, null, true); //L'ULTIMO PARAMETRO IMPOSTATO A TRUE PERMETTE DI IMPILARE LE BARRE //CREAZIONE DEI DATASET PER UN ISTOGRAMMA CON DATASET IMPILATI $dataSetStacked = new itaChartsDataSet(); $dataSetStacked->setData(array(rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10))); $dataSetStacked->setLabel("Dati 2015"); $dataSetStacked2 = new itaChartsDataSet(); $dataSetStacked2->setBorderColor("red"); $dataSetStacked2->setData(array(rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10),rand(0,10))); $dataSetStacked2->setLabel("Dati 2016"); //CREAZIONE DI UN ISTOGRAMMA CON DATASET IMPILATI $stackedChart = new itaCharts('cwbZzzChartTest_chart4'); $stackedChart->setLabels($months); $stackedChart->addDataSet($dataSetStacked); $stackedChart->addDataSet($dataSetStacked2); $stackedChart->setChartType(itaCharts::ITA_CHARTS_TYPE_BAR); $stackedChart->setOptions($optionsStacked); $stackedChart->render();
8 visualizzazioni.