Как загрузить несколько диаграмм Google за одну загрузку, поскольку диаграммы Google позволяют загружать только один пакет - PullRequest
0 голосов
/ 26 апреля 2018

У меня есть круговая диаграмма, которая легко отображается на моей странице, но мне нужно также создать древовидную карту на этой странице. Теперь древовидная карта использует package {'packages':['treemap']}. Поскольку указано, что будет только один вызов для загрузки function google .charts.load(). Код выглядит так. Панель и круговая диаграмма загружаются, но древовидная карта не отображается.

$(document).ready(function () {
    $("#submit").click(function () {
        $("#pages").hide();

        var datefrom = $('#fromdatecalendar').val()
        var dateto = $('#todatecalendar').val()
        var model = $("#model_name").val().toString();
        var queryObject = "";
        var queryObjectLen = "";
        google.charts.load('current', { 'packages': ['corechart'] });
        google.charts.load('current', { 'packages': ['treemap'] });
        google.charts.setOnLoadCallback(drawChart);

        function drawChart() {
            $.ajax({
                url: "connect.jsp",
                type: "POST",
                data: { datetype: $('#fromdatecalendar').val(), datatocal: $('#todatecalendar').val(), model: $("#model_name").val().toString() },
                success: function (datas) {
                    var jsonData = JSON.parse(datas);
                    //loadData(jsondata);
                    var data = new google.visualization.DataTable();
                    var data2 = new google.visualization.DataTable();
                    // assumes "word" is a string and "count" is a number
                    data.addColumn('string', 'CATEGORY');
                    data.addColumn('number', 'COUNT_CAT');
                    data2.addColumn('string', 'CATEGORY');
                    data2.addColumn('string', 'SUB_CATEGORY');
                    data2.addColumn('string', 'SUB_CATEGORY_2');
                    data2.addColumn('string', 'SUB_CATEGORY_3');
                    data2.addColumn('string', 'SUB_CATEGORY_4');
                    data2.addColumn('string', 'SUB_CATEGORY_5');
                    data2.addColumn('number', 'COUNT_CAT');
                    for (var i = 0; i < jsonData.length; i++) {
                        data.addRow([jsonData[i].CATEGORY, jsonData[i].COUNT_CAT]);
                    }
                    for (var j = 0; i < jsonData.length; i++) {
                        data2.addRow([jsonData[j].CATEGORY, jsonData[j].SUB_CATEGORY, jsonData[j].SUB_CATEGORY_2, jsonData[j].SUB_CATEGORY_3, jsonData[j].SUB_CATEGORY_4, jsonData[j].SUB_CATEGORY_5, jsonData[j].COUNT_CAT]);
                    }
                    //alert(data);
                    var piechart_options = {
                        title: 'Category Count',
                        backgroundColor: '#f5f5f5',
                        pieSliceText: 'value',
                        is3D: true

                    };
                    var piechart = new google.visualization.PieChart(document.getElementById('chart_div'));
                    piechart.draw(data, piechart_options);

                    var barchart_options = {
                        title: 'Category',
                        backgroundColor: '#f5f5f5',
                        legend: 'none'
                    };
                    var barchart = new google.visualization.BarChart(document.getElementById('barchart_div'));
                    barchart.draw(data, barchart_options);

                    var tree = new google.visualization.TreeMap(document.getElementById('treechart_div'));

                    tree.draw(data2, {
                        minColor: '#f00',
                        midColor: '#ddd',
                        maxColor: '#0d0',
                        headerHeight: 15,
                        fontColor: 'black',
                        showScale: true
                    });
                    var showsubcat = document.getElementById("showsub");
                    showsubcat.onclick = function () {
                        var view = new google.visualization.DataView(data);
                        view.hideColumns([1]);
                        piechart.draw(view, piechart_options);
                    }


                },
                error: function (xhr, type) {
                    alert('server error occoured')
                }

            });

        }
    });
});

1 Ответ

0 голосов
/ 26 апреля 2018

вы можете загрузить несколько пакетов, как это ...

google.charts.load('current', {'packages': ['corechart', 'treemap']});
...