/
home
/
obinna
/
html
/
restaurants
/
var
/
phpmyadmin
/
src
/
Plugins
/
Schema
/
Eps
/
Upload File
HOME
<?php /** * Classes to create relation schema in EPS format. */ declare(strict_types=1); namespace PhpMyAdmin\Plugins\Schema\Eps; /** * This Class is EPS Library and * helps in developing structure of EPS Schema Export * * @see https://www.php.net/manual/en/book.xmlwriter.php */ class Eps { public string $font = 'Arial'; public int $fontSize = 12; /** * %!PS-Adobe-3.0 EPSF-3.0 This is the MUST first comment to include * it shows/tells that the Post Script document is purely under * Document Structuring Convention [DSC] and is Compliant * Encapsulated Post Script Document */ public string $stringCommands = "%!PS-Adobe-3.0 EPSF-3.0 \n"; /** * Set document title * * @param string $value sets the title text */ public function setTitle(string $value): void { $this->stringCommands .= '%%Title: ' . $value . "\n"; } /** * Set document author * * @param string $value sets the author */ public function setAuthor(string $value): void { $this->stringCommands .= '%%Creator: ' . $value . "\n"; } /** * Set document creation date * * @param string $value sets the date */ public function setDate(string $value): void { $this->stringCommands .= '%%CreationDate: ' . $value . "\n"; } /** * Set document orientation * * @param string $orientation sets the orientation */ public function setOrientation(string $orientation): void { $this->stringCommands .= "%%PageOrder: Ascend \n"; if ($orientation === 'L') { $orientation = 'Landscape'; $this->stringCommands .= '%%Orientation: ' . $orientation . "\n"; } else { $orientation = 'Portrait'; $this->stringCommands .= '%%Orientation: ' . $orientation . "\n"; } $this->stringCommands .= "%%EndComments \n"; $this->stringCommands .= "%%Pages 1 \n"; $this->stringCommands .= "%%BoundingBox: 72 150 144 170 \n"; } /** * Set the font and size * * font can be set whenever needed in EPS * * @param string $value sets the font name e.g Arial * @param int $size sets the size of the font e.g 10 */ public function setFont(string $value, int $size): void { $this->font = $value; $this->fontSize = $size; $this->stringCommands .= '/' . $value . " findfont % Get the basic font\n"; $this->stringCommands .= '' . $size . ' scalefont % Scale the font to ' . $size . " points\n"; $this->stringCommands .= "setfont % Make it the current font\n"; } /** * Get the font * * @return string return the font name e.g Arial */ public function getFont(): string { return $this->font; } /** * Get the font Size * * @return int return the size of the font e.g 10 */ public function getFontSize(): int { return $this->fontSize; } /** * Draw the line * * drawing the lines from x,y source to x,y destination and set the * width of the line. lines helps in showing relationships of tables * * @param int|float $xFrom The x_from attribute defines the start left position of the element * @param int|float $yFrom The y_from attribute defines the start right position of the element * @param int|float $xTo The x_to attribute defines the end left position of the element * @param int|float $yTo The y_to attribute defines the end right position of the element * @param int $lineWidth Sets the width of the line e.g 2 */ public function line( int|float $xFrom = 0, int|float $yFrom = 0, int|float $xTo = 0, int|float $yTo = 0, int $lineWidth = 0, ): void { $this->stringCommands .= $lineWidth . " setlinewidth \n"; $this->stringCommands .= $xFrom . ' ' . $yFrom . " moveto \n"; $this->stringCommands .= $xTo . ' ' . $yTo . " lineto \n"; $this->stringCommands .= "stroke \n"; } /** * Draw the rectangle * * drawing the rectangle from x,y source to x,y destination and set the * width of the line. rectangles drawn around the text shown of fields * * @param int|float $xFrom The x_from attribute defines the start left position of the element * @param int|float $yFrom The y_from attribute defines the start right position of the element * @param int|float $xTo The x_to attribute defines the end left position of the element * @param int|float $yTo The y_to attribute defines the end right position of the element * @param int $lineWidth Sets the width of the line e.g 2 */ public function rect(int|float $xFrom, int|float $yFrom, int|float $xTo, int|float $yTo, int $lineWidth): void { $this->stringCommands .= $lineWidth . " setlinewidth \n"; $this->stringCommands .= "newpath \n"; $this->stringCommands .= $xFrom . ' ' . $yFrom . " moveto \n"; $this->stringCommands .= '0 ' . $yTo . " rlineto \n"; $this->stringCommands .= $xTo . " 0 rlineto \n"; $this->stringCommands .= '0 -' . $yTo . " rlineto \n"; $this->stringCommands .= "closepath \n"; $this->stringCommands .= "stroke \n"; } /** * Set the current point * * The moveto operator takes two numbers off the stack and treats * them as x and y coordinates to which to move. The coordinates * specified become the current point. * * @param int|float $x The x attribute defines the left position of the element * @param int|float $y The y attribute defines the right position of the element */ public function moveTo(int|float $x, int|float $y): void { $this->stringCommands .= $x . ' ' . $y . " moveto \n"; } /** * Output/Display the text * * @param string $text The string to be displayed */ public function show(string $text): void { $this->stringCommands .= '(' . $text . ") show \n"; } /** * Output the text at specified co-ordinates * * @param string $text String to be displayed * @param int|float $x X attribute defines the left position of the element * @param int|float $y Y attribute defines the right position of the element */ public function showXY(string $text, int|float $x, int|float $y): void { $this->moveTo($x, $y); $this->show($text); } /** * Ends EPS Document */ public function endEpsDoc(): void { $this->stringCommands .= "showpage \n"; } public function getOutputData(): string { return $this->stringCommands; } }