gpt4 book ai didi

javascript - 在 PHP 中使用时间轴 Google Chart API - 日期/时间格式问题

转载 作者:行者123 更新时间:2023-11-29 01:53:04 25 4
gpt4 key购买 nike

我正在尝试实现 Google 的 Timeline API https://developers.google.com/chart/interactive/docs/gallery/timeline#controlling-the-colors

我对日期格式有疑问,因为我不确定如何将我的时间格式存储/转换为时间线图表的正确格式。

我的数据库是这样的: enter image description here

我正在尝试输出一个如下所示的图表:(这是一个硬编码示例)

enter image description here

我当前的代码如下所示:

    <?php
$connect=mysqli_connect("localhost","root","","smartcinema");
if (mysqli_connect_errno())
{
echo "Failed to connect to MySQL: " . mysqli_connect_error();
}

$query = "SELECT a.screen_name, m.title, s.show_startime, s.show_endtime FROM timetable AS t INNER JOIN showing AS s ON s.showing_id = t.showing_id JOIN auditorium AS a ON a.screen_id = t.screen_id JOIN movies AS m ON m.movie_id = t.movie_id";
$qresult = mysqli_query($connect,$query);
$rows = array();
$table = array();




$table['cols'] = array (
array('id' => 'Screen', 'type' => 'string'),
array('id' => 'Movie', 'type' => 'string'),
array('id' => 'Start time', 'type' => 'date'),
array('id' => 'End time', 'type' => 'date')
);

while($res = mysqli_fetch_assoc($qresult)){
$result[] = $res;
}

foreach ($result as $r) {

$temp = array();
$temp[] = array('v' => $r['screen_name']);
$temp[] = array('v' => $r['title']);
$temp[] = array('v' => 'new Date(0,0,0,'.date('H',strtotime($r['show_startime'])).','.date('i',strtotime($r['show_startime'])).','.date('s',strtotime($r['show_startime'])).')');
$temp[] = array('v' => 'new Date(0,0,0,'.date('H',strtotime($r['show_endtime'])).','.date('i',strtotime($r['show_endtime'])).','.date('s',strtotime($r['show_endtime'])).')');
$rows[] = array('c' => $temp);

}
$table['rows'] = $rows;
$jsonTable = json_encode($table);
print_r($jsonTable);
?>

<script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script>
<script type="text/javascript">
google.charts.load("current", {packages:["timeline"]});
google.charts.setOnLoadCallback(drawChart);
function drawChart() {
var data = new google.visualization.DataTable(<?php echo $jsonTable; ?>);
var container = document.getElementById('test');
var chart = new google.visualization.Timeline(container);


var options = {
timeline: { colorByRowLabel: true },
backgroundColor: '#ffd'
};

chart.draw(dataTable, options);
}
</script>

<div id="test" ></div>

最佳答案

当您 print_r($jsonTable); 时——它与以下示例有何不同?

google.charts.load('current', {
callback: drawChart,
packages: ['timeline']
});

function drawChart() {
var dataTable = new google.visualization.DataTable({
cols: [
{id: 'Screen', type: 'string'},
{id: 'Movie', type: 'string'},
{id: 'Start time', type: 'date'},
{id: 'End time', type: 'date'}
],
rows: [
{c:[{v: 'Screen 1'}, {v: 'Batman v Superman: Dawn of Justice'}, {v: new Date(0, 0, 0, 10, 0, 0)}, {v: new Date(0, 0, 0, 12, 31, 0)}]},
{c:[{v: 'Screen 1'}, {v: 'Batman v Superman: Dawn of Justice'}, {v: new Date(0, 0, 0, 12, 51, 0)}, {v: new Date(0, 0, 0, 15, 22, 0)}]},
{c:[{v: 'Screen 1'}, {v: 'Batman v Superman: Dawn of Justice'}, {v: new Date(0, 0, 0, 15, 42, 0)}, {v: new Date(0, 0, 0, 18, 13, 0)}]},
{c:[{v: 'Screen 2'}, {v: 'High-Rise'}, {v: new Date(0, 0, 0, 10, 0, 0)}, {v: new Date(0, 0, 0, 11, 52, 0)}]},
{c:[{v: 'Screen 2'}, {v: 'High-Rise'}, {v: new Date(0, 0, 0, 12, 2, 0)}, {v: new Date(0, 0, 0, 13, 54, 0)}]},
{c:[{v: 'Screen 2'}, {v: 'High-Rise'}, {v: new Date(0, 0, 0, 14, 4, 0)}, {v: new Date(0, 0, 0, 15, 56, 0)}]},
]
});

var container = document.getElementById('example');
var chart = new google.visualization.Timeline(container);
chart.draw(dataTable);
}
<script src="https://www.gstatic.com/charts/loader.js"></script>
<div id="example"></div>

关于javascript - 在 PHP 中使用时间轴 Google Chart API - 日期/时间格式问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36233412/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com