Удаление гексис-метки линейного графика Google - PullRequest
1 голос
/ 09 апреля 2020

У меня есть график Google с тремя линиями. Я показываю месяцы на осях как ярлыки. Однако, поскольку график продолжает рисовать линии, метки исчезают / удаляются. Как этого избежать?

Ниже код моей диаграммы:

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

function prepareChartData(){
  var chartData = new google.visualization.DataTable();
  chartData.addColumn('date', 'Date');
  chartData.addColumn('number', 'Total');
  chartData.addColumn('number', 'Dogs');
  chartData.addColumn('number', 'Cats');
  title = 'My Chart';

  var options = {
title: title,
curveType: 'function',
legend: {position: 'bottom', alignment: 'start'},
colors: ['#003f5c', '#ffa600', '#665191', '#f95d6a'],
chartArea: {
	bottom: 80
},
annotations: {
  alwaysOutside: true,
  textStyle: {
    color: 'black',
    fontSize: 11
  },
},
hAxis: {
  format: 'MMM yy',
  viewWindowMode: "explicit",
},
vAxis: {
  minValue: 0,
  viewWindowMode: "explicit",
  viewWindow: { min: 0 },
  title: ''
},
titleTextStyle: {
  color:'#3a3a3a',
  fontSize:24,
  bold:false
  // fontName: "Segoe UI"
  },
bar: {groupWidth: '95%'},
bars: 'horizontal'
  };

  var chartDivId = "chart_div";
  var chart = new google.visualization.LineChart(document.getElementById(chartDivId));
  var rawData =[];

   var chart_object = { "Dec 19": {monthLabel: "Dec", chartArray:[{'date': "2019-12-31", 'total': "5", 'cats': "10", 'dogs': "10"}]},"Jan 20": {monthLabel: "Jan", chartArray:[{'date': "2020-1-01", 'total': "5", 'cats': "10", 'dogs': "10"}]},"Feb 20": {monthLabel: "Feb", chartArray:[{'date': "2020-2-29", 'total': "5", 'cats': "10", 'dogs': "10"}]}, "Mar 20": {monthLabel: "Mar", chartArray:[{'date': "2020-3-01", 'total': "5", 'cats': "10", 'dogs': "10"},{'date': "2020-03-12", 'total': "15", 'cats': "30", 'dogs': "30"}]}};

  $.each(chart_object, function(i, chartobject) {
 	$.each(  chartobject.chartArray, function( chartIndex , chartValue ){

date = chartValue['date'];
total = parseInt(chartValue['total']);
catscount = parseInt(chartValue['cats']);
dogscount = parseInt(chartValue['dogs']);
catspercentage = 0;
catspercentageAnnotation = catscount+",  percent "+catspercentage+"%";
dogsspercentage = 0;
dogsspercentageAnnotation = dogscount+",  percent "+dogsspercentage+"%";

rawData.push([ new Date(date), total, {v: catscount, f: catspercentageAnnotation}, {v: dogscount, f: dogsspercentageAnnotation}]);
  });
  });

  var counter = 0;
  drawChart();

  function drawChart() {
if(counter < rawData.length){
  chartData.addRow(rawData[counter]);

  // build x-axis ticks to prevent repeated labels
  var dateFormat = new google.visualization.DateFormat({
    pattern: 'yyyy-MM-dd'
  });
  var dateRange = chartData.getColumnRange(0);
  var ticks = [];
  var dateTick = dateRange.min;
  while (dateTick.getTime() <= dateRange.max.getTime()) {
    if (ticks.length === 0) {
      // format first tick
      ticks.push({
        v: dateTick,
        f: dateFormat.formatValue(dateTick)
      });
    } else {
      ticks.push(dateTick);
    }
    dateTick = new Date(dateTick.getFullYear(), dateTick.getMonth() + 1, 1);
  }
  options.hAxis.ticks = ticks;

  chart.draw(chartData, options);
  counter++;
  window.setTimeout(drawChart, 1000);
}
  }
}
 <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js" type="text/javascript" ></script>
  <script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script>
  <div id="chart_div"></div>

Мне не хватает какой-либо опции графика? Как я могу отобразить месяцы в самом начале месяца без удаления?

Может кто-нибудь помочь мне исправить это? Заранее спасибо.

1 Ответ

1 голос
/ 09 апреля 2020

У вас есть несколько вариантов:

Чередования

{
    options: {
        hAxis: {
            maxAlternation: 4
        }
    }
}

Описание документации:

Максимальное количество уровней текста по горизонтальной оси. Если текстовые метки оси становятся слишком переполненными, сервер может сместить соседние метки вверх или вниз, чтобы метки были ближе друг к другу. Это значение указывает наибольшее количество уровней для использования; сервер может использовать меньше уровней, если метки могут помещаться без наложения. Для даты и времени значение по умолчанию равно 1.

Это позволит меткам чередоваться между 4 различными уровнями, что позволит всем сосуществовать. Вы можете заменить 4 другим номером, который вы считаете подходящим. Кроме того, вам может потребоваться поставить галочку в области диаграммы, чтобы освободить место для дополнительных строк меток.

Наклонный текст

{
    options: {
        hAxis: {
            slantedTextAngle: 90
        }
    }
}

Описание документации:

Угол горизонтальной оси текста, если он нарисован наклонно. Игнорируется, если hAxis.slantedText равен false или находится в автоматическом режиме, и диаграмма решила нарисовать текст по горизонтали. Если угол положительный, вращение против часовой стрелки, а если отрицательное, то по часовой стрелке.

Это заставит метки записываться вертикально, поэтому каждая метка будет использовать только очень маленькое пространство на ось.

Просто увеличьте область диаграммы внизу

{
    options: {
        chartArea: {
            bottom: 80
        }
    }
}

Описание документации:

Объект с элементами для настройки размещения и размера диаграммы область (где нарисован сам график, исключая оси и легенды). Поддерживаются два формата: число или число, за которым следует%. Простое число - это значение в пикселях; число, за которым следует%, является процентом. Пример: chartArea: {left: 20, top: 0, width: '50% ', height: '75%'}

Увеличивая свободное место в нижней части диаграммы, вы Позвольте наклонному тексту работать автоматически, наклоняя надписи «достаточно».

...