Установить фиксированную высоту сетки для диаграммы Ганта amchart4 - PullRequest
0 голосов
/ 04 октября 2019

как мне установить высоту для каждой сетки равной высоте?

Я уже установил внешний контейнер для умножения на количество строк данных по 100 пикселей каждая, но высота сетки для каждой строки, похоже, увеличивается с увеличением внешней высоты. Пожалуйста, помогите, большое спасибо!

Отображение моего текущего графика Ниже приведены мои коды в ruby:

.col-6.cost-info-label
    = timeline_info.name
.poc_chart{:id => "timeline_#{index2}", :style => "width: 100%; height: 
#{height_value}px;"}
%br
%br
%script{:src => "https://www.amcharts.com/lib/4/core.js"}
%script{:src => "https://www.amcharts.com/lib/4/charts.js"}
%script{:src => "https://www.amcharts.com/lib/4/themes/animated.js"}
/ Chart code
:javascript
am4core.ready(function() {

// Themes begin
am4core.useTheme(am4themes_animated);
// Themes end
var timelines = #{raw timeline_info.to_json};
var timeline_activities = #{raw timeline_activities.to_json};
var num_of_loops = timeline_activities.length
var chart = am4core.create("timeline_#{raw index2}", am4charts.XYChart);
chart.hiddenState.properties.opacity = 0; // this creates initial fade-in
chart.paddingRight = 30;
chart.dateFormatter.inputDateFormat = "yyyy-MM-dd";

var colorSet = new am4core.ColorSet();
colorSet.saturation = 0.4;
var data_sets = [];
var i;
var k;
var color_counter = 0;
var brighten_sign;
for(i=0; i < num_of_loops; i++){
    var timeline = timeline_activities[i];
    var formatted_start_date;
    var formatted_end_date;
    var actual_start_date;
    var actual_end_date;
    var formatted_name;
    if(timeline_activities[i]["planned_start"] == null){
        formatted_start_date = null;
    }
    else{
        var planned_start = new Date(timeline_activities[i]["planned_start"]);
        formatted_start_date = planned_start.getFullYear() + '-' + (planned_start.getMonth()+1).toString().padStart(2, '0') + '-' + planned_start.getDate().toString().padStart(2, '0');
    }

    if(timeline_activities[i]["planned_end"] == null){
        formatted_end_date = null;
    }
    else{
        var planned_end = new Date(timeline_activities[i]["planned_end"]);
        formatted_end_date = planned_end.getFullYear() + '-' + (planned_end.getMonth()+1).toString().padStart(2, '0') + '-' + planned_end.getDate().toString().padStart(2, '0');
    }

    if(formatted_start_date == null){
        actual_start_date = null;
    }
    else if(timeline_activities[i]["actual_start"] == null){
        actual_start_date = formatted_start_date;
    }
    else{
        var actual_start = new Date(timeline_activities[i]["actual_start"]);
        actual_start_date = actual_start.getFullYear() + '-' + (actual_start.getMonth()+1).toString().padStart(2, '0') + '-' + actual_start.getDate().toString().padStart(2, '0');
    }

    if(formatted_end_date == null){
        actual_end_date = null;
    }
    else if(timeline_activities[i]["actual_end"] == null){
        actual_end_date = formatted_end_date;
    }
    else{
        var actual_end = new Date(timeline_activities[i]["actual_end"]);
        actual_end_date = actual_end.getFullYear() + '-' + (actual_end.getMonth()+1).toString().padStart(2, '0') + '-' + actual_end.getDate().toString().padStart(2, '0');
    }

    if(timeline_activities[i]["name"].length > 20){
        formatted_name = timeline_activities[i]["name"].slice(0, 20) + '...';
    }
    else{
        formatted_name = timeline_activities[i]["name"];
    }
    var random_num = Math.random();
    var random_num_1 = random_num-0.1;
    data_sets.push({
        main: timelines["name"],
        name: formatted_name,
        fromDate: formatted_start_date,
        toDate: formatted_end_date,
        actualStartDate: actual_start_date,
        actualEndDate: actual_end_date,
        color: colorSet.getIndex(0).brighten(0),
        color1: colorSet.getIndex(0).brighten(0.8)
    });
    color_counter++;

};
chart.data = data_sets;

var categoryAxis = chart.yAxes.push(new am4charts.CategoryAxis());
categoryAxis.dataFields.category = "name";
categoryAxis.renderer.grid.template.location = 0;
categoryAxis.renderer.grid.template.height = 40;
categoryAxis.renderer.inversed = true;

var dateAxis = chart.xAxes.push(new am4charts.DateAxis());
dateAxis.dateFormatter.dateFormat = "yyyy-MM-dd";
dateAxis.renderer.minGridDistance = 70;
dateAxis.baseInterval = { count: 30, timeUnit: "day" };
dateAxis.max = new Date(2018, 0, 1, 24, 0, 0, 0);
dateAxis.strictMinMax = true;
dateAxis.renderer.tooltipLocation = 0;

var series1 = chart.series.push(new am4charts.ColumnSeries());
series1.columns.template.width = am4core.percent(80);
series1.columns.template.tooltipText = "Project Timeline: {main} \n Activity : {name} \n Planned: {openDateX} - {dateX}";

series1.dataFields.openDateX = "fromDate";
series1.dataFields.dateX = "toDate";
series1.dataFields.categoryY = "name";
series1.columns.template.propertyFields.fill = "color"; // get color from data
series1.columns.template.propertyFields.stroke = "color";
series1.columns.template.strokeOpacity = 1;

var series2 = chart.series.push(new am4charts.ColumnSeries());
series2.columns.template.width = am4core.percent(80);
series2.columns.template.tooltipText = "Project Timeline: {main} \n Activity :{name} \n Actual: {openDateX} - {dateX}";

series2.dataFields.openDateX = "actualStartDate";
series2.dataFields.dateX = "actualEndDate";
series2.dataFields.categoryY = "name";
series1.columns.template.propertyFields.fill = "color1"; // get color from data
series1.columns.template.propertyFields.stroke = "color1";
series1.columns.template.strokeOpacity = 1;

chart.scrollbarX = new am4core.Scrollbar();

}); // end am4core.ready()

`

...