Я пытаюсь построить из диаграммы Ганта с даты/времени на оси X, код у меня есть что-то вроде этого:AmCharts Диаграмма Ганта со временем данные не загружаются правильно
AmCharts.useUTC = true;
var chart = AmCharts.makeChart("user-pages", {
"type": "gantt",
"theme": "light",
"marginRight": 70,
"dataDateFormat": "DD-MM-YYYY HH:NN",
"columnWidth": 0.5,
"valueAxis": {
"type": "date"
},
"brightnessStep": 7,
"graph": {
"fillAlphas": 1,
"lineAlpha": 1,
"lineColor": "#fff",
"balloonText": "<b>[[task]]</b>:<br />[[open]] -- [[value]]"
},
"rotate": true,
"categoryField": "category",
"segmentsField": "segments",
"colorField": "color",
"startDateField": "start",
"endDateField": "end",
"dataProvider": [ {
"category": "Module #1",
"segments": [ {
"start": AmCharts.stringToDate("2016-10-03T09:33:00+00:00", "DD-MM-YYYY HH:NN"),
"end": AmCharts.stringToDate("2016-10-04T10:33:00+00:00", "DD-MM-YYYY HH:NN"),
"color": "#b9783f",
"task": "Gathering requirements"
}]
}, {
"category": "Module #2",
"segments": [ {
"start": AmCharts.stringToDate("2016-10-03T07:00:00+00:00", "DD-MM-YYYY HH:NN"),
"end": AmCharts.stringToDate("2016-10-03T08:00:00+00:00", "DD-MM-YYYY HH:NN"),
"color": "#b9783f",
"task": "Gathering requirements"
}, {
"start": AmCharts.stringToDate("2016-10-03T13:00:00+00:00", "DD-MM-YYYY HH:NN"),
"end": AmCharts.stringToDate("2016-10-03T14:00:00+00:00", "DD-MM-YYYY HH:NN"),
"task": "Producing specifications"
}, {
"start": AmCharts.stringToDate("2016-10-03T15:00:00+00:00", "DD-MM-YYYY HH:NN"),
"end": AmCharts.stringToDate("2016-10-03T16:00:00+00:00", "DD-MM-YYYY HH:NN"),
"task": "Development"
} ]
}, {
"category": "Module #3",
"segments": [ {
"start": AmCharts.stringToDate("2016-10-03T09:33:00+00:00", "DD-MM-YYYY HH:NN"),
"end": AmCharts.stringToDate("2016-10-03T10:33:00+00:00", "DD-MM-YYYY HH:NN"),
"color": "#b9783f",
"task": "Gathering requirements"
}, {
"start": AmCharts.stringToDate("2016-10-03T11:33:00+00:00", "DD-MM-YYYY HH:NN"),
"end": AmCharts.stringToDate("2016-10-03T12:33:00+00:00", "DD-MM-YYYY HH:NN"),
"task": "Producing specifications"
}, {
"start": AmCharts.stringToDate("2016-10-03T15:33:00+00:00", "DD-MM-YYYY HH:NN"),
"end": AmCharts.stringToDate("2016-10-03T17:33:00+00:00", "DD-MM-YYYY HH:NN"),
"task": "Development"
} ]
}, {
"category": "Module #4",
"segments": [ {
"start": AmCharts.stringToDate("2016-10-03T07:00:00+00:00", "DD-MM-YYYY HH:NN"),
"end": AmCharts.stringToDate("2016-10-03T08:00:00+00:00", "DD-MM-YYYY HH:NN"),
"color": "#b9783f",
"task": "Gathering requirements"
}, {
"start": AmCharts.stringToDate("2016-10-03T13:00:00+00:00", "DD-MM-YYYY HH:NN"),
"end": AmCharts.stringToDate("2016-10-03T14:00:00+00:00", "DD-MM-YYYY HH:NN"),
"task": "Producing specifications"
}, {
"start": AmCharts.stringToDate("2016-10-03T15:00:00+00:00", "DD-MM-YYYY HH:NN"),
"end": AmCharts.stringToDate("2016-10-03T16:00:00+00:00", "DD-MM-YYYY HH:NN"),
"task": "Development"
} ]
}, {
"category": "Module #5",
"segments": [ {
"start": AmCharts.stringToDate("2016-10-03T09:33:00+00:00", "DD-MM-YYYY HH:NN"),
"end": AmCharts.stringToDate("2016-10-03T10:33:00+00:00", "DD-MM-YYYY HH:NN"),
"color": "#b9783f",
"task": "Gathering requirements"
}, {
"start": AmCharts.stringToDate("2016-10-03T11:33:00+00:00", "DD-MM-YYYY HH:NN"),
"end": AmCharts.stringToDate("2016-10-03T12:33:00+00:00", "DD-MM-YYYY HH:NN"),
"task": "Producing specifications"
}, {
"start": AmCharts.stringToDate("2016-10-03T15:33:00+00:00", "DD-MM-YYYY HH:NN"),
"end": AmCharts.stringToDate("2016-10-03T17:33:00+00:00", "DD-MM-YYYY HH:NN"),
"task": "Development"
} ]
} ],
"valueScrollbar": {
"autoGridCount": true
},
"chartCursor": {
"cursorColor": "#55bb76",
"valueBalloonsEnabled": false,
"cursorAlpha": 0,
"valueLineAlpha": 0.5,
"valueLineBalloonEnabled": true,
"valueLineEnabled": true,
"zoomable": false,
"valueZoomable": true
},
"export": {
"enabled": true
}
});
Вы можете увидеть вопрос здесь: http://jsfiddle.net/28305m8g/1/
Если изменить сегмент первого быть в тот же день:
[ {
"category": "Module #1",
"segments": [ {
"start": AmCharts.stringToDate("2016-10-03T09:33:00+00:00", "DD-MM-YYYY HH:NN"),
"end": AmCharts.stringToDate("2016-10-04T10:33:00+00:00", "DD-MM-YYYY HH:NN"),
"color": "#b9783f",
"task": "Gathering requirements"
}]
To:
[ {
"category": "Module #1",
"segments": [ {
"start": AmCharts.stringToDate("2016-10-03T09:33:00+00:00", "DD-MM-YYYY HH:NN"),
"end": AmCharts.stringToDate("2016-10-03T10:33:00+00:00", "DD-MM-YYYY HH:NN"),
"color": "#b9783f",
"task": "Gathering requirements"
}]
Вы можете видеть, что это работает ниже: http://jsfiddle.net/28305m8g/2/
Кто-нибудь знает, почему это происходит, и может помочь мне исправить это?
спасибо xorspark этого решения работало, у меня есть быстрый вопрос для вас, мой график на зависших сейчас дает мне следующую ошибку в консоли: ' Uncaught TypeError: g.fixPrevious не является functionhowGraphBalloon @ amcharts.js: 211handleRollOver @ amcharts.js: 204 (анонимная функция) @ amcharts.js: 203 browser_adapter.js: 93 ИСКЛЮЧЕНИЕ: TypeError: g.fixPrevious не является функцией ' Знаете ли вы, что вызывает это? –
Не могу сказать точно без скрипки, которая воспроизводит его. Единственный раз, когда я видел подобную проблему, появляется, если вы одновременно включаете файлы amcharts и amap js. Если у вас есть диаграммы и карты на одной странице, вы должны использовать ammap_amcharts_extension.js вместо ammap.js – xorspark
Я использую оба файла amap.js и amcharts на одной странице, но, как только я использую amap_amcharts_extensions.js вместо патронов .js I Затем бегите в следующее сообщение об ошибке: 'amcharts.js: 3 Uncaught TypeError: не удается прочитать свойство 'длина' неопределенной a.inherits.b.fire \t \t @ amcharts.js: 3 handleReleaseOutside \t \t @ ammap_amcharts_extension.js: 19 d.handleMouseUp \t @ \t amcharts.js: 6' –