Mysql到谷歌图表与列标签

时间:2014-09-12 23:06:05

标签: php mysql label google-visualization

我正在尝试使用列标签创建一个谷歌图表。以下工作对我来说很好。除了当我尝试使用它与从mysql表中的Json datacreated时。你们能不能帮我理解我做错了什么。

使用Google Chart代码:

<script type="text/javascript">
    function drawVisualization() {

    var data = google.visualization.arrayToDataTable([
        ['From', 'TotalOrders', 'Quantity'],
        ['Wk of 9/7/14', 172, 8910],
        ['Wk of 9/14/14', 121, 5901],
        ['Wk of 9/21/14', null, null],
        ['Wk of 9/28/14', null, null]
    ]);


    var formatter = new google.visualization.NumberFormat( {pattern:'#,###'});
    formatter.format(data, 1);
    formatter.format(data, 2);

    mydiv = $("#mychart");
    chart = new google.visualization.ComboChart(mydiv[0]);
    chart.draw(data, {
        width: 600, height: 400, seriesType: 'bars',
        chartArea: {left: 60, top: 30, width: 540}
    });    


    rects = mydiv.find('svg > g > g > g > rect');
    var row = 0;
    for (i = 0; i < rects.length; i++) {

        el = $(rects[i]);
        if (parseFloat(el.attr("height")) <= 2) { continue; }
        aparent = el.parent();
        do { // skips 'null' values
            text = data.getValue(row++, 1);
        } while (text == null && row < data.getNumberOfRows());

        if (text) {
            text = formatter.formatValue(text);
            // see below
            pos = getElementPos(el);
            attrs = {x: pos.x + pos.width / 2, y: pos.y - 2,
                fill: 'black',
                'font-family': 'Arial', 'font-size': 11,
                'text-anchor': 'middle'};
            aparent.append(addTextNode(attrs, text, aparent));
        }
    }
}


google.load('visualization', '1', {packages: ['corechart']});
google.setOnLoadCallback(drawVisualization);

function getElementPos($el) {
    return {
        x: parseInt($el.attr("x")),
        width: parseInt($el.attr("width")),
        y: parseInt($el.attr("y")),
        height: parseInt($el.attr("height"))
    }
}


function addTextNode(attrs, text, _element) {
    var el = document.createElementNS('http://www.w3.org/2000/svg', "text");
    for (var k in attrs) { el.setAttribute(k, attrs[k]); }
    var textNode = document.createTextNode(text);
    el.appendChild(textNode);
    return el;
}

</script>

       

但是当我使用以下内容时它不起作用。

$table = array();
$table['cols'] = array(
    array('label' => 'From', 'type' => 'string'),
    array('label' => 'TotalOrders', 'type' => 'number'),
    array('label' => 'Quantity', 'type' => 'Number')
);

$rows = array();
while($r = mysql_fetch_assoc($sth)) {
    $temp = array();
    $temp[] = array('v' => (string) $r['From']); 
    $temp[] = array('v' => (int) $r['TotalOrders']); 
    $temp[] = array('v' => (int) $r['Quantity']); 
    $rows[] = array('c' => $temp);
}

$table['rows'] = $rows;
$jsonTable = json_encode($table);

我似乎无法找到这里出了什么问题。也许你们可以指出我正确的方向。

1 个答案:

答案 0 :(得分:0)

JSON结构与arrayToDataTable函数不兼容 - 您必须使用常规DataTable构造函数:

var data = new google.visualization.DataTable(<?php echo $jsonTable; ?>);

此外,您应该在输出中正确解析json_encode函数,否则它们可能会以字符串形式出现:

$jsonTable = json_encode($table, JSON_NUMERIC_CHECK);