strokeWidth = $width; return $this; } /** * Set the color for the stroke or none for no stroke * * @param string $color The color to set for the stroke * * @return self Fluid interface */ public function setStrokeColor($color) { $this->strokeColor = $color ? $color : 'none'; return $this; } /** * Set additional styles for this drawable * * @param string $styles The styles to set additionally * * @return self Fluid interface */ public function setAdditionalStyle($styles) { $this->additionalStyle = $styles; return $this; } /** * Set the fill for this styleable * * @param string $color The color to use for filling or null to use no fill * * @return self Fluid interface */ public function setFill($color = null) { $this->fill = $color ? $color : 'none'; return $this; } /** * Set the id for this element * * @param string $id The id to set for this element * * @return self Fluid interface */ public function setId($id) { $this->id = $id; return $this; } /** * Return the content of the style attribute as a string * * @return string A string containing styles */ public function getStyle() { $base = sprintf("fill: %s; stroke: %s;stroke-width: %s;", $this->fill, $this->strokeColor, $this->strokeWidth); $base .= ';' . $this->additionalStyle . ';'; return $base; } /** * Add an additional attribute to this element */ public function setAttribute($key, $value) { $this->attributes[$key] = $value; } /** * Apply attribute to a DOMElement * * @param DOMElement $el Element to apply attributes */ protected function applyAttributes(DOMElement $el) { foreach ($this->attributes as $name => $value) { $el->setAttribute($name, $value); } } }