QRMarkupSVG
extends QRMarkup
in package
SVG output
Tags
Table of Contents
Constants
- MIME_TYPE = 'image/svg+xml'
Properties
- $circleDiameter : float
- $circleRadius : float
- $connectPaths : bool
- $drawCircularModules : bool
- $drawLightModules : bool
- $eol : string
- $excludeFromConnect : array<string|int, mixed>
- $keepAsSquare : array<string|int, mixed>
- $length : int
- the side length of the QR image (modules * scale)
- $matrix : QRMatrix
- the (filled) data matrix object
- $moduleCount : int
- the current size of the QR matrix
- $moduleValues : array<string|int, mixed>
- an (optional) array of color values for the several QR matrix parts
- $options : SettingsContainerInterface|QROptions
- the options instance
- $scale : int
Methods
- __construct() : mixed
- QROutputAbstract constructor.
- dump() : string
- moduleValueIsValid() : bool
- collectModules() : array<string|int, mixed>
- collects the modules per QRMatrix::M_* type and runs a $transform function on each module and returns an array with the transformed modules
- copyVars() : void
- Creates copies of several QROptions values to avoid calling the magic getters in long loops for a significant performance increase.
- createMarkup() : string
- returns the fully parsed and rendered markup string for the given input
- getCssClass() : string
- returns a string with all css classes for the current element
- getDefaultModuleValue() : mixed
- Returns a default value for either dark or light modules (return value depends on the output class)
- getModuleValue() : mixed
- Returns the prepared value for the given $M_TYPE
- getModuleValueAt() : mixed
- Returns the prepared module value at the given coordinate [$x, $y] (convenience)
- getOutputDimensions() : array<string|int, mixed>
- getViewBox() : string
- returns the value for the SVG viewBox attribute
- header() : string
- returns the <svg> header with the given options parsed
- module() : string
- returns a path segment for a single module
- path() : string
- renders and returns a single <path> element
- paths() : string
- returns one or more SVG <path> elements
- prepareModuleValue() : mixed
- Prepares the value for the given input (return value depends on the output class)
- saveToFile() : void
- Saves the qr $data to a $file. If $file is null, nothing happens.
- setMatrixDimensions() : void
- Sets/updates the matrix dimensions
- setModuleValues() : void
- Sets the initial module values
- toBase64DataURI() : string
- Returns a base64 data URI for the given string and mime type
Constants
MIME_TYPE
public
final mixed
MIME_TYPE
= 'image/svg+xml'
Properties
$circleDiameter
protected
float
$circleDiameter
$circleRadius
protected
float
$circleRadius
Tags
$connectPaths
protected
bool
$connectPaths
Tags
$drawCircularModules
protected
bool
$drawCircularModules
Tags
$drawLightModules
protected
bool
$drawLightModules
Tags
$eol
protected
string
$eol
Tags
$excludeFromConnect
protected
array<string|int, mixed>
$excludeFromConnect
Tags
$keepAsSquare
protected
array<string|int, mixed>
$keepAsSquare
Tags
$length
the side length of the QR image (modules * scale)
protected
int
$length
$matrix
the (filled) data matrix object
protected
QRMatrix
$matrix
$moduleCount
the current size of the QR matrix
protected
int
$moduleCount
Tags
$moduleValues
an (optional) array of color values for the several QR matrix parts
protected
array<string|int, mixed>
$moduleValues
$options
the options instance
protected
SettingsContainerInterface|QROptions
$options
$scale
protected
int
$scale
Tags
Methods
__construct()
QROutputAbstract constructor.
public
__construct(SettingsContainerInterface|QROptions $options, QRMatrix $matrix) : mixed
Parameters
dump()
public
dump([string $file = null ]) : string
Parameters
- $file : string = null
Tags
Return values
stringmoduleValueIsValid()
public
static moduleValueIsValid(mixed $value) : bool
Parameters
- $value : mixed
Tags
Return values
boolcollectModules()
collects the modules per QRMatrix::M_* type and runs a $transform function on each module and returns an array with the transformed modules
protected
collectModules(Closure $transform) : array<string|int, mixed>
The transform callback is called with the following parameters:
$x - current column $y - current row $M_TYPE - field value $M_TYPE_LAYER - (possibly modified) field value that acts as layer id
Parameters
- $transform : Closure
Return values
array<string|int, mixed>copyVars()
Creates copies of several QROptions values to avoid calling the magic getters in long loops for a significant performance increase.
protected
copyVars() : void
These variables are usually used in the "module" methods and are called up to 31329 times (at version 40).
createMarkup()
returns the fully parsed and rendered markup string for the given input
protected
createMarkup(bool $saveToFile) : string
Parameters
- $saveToFile : bool
Tags
Return values
stringgetCssClass()
returns a string with all css classes for the current element
protected
getCssClass([int $M_TYPE = 0 ]) : string
Parameters
- $M_TYPE : int = 0
Tags
Return values
stringgetDefaultModuleValue()
Returns a default value for either dark or light modules (return value depends on the output class)
protected
abstract getDefaultModuleValue(bool $isDark) : mixed
Parameters
- $isDark : bool
getModuleValue()
Returns the prepared value for the given $M_TYPE
protected
getModuleValue(int $M_TYPE) : mixed
Parameters
- $M_TYPE : int
Tags
getModuleValueAt()
Returns the prepared module value at the given coordinate [$x, $y] (convenience)
protected
getModuleValueAt(int $x, int $y) : mixed
Parameters
- $x : int
- $y : int
getOutputDimensions()
protected
getOutputDimensions() : array<string|int, mixed>
Tags
Return values
array<string|int, mixed>getViewBox()
returns the value for the SVG viewBox attribute
protected
getViewBox() : string
Tags
Return values
stringheader()
returns the <svg> header with the given options parsed
protected
header() : string
Tags
Return values
stringmodule()
returns a path segment for a single module
protected
module(int $x, int $y, int $M_TYPE) : string
Parameters
- $x : int
- $y : int
- $M_TYPE : int
Tags
Return values
stringpath()
renders and returns a single <path> element
protected
path(string $path, int $M_TYPE) : string
Parameters
- $path : string
- $M_TYPE : int
Tags
Return values
stringpaths()
returns one or more SVG <path> elements
protected
paths() : string
Return values
stringprepareModuleValue()
Prepares the value for the given input (return value depends on the output class)
protected
abstract prepareModuleValue(mixed $value) : mixed
Parameters
- $value : mixed
saveToFile()
Saves the qr $data to a $file. If $file is null, nothing happens.
protected
saveToFile(string $data[, string $file = null ]) : void
Parameters
- $data : string
- $file : string = null
Tags
setMatrixDimensions()
Sets/updates the matrix dimensions
protected
setMatrixDimensions() : void
Call this method if you modify the matrix from within your custom module in case the dimensions have been changed
setModuleValues()
Sets the initial module values
protected
setModuleValues() : void
toBase64DataURI()
Returns a base64 data URI for the given string and mime type
protected
toBase64DataURI(string $data[, string $mime = null ]) : string
Parameters
- $data : string
- $mime : string = null