Пчарт печатает двойные значения по оси X

Быть нежным..

Использование приведенного ниже кода для печати диаграммы с использованием pchart на RPI приводит к двойным значениям, напечатанным на оси X.

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

Помощь будет оценена!

Морис

<?php

ini_set('display_errors', 'On');
error_reporting(E_ALL | E_STRICT);

include("class/pDraw.class.php");
include("class/pImage.class.php");
include("class/pData.class.php");

$db = new PDO("sqlite:/home/pi/sensor.db");

$MyData = new pData();

$tijd="";
$lucht="";

$result = $db->query('SELECT tijd, lucht FROM waarden WHERE lucht  > 40');
foreach($result as $row)
{
$tijd[]   = $row["tijd"];
$lucht[] = $row["lucht"];
}

$MyData->addPoints($lucht,"lucht");
$MyData->setSerieOnAxis("lucht", 0);
$MyData->setAxisName(0,"lucht");
$MyData->setAxisUnit(0,"%");

$MyData->addPoints($tijd,"tijd");
$MyData->setSerieDescription("tijd","Tijden");
$MyData->setAbscissa("tijd");

$myPicture = new pImage(800,330,$MyData);
$myPicture->setFontProperties(array("FontName"=>"fonts/Forgotte.ttf","FontSize"=>11));
$myPicture->setGraphArea(60,40,740,290);
$myPicture->drawScale(array("AutoAxisLabels"=>FALSE,"RemoveXAxis"=>FALSE));
$myPicture->drawLineChart();

//rotate the xaxis values
$myPicture->drawScale(array("DrawSubTicks"=>False, "LabelRotation"=>20));

$myPicture->autoOutput("mypic.png");
$db = null;
?>

введите описание изображения здесь

1

Решение

Нашел свою ошибку.

Похоже, моя двойная инструкция

$myPicture->drawScale(array("

в инициализации на и не обрабатывается слишком хорошо и приводит к двойной метке Xaxis

Правильный код:

<?php

ini_set('display_errors', 'On');
error_reporting(E_ALL | E_STRICT);

include("class/pDraw.class.php");
include("class/pImage.class.php");
include("class/pData.class.php");

$db = new PDO("sqlite:/home/pi/sensor.db");

$MyData = new pData();

$tijd="";
$lucht="";

$result = $db->query('SELECT tijd, lucht FROM waarden WHERE lucht  > 40');
foreach($result as $row)
{
$tijd[]   = $row["tijd"];
$lucht[] = $row["lucht"];
}

$MyData->addPoints($lucht,"lucht");
$MyData->setSerieOnAxis("lucht", 0);
$MyData->setAxisName(0,"lucht");
$MyData->setAxisUnit(0,"%");

$MyData->addPoints($tijd,"tijd");
$MyData->setAbscissa("tijd");
$MyData->setAbscissaName("Time of Reading");

$myPicture = new pImage(800,330,$MyData);
$myPicture->setFontProperties(array("FontName"=>"fonts/Forgotte.ttf","FontSize"=>11));
$myPicture->setGraphArea(60,40,740,290);

//Remove line below to avoid double Xaxis values
//$myPicture->drawScale(array("AutoAxisLabels"=>FALSE,"RemoveXAxis"=>FALSE));
$myPicture->drawScale(array("DrawSubTicks"=>False, "LabelRotation"=>20));
$myPicture->drawLineChart();
$myPicture->autoOutput("mypic.png");
$db = null;
?>
0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]