Panoramica
I grafici di Google Tables possono essere stampati direttamente dal browser o da JavaScript tramite la funzione print()
. Se vuoi fornire l'accesso a un'immagine PNG di un grafico, puoi utilizzare il metodo getImageURI()
. Questo funziona attualmente per i grafici principali e i grafici geografici.
Se il grafico (di tipo ChartType, ad esempio ColumnChart o PeieChart) si chiama my_chart e il div che lo visualizza è my_div, procedi come descritto di seguito per accedere al grafico come PNG:
var my_div = document.getElementById('chart_div'); var my_chart = new google.visualization.ChartType(chart_div); google.visualization.events.addListener(my_chart, 'ready', function () { my_div.innerHTML = '<img src="' + my_chart.getImageURI() + '">'; }); my_chart.draw(data);
Nota: per assicurarti che il rendering del grafico sia terminato, devi attendere l'evento ready
, come mostrato negli esempi in questa pagina.
Nota: funziona solo nei browser che supportano l'elemento HTML5 <canvas>
, pertanto non funziona su Internet Explorer 9 o versioni precedenti.
Ecco un esempio completo:
<html> <head> <script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script> <script type="text/javascript"> google.charts.load("current", {packages:['corechart']}); google.charts.setOnLoadCallback(drawChart); function drawChart() { var data = google.visualization.arrayToDataTable([ ['Element', 'Density', { role: 'style' }], ['Copper', 8.94, '#b87333', ], ['Silver', 10.49, 'silver'], ['Gold', 19.30, 'gold'], ['Platinum', 21.45, 'color: #e5e4e2' ] ]); var options = { title: "Density of Precious Metals, in g/cm^3", bar: {groupWidth: '95%'}, legend: 'none', }; var chart_div = document.getElementById('chart_div'); var chart = new google.visualization.ColumnChart(chart_div); // Wait for the chart to finish drawing before calling the getImageURI() method. google.visualization.events.addListener(chart, 'ready', function () { chart_div.innerHTML = '<img src="' + chart.getImageURI() + '">'; console.log(chart_div.innerHTML); }); chart.draw(data, options); } </script> <div id='chart_div'></div>
Quando questo programma viene eseguito, chart_div.innerHTML
sarà impostato su questa codifica PNG del grafico e visualizzata nella console JavaScript:
data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAZAAAADICAYAAADGFbfiA...
Quando l'URI viene inserito direttamente nella barra degli indirizzi del browser, nei browser moderni l'immagine viene visualizzata:
Puoi includere un link alla versione stampabile con la seguente riga di JavaScript:
document.getElementById('png').outerHTML = '<a href="' + chart.getImageURI() + '">Printable version</a>';
seguito da questa riga nel codice HTML:
<div id='png'></div>
Selezioni di snapshot
In qualità di creatore di grafici, puoi eseguire la maggior parte delle operazioni che i tuoi utenti possono eseguire in modo programmatico nei browser. Pertanto, se vuoi
creare un'immagine statica del grafico con
una descrizione comando
mostrata o con i
Migratori in un punto particolare, puoi farlo chiamando setSelection()
prima del giorno
getImageURI()
, come mostrato di seguito.
Di seguito è riportato un grafico a dispersione con 100 punti casuali, uno dei quali con descrizione comando e michi preselezionati:
Ricarica e vedrai un punto di accesso diverso. Il codice, con le righe chiave in grassetto:
<script type="text/javascript"> google.charts.load("current", {packages:['corechart']}); google.charts.setOnLoadCallback(drawChart); function drawChart() { var data = new google.visualization.DataTable(); data.addColumn('number'); data.addColumn('number'); for (var i = 0; i < 100; i++) data.addRow([Math.floor(Math.random() * 100), Math.floor(Math.random() * 100)]); var options = { legend: 'none', crosshair: { trigger: 'both' }, // Display crosshairs. tooltip: { trigger: 'selection' } // Display tooltips on selection. }; var chart = new google.visualization.ScatterChart(document.getElementById('scatter_setselection')); google.visualization.events.addListener(chart, 'ready', function () { chart.setSelection([{row:99, column:1}]); // Select one of the points. png = '<a href="' + chart.getImageURI() + '">Printable version</a>'; console.log(png); }); chart.draw(data, options); }