* @copyright Copyright (C) 2003, 2004 Jesper Veggerby Hansen * @license http://www.gnu.org/copyleft/lesser.html LGPL License 2.1 * @version CVS: $Id$ * @link http://pear.php.net/package/Image_Graph */ /** * Include file Image/Graph/Plot.php */ require_once 'Image/Graph/Plot.php'; /** * Include file Image/Graph/Tool.php */ require_once 'Image/Graph/Tool.php'; /** * Fit the graph (to a line using linear regression). * * @category Images * @package Image_Graph * @subpackage Plot * @author Jesper Veggerby * @copyright Copyright (C) 2003, 2004 Jesper Veggerby Hansen * @license http://www.gnu.org/copyleft/lesser.html LGPL License 2.1 * @version Release: @package_version@ * @link http://pear.php.net/package/Image_Graph */ class Image_Graph_Plot_Fit_Line extends Image_Graph_Plot { /** * Perform the actual drawing on the legend. * * @param int $x0 The top-left x-coordinate * @param int $y0 The top-left y-coordinate * @param int $x1 The bottom-right x-coordinate * @param int $y1 The bottom-right y-coordinate * @access private */ function _drawLegendSample($x0, $y0, $x1, $y1) { $y = ($y0 + $y1) / 2; $dy = abs($y1 - $y0) / 6; $this->_canvas->addVertex(array('x' => $x0, 'y' => $y + $dy)); $this->_canvas->addVertex(array('x' => $x1, 'y' => $y - $dy)); $this->_canvas->polygon(array('connect' => false)); } /** * Output the plot * * @return bool Was the output 'good' (true) or 'bad' (false). * @access private */ function _done() { if (Image_Graph_Plot::_done() === false) { return false; } $this->_canvas->startGroup(get_class($this) . '_' . $this->_title); $this->_clip(true); $keys = array_keys($this->_dataset); foreach ($keys as $key) { $dataset =& $this->_dataset[$key]; $dataset->_reset(); $data = array(); while ($point = $dataset->_next()) { $data[] = array( 'X' => $this->_pointX($point), 'Y' => $this->_pointY($point) ); } $regression = Image_Graph_Tool::calculateLinearRegression($data); $this->_getLineStyle($key); $this->_canvas->line( array( 'x0' => $this->_left, 'y0' => $this->_left * $regression['slope'] + $regression['intersection'], 'x1' => $this->_right, 'y1' => $this->_right * $regression['slope'] + $regression['intersection'] ) ); } $this->_clip(false); $this->_canvas->endGroup(); return true; } } ?>