MediaWiki master
BitmapHandler Class Reference

Generic handler for bitmap images. More...

Inherits TransformationalImageHandler.

Inherited by BitmapHandler_ClientOnly, BmpHandler, ExifBitmapHandler, GIFHandler, Jpeg2000Handler, PNGHandler, WebPHandler, and XCFHandler.

Collaboration diagram for BitmapHandler:

Public Member Functions

 autoRotateEnabled ()
 
 canRotate ()
 Returns whether the current scaler supports rotation (im and gd do)
 
 makeParamString ( $params)
 Merge a parameter array into a string appropriate for inclusion in filenames.
Parameters
array$paramsArray of parameters that have been through normaliseParams.
Returns
string
Stability: stable
to override
Exceptions
MediaTransformInvalidParametersException

 
 normaliseParams ( $image, &$params)
 
 parseParamString ( $str)
 Parse a param string made with makeParamString back into an array.
Parameters
string$strThe parameter string without file name (e.g. 122px)
Returns
array|false Array of parameters or false on failure.
Stability: stable
to override

 
 rotate ( $file, $params)
 
 validateParam ( $name, $value)
 Validate a thumbnail parameter at parse time.Return true to accept the parameter, and false to reject it. If you return false, the parser will do something quiet and forgiving.
Parameters
string$name
mixed$value
Returns
bool
Stability: stable
to override

 
- Public Member Functions inherited from TransformationalImageHandler
 doTransform ( $image, $dstPath, $dstUrl, $params, $flags=0)
 Create a thumbnail.
 
 extractPreRotationDimensions ( $params, $rotation)
 Extracts the width/height if the image will be scaled before rotating.
 
 getMediaTransformError ( $params, $errMsg)
 Get a MediaTransformError with error 'thumbnail_error'.
 
 isImageAreaOkForThumbnaling ( $file, &$params)
 Check if the file is smaller than the maximum image area for thumbnailing.
 
 mustRender ( $file)
 Returns whether the file needs to be rendered.
 
- Public Member Functions inherited from ImageHandler
 canRender ( $file)
 True if the handled types can be transformed.
Stability: stable
to override
Parameters
File$file
Returns
bool

 
 getDimensionsString ( $file)
 Shown in file history box on image description page.
Stability: stable
to override
Parameters
File$file
Returns
string Dimensions

 
 getImageArea ( $image)
 Function that returns the number of pixels to be thumbnailed.
 
 getImageSize ( $image, $path)
 Get an image size array like that returned by getimagesize(), or false if it can't be determined.
 
 getLongDesc ( $file)
 Long description.Shown under image on image description page surrounded by ().
Stability: stable
to override
Parameters
File$file
Returns
string

 
 getParamMap ()
 Get an associative array mapping magic word IDs to parameter names.Will be used by the parser to identify parameters.

Returns
string[]

 
 getScriptedTransform ( $image, $script, $params)
 Get a MediaTransformOutput object representing an alternate of the transformed output which will call an intermediary thumbnail assist script.Used when the repository has a thumbnailScriptUrl option configured.Return false to fall back to the regular getTransform().
Stability: stable
to override
Parameters
File$image
string$script
array$params
Returns
ThumbnailImage|false

 
 getShortDesc ( $file)
 Short description.Shown on Special:Search results.
Stability: stable
to override
Parameters
File$file
Returns
string

 
 getSizeAndMetadata ( $state, $path)
 Get image size information and metadata array.
 
 sanitizeParamsForBucketing ( $params)
 Returns a normalised params array for which parameters have been cleaned up for bucketing purposes.
Stability: stable
to override
Parameters
array$params
Returns
array

 
- Public Member Functions inherited from MediaHandler
 canAnimateThumbnail ( $file)
 If the material is animated, we can animate the thumbnail.
 
 convertMetadataVersion ( $metadata, $version=1)
 Convert metadata version.
 
 filterThumbnailPurgeList (&$files, $options)
 Remove files from the purge list.
 
 formatMetadata ( $image, $context=false)
 Get an array structure that looks like this:
 
 getAvailableLanguages (File $file)
 Get list of languages file can be viewed in.
 
 getCommonMetaArray (File $file)
 Get an array of standard (FormatMetadata type) metadata values.
 
 getContentHeaders ( $metadata)
 Get useful response headers for GET/HEAD requests for a file with the given metadata.
 
 getDefaultRenderLanguage (File $file)
 On file types that support renderings in multiple languages, which language is used by default if unspecified.
 
 getEntireText (File $file)
 Get the text of the entire document.
 
 getLength ( $file)
 If it's an audio file, return the length of the file.
 
 getMatchedLanguage ( $userPreferredLanguage, array $availableLanguages)
 When overridden in a descendant class, returns a language code most suiting.
 
 getMetadata ( $image, $path)
 Get handler-specific metadata which will be saved in the img_metadata field.
 
 getMetadataType ( $image)
 Get a string describing the type of metadata, for display purposes.
 
 getPageDimensions (File $image, $page)
 Get an associative array of page dimensions Currently "width" and "height" are understood, but this might be expanded in the future.
 
 getPageText (File $image, $page)
 Generic getter for text layer.
 
 getRotation ( $file)
 On supporting image formats, try to read out the low-level orientation of the file and return the angle that the file needs to be rotated to be viewed.
 
 getSizeAndMetadataWithFallback ( $file, $path)
 Get the metadata array and the image size, with b/c fallback.
 
 getThumbType ( $ext, $mime, $params=null)
 Get the thumbnail extension and MIME type for a given source MIME type.
 
 getTransform ( $image, $dstPath, $dstUrl, $params)
 Get a MediaTransformOutput object representing the transformed output.
 
 getWarningConfig ( $file)
 Gets configuration for the file warning message.
 
 isAnimatedImage ( $file)
 The material is an image, and is animated.
 
 isEnabled ()
 False if the handler is disabled for all files.
 
 isExpensiveToThumbnail ( $file)
 True if creating thumbnails from the file is large or otherwise resource-intensive.
 
 isFileMetadataValid ( $image)
 Check if the metadata is valid for this handler.
 
 isMetadataValid ( $image, $metadata)
 Check if the metadata string is valid for this handler.
 
 isMultiPage ( $file)
 True if the type has multi-page capabilities.
 
 isVectorized ( $file)
 The material is vectorized and thus scaling is lossless.
 
 pageCount (File $file)
 Page count for a multi-page document, false if unsupported or unknown.
 
 parserTransformHook ( $parser, $file)
 Modify the parser object post-transform.
 
 removeBadFile ( $dstPath, $retval=0)
 Check for zero-sized thumbnails.
 
 supportsBucketing ()
 Returns whether or not this handler supports the chained generation of thumbnails according to buckets.
 
 useSplitMetadata ()
 If this returns true, LocalFile may split metadata up and store its constituent items separately.
 
 verifyUpload ( $fileName)
 File validation hook called on upload.
 

Static Public Member Functions

static imageJpegWrapper ( $dst_image, $thumbPath, $quality=null)
 Callback for transformGd when transforming jpeg images.
 
- Static Public Member Functions inherited from MediaHandler
static fitBoxWidth ( $boxWidth, $boxHeight, $maxHeight)
 Calculate the largest thumbnail width for a given original file size such that the thumbnail's height is at most $maxHeight.
 
static getGeneralLongDesc ( $file)
 Used instead of getLongDesc if there is no handler registered for file.
 
static getGeneralShortDesc ( $file)
 Used instead of getShortDesc if there is no handler registered for file.
 
static getHandler ( $type)
 Get a MediaHandler for a given MIME type from the instance cache.
 
static getMetadataVersion ()
 Get metadata version.
 
static getPageRangesByDimensions ( $pagesByDimensions)
 Converts a dimensions array about a potentially multipage document from an exhaustive list of ordered page numbers to a list of page ranges.
 

Protected Member Functions

 getScalerType ( $dstPath, $checkDstPath=true)
 Returns which scaler type should be used.
 
 imageMagickSubsampling ( $pixelFormat)
 Get ImageMagick subsampling factors for the target JPEG pixel format.
 
 transformCustom ( $image, $params)
 Transform an image using a custom command.
 
 transformGd ( $image, $params)
 Transform an image using the built in GD library.
 
 transformImageMagick ( $image, $params)
 Transform an image using ImageMagick.
 
 transformImageMagickExt ( $image, $params)
 Transform an image using the Imagick PHP extension.
 
- Protected Member Functions inherited from TransformationalImageHandler
 escapeMagickInput ( $path, $scene=false)
 Escape a string for ImageMagick's input filenames.
 
 escapeMagickOutput ( $path, $scene=false)
 Escape a string for ImageMagick's output filename.
 
 escapeMagickPath ( $path, $scene=false)
 Armour a string against ImageMagick's GetPathComponent().
 
 escapeMagickProperty ( $s)
 Escape a string for ImageMagick's property input (e.g.
 
 getClientScalingThumbnailImage ( $image, $scalerParams)
 Get a ThumbnailImage that respresents an image that will be scaled client side.
 
 getMagickVersion ()
 Retrieve the version of the installed ImageMagick You can use PHPs version_compare() to use this value Value is cached for one hour.
 
 getThumbnailSource ( $file, $params)
 Get the source file for the transform.
 
- Protected Member Functions inherited from ImageHandler
 getScriptParams ( $params)
 
- Protected Member Functions inherited from MediaHandler
 formatMetadataHelper ( $metadataArray, $context=false)
 sorts the visible/invisible field.
 
 formatTag (string $key, $vals, $context=false)
 Override default formatting for the given metadata field.
 
 hasMostDerivedMethod ( $name)
 Check whether a method is implemented in the most derived class.
 
 logErrorForExternalProcess ( $retval, $err, $cmd)
 Log an error that occurred in an external process.
 
 useLegacyMetadata ()
 If this returns true, the new method getSizeAndMetadata() will not be called.
 
 visibleMetadataFields ()
 Get a list of metadata items which should be displayed when the metadata table is collapsed.
 

Additional Inherited Members

- Public Attributes inherited from MediaHandler
const METADATA_BAD = false
 
const METADATA_COMPATIBLE = 2
 
const METADATA_GOOD = true
 
const TRANSFORM_LATER = 1
 
- Static Protected Member Functions inherited from MediaHandler
static addMeta (&$array, $visibility, $type, $id, $value, $param=false)
 This is used to generate an array element for each metadata value That array is then used to generate the table of metadata values on the image page.
 

Detailed Description

Generic handler for bitmap images.

Stability: stable
to extend

Definition at line 34 of file BitmapHandler.php.

Member Function Documentation

◆ autoRotateEnabled()

BitmapHandler::autoRotateEnabled ( )
See also
$wgEnableAutoRotation
Stability: stable
to override
Returns
bool Whether auto rotation is enabled

Reimplemented from TransformationalImageHandler.

Definition at line 559 of file BitmapHandler.php.

References canRotate().

Referenced by ExifBitmapHandler\applyExifRotation(), and ExifBitmapHandler\getRotation().

◆ canRotate()

BitmapHandler::canRotate ( )

Returns whether the current scaler supports rotation (im and gd do)

Stability: stable
to override
Returns
bool

Reimplemented from TransformationalImageHandler.

Definition at line 535 of file BitmapHandler.php.

References getScalerType().

Referenced by autoRotateEnabled().

◆ getScalerType()

BitmapHandler::getScalerType ( $dstPath,
$checkDstPath = true )
protected

Returns which scaler type should be used.

Creates parent directories for $dstPath and returns 'client' on error

Stability: stable
to override
Parameters
string | null$dstPath
bool$checkDstPath
Returns
string|callable One of client, im, custom, gd, imext or an array( object, method )

Reimplemented from TransformationalImageHandler.

Reimplemented in WebPHandler, and XCFHandler.

Definition at line 45 of file BitmapHandler.php.

Referenced by canRotate(), and rotate().

◆ imageJpegWrapper()

static BitmapHandler::imageJpegWrapper ( $dst_image,
$thumbPath,
$quality = null )
static

Callback for transformGd when transforming jpeg images.

@phpcs:ignore MediaWiki.Commenting.FunctionComment.ObjectTypeHintParam

Parameters
resource | object$dst_imageImage resource of the original image
string$thumbPathFile path to write the thumbnail image to
int | null$qualityQuality of the thumbnail from 1-100, or null to use default quality.

Definition at line 522 of file BitmapHandler.php.

◆ imageMagickSubsampling()

BitmapHandler::imageMagickSubsampling ( $pixelFormat)
protected

Get ImageMagick subsampling factors for the target JPEG pixel format.

Parameters
string$pixelFormatone of 'yuv444', 'yuv422', 'yuv420'
Returns
string[] List of sampling factors

Definition at line 133 of file BitmapHandler.php.

Referenced by transformImageMagick(), and transformImageMagickExt().

◆ makeParamString()

BitmapHandler::makeParamString ( $params)

Merge a parameter array into a string appropriate for inclusion in filenames.

Parameters
array$paramsArray of parameters that have been through normaliseParams.
Returns
string
Stability: stable
to override
Exceptions
MediaTransformInvalidParametersException

Stability: stable
to override

Reimplemented from ImageHandler.

Reimplemented in JpegHandler.

Definition at line 74 of file BitmapHandler.php.

References $params.

◆ normaliseParams()

BitmapHandler::normaliseParams ( $image,
& $params )
Stability: stable
to override
Parameters
File$image
array&$params
Returns
bool

Reimplemented from TransformationalImageHandler.

Reimplemented in BitmapHandler_ClientOnly, and JpegHandler.

Definition at line 113 of file BitmapHandler.php.

References $params, and ImageHandler\getImageArea().

◆ parseParamString()

BitmapHandler::parseParamString ( $str)

Parse a param string made with makeParamString back into an array.

Parameters
string$strThe parameter string without file name (e.g. 122px)
Returns
array|false Array of parameters or false on failure.
Stability: stable
to override

Stability: stable
to override

Reimplemented from ImageHandler.

Reimplemented in JpegHandler.

Definition at line 86 of file BitmapHandler.php.

References $params.

◆ rotate()

BitmapHandler::rotate ( $file,
$params )
Stability: stable
to override
Parameters
File$file
array$paramsRotate parameters. 'rotation' clockwise rotation in degrees, allowed are multiples of 90
Since
1.21
Returns
MediaTransformError|false

Reimplemented from TransformationalImageHandler.

Reimplemented in JpegHandler.

Definition at line 579 of file BitmapHandler.php.

References $params, TransformationalImageHandler\escapeMagickInput(), TransformationalImageHandler\escapeMagickOutput(), MediaHandler\getRotation(), getScalerType(), MediaHandler\logErrorForExternalProcess(), wfDebug(), and wfShellExecWithStderr().

◆ transformCustom()

BitmapHandler::transformCustom ( $image,
$params )
protected

Transform an image using a custom command.

Parameters
File$imageFile associated with this thumbnail
array$paramsArray with scaler params
Returns
MediaTransformError|false Error object if error occurred, false (=no error) otherwise

Reimplemented from TransformationalImageHandler.

Definition at line 383 of file BitmapHandler.php.

References $params, TransformationalImageHandler\getMediaTransformError(), MediaHandler\logErrorForExternalProcess(), wfDebug(), and wfShellExecWithStderr().

◆ transformGd()

BitmapHandler::transformGd ( $image,
$params )
protected

Transform an image using the built in GD library.

Parameters
File$imageFile associated with this thumbnail
array$paramsArray with scaler params
Returns
MediaTransformError|false Error object if error occurred, false (=no error) otherwise

Reimplemented from TransformationalImageHandler.

Definition at line 417 of file BitmapHandler.php.

References $params, TransformationalImageHandler\extractPreRotationDimensions(), TransformationalImageHandler\getMediaTransformError(), MediaHandler\getRotation(), wfDebug(), and wfMessage().

◆ transformImageMagick()

BitmapHandler::transformImageMagick ( $image,
$params )
protected

Transform an image using ImageMagick.

Stability: stable
to override
Parameters
File$imageFile associated with this thumbnail
array$paramsArray with scaler params
Returns
MediaTransformError|false Error object if error occurred, false (=no error) otherwise

Reimplemented from TransformationalImageHandler.

Reimplemented in JpegHandler.

Definition at line 155 of file BitmapHandler.php.

References $params, TransformationalImageHandler\escapeMagickInput(), TransformationalImageHandler\escapeMagickOutput(), TransformationalImageHandler\escapeMagickProperty(), TransformationalImageHandler\extractPreRotationDimensions(), ImageHandler\getImageArea(), TransformationalImageHandler\getMediaTransformError(), MediaHandler\getRotation(), imageMagickSubsampling(), MediaHandler\isAnimatedImage(), MediaHandler\logErrorForExternalProcess(), wfDebug(), and wfShellExecWithStderr().

◆ transformImageMagickExt()

BitmapHandler::transformImageMagickExt ( $image,
$params )
protected

Transform an image using the Imagick PHP extension.

Parameters
File$imageFile associated with this thumbnail
array$paramsArray with scaler params
Returns
MediaTransformError|false Error object if error occurred, false (=no error) otherwise

Reimplemented from TransformationalImageHandler.

Definition at line 290 of file BitmapHandler.php.

References $params, TransformationalImageHandler\extractPreRotationDimensions(), ImageHandler\getImageArea(), TransformationalImageHandler\getMediaTransformError(), MediaHandler\getRotation(), imageMagickSubsampling(), MediaHandler\isAnimatedImage(), and wfDebug().

◆ validateParam()

BitmapHandler::validateParam ( $name,
$value )

Validate a thumbnail parameter at parse time.Return true to accept the parameter, and false to reject it. If you return false, the parser will do something quiet and forgiving.

Parameters
string$name
mixed$value
Returns
bool
Stability: stable
to override

Stability: stable
to override

Reimplemented from ImageHandler.

Reimplemented in JpegHandler.

Definition at line 100 of file BitmapHandler.php.


The documentation for this class was generated from the following file: