Qt
Internal/Contributor docs for the Qt SDK. <b>Note:</b> These are NOT official API docs; those are found <a href='https://doc.qt.io/'>here</a>.
Loading...
Searching...
No Matches
QICNSHandler Class Reference

#include <qicnshandler_p.h>

+ Inheritance diagram for QICNSHandler:
+ Collaboration diagram for QICNSHandler:

Public Member Functions

 QICNSHandler ()
 
bool canRead () const override
 Returns true if an image can be read from the device (i.e., the image format is supported, the device can be read from and the initial header information suggests that the image can be read); otherwise returns false.
 
bool read (QImage *image) override
 Read an image from the device, and stores it in image.
 
bool write (const QImage &image) override
 Writes the image image to the assigned device.
 
bool supportsOption (ImageOption option) const override
 Returns true if the QImageIOHandler supports the option option; otherwise returns false.
 
QVariant option (ImageOption option) const override
 Returns the value assigned to option as a QVariant.
 
int imageCount () const override
 For image formats that support animation, this function returns the number of images in the animation.
 
bool jumpToImage (int imageNumber) override
 For image formats that support animation, this function jumps to the image whose sequence number is imageNumber.
 
bool jumpToNextImage () override
 For image formats that support animation, this function jumps to the next image.
 
- Public Member Functions inherited from QImageIOHandler
 QImageIOHandler ()
 Constructs a QImageIOHandler object.
 
virtual ~QImageIOHandler ()
 Destructs the QImageIOHandler object.
 
void setDevice (QIODevice *device)
 Sets the device of the QImageIOHandler to device.
 
QIODevicedevice () const
 Returns the device currently assigned to the QImageIOHandler.
 
void setFormat (const QByteArray &format)
 Sets the format of the QImageIOHandler to format.
 
void setFormat (const QByteArray &format) const
 Sets the format of the QImageIOHandler to format.
 
QByteArray format () const
 Returns the format that is currently assigned to QImageIOHandler.
 
virtual void setOption (ImageOption option, const QVariant &value)
 Sets the option option with the value value.
 
virtual int loopCount () const
 For image formats that support animation, this function returns the number of times the animation should loop.
 
virtual int nextImageDelay () const
 For image formats that support animation, this function returns the number of milliseconds to wait until reading the next image.
 
virtual int currentImageNumber () const
 For image formats that support animation, this function returns the sequence number of the current image in the animation.
 
virtual QRect currentImageRect () const
 Returns the rect of the current image.
 

Static Public Member Functions

static bool canRead (QIODevice *device)
 
- Static Public Member Functions inherited from QImageIOHandler
static bool allocateImage (QSize size, QImage::Format format, QImage *image)
 

Additional Inherited Members

- Public Types inherited from QImageIOHandler
enum  ImageOption {
  Size , ClipRect , Description , ScaledClipRect ,
  ScaledSize , CompressionRatio , Gamma , Quality ,
  Name , SubType , IncrementalReading , Endianness ,
  Animation , BackgroundColor , ImageFormat , SupportedSubTypes ,
  OptimizedWrite , ProgressiveScanWrite , ImageTransformation
}
 This enum describes the different options supported by QImageIOHandler. More...
 
enum  Transformation {
  TransformationNone = 0 , TransformationMirror = 1 , TransformationFlip = 2 , TransformationRotate180 = TransformationMirror | TransformationFlip ,
  TransformationRotate90 = 4 , TransformationMirrorAndRotate90 = TransformationMirror | TransformationRotate90 , TransformationFlipAndRotate90 = TransformationFlip | TransformationRotate90 , TransformationRotate270 = TransformationRotate180 | TransformationRotate90
}
 
- Protected Member Functions inherited from QImageIOHandler
 QImageIOHandler (QImageIOHandlerPrivate &dd)
 
- Protected Attributes inherited from QImageIOHandler
QScopedPointer< QImageIOHandlerPrivated_ptr
 

Detailed Description

Definition at line 90 of file qicnshandler_p.h.

Constructor & Destructor Documentation

◆ QICNSHandler()

QICNSHandler::QICNSHandler ( )

Definition at line 626 of file qicnshandler.cpp.

Member Function Documentation

◆ canRead() [1/2]

bool QICNSHandler::canRead ( ) const
overridevirtual

Returns true if an image can be read from the device (i.e., the image format is supported, the device can be read from and the initial header information suggests that the image can be read); otherwise returns false.

When reimplementing canRead(), make sure that the I/O device (device()) is left in its original state (e.g., by using peek() rather than read()).

See also
read(), QIODevice::peek()

Implements QImageIOHandler.

Definition at line 649 of file qicnshandler.cpp.

References canRead(), QImageIOHandler::device(), QByteArrayLiteral, and QImageIOHandler::setFormat().

Referenced by canRead(), and QICNSPlugin::capabilities().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ canRead() [2/2]

bool QICNSHandler::canRead ( QIODevice * device)
static

Definition at line 631 of file qicnshandler.cpp.

References QImageIOHandler::device(), QIODevice::isReadable(), QIODevice::isSequential(), QIODevice::peek(), QByteArrayLiteral, and qWarning.

+ Here is the call graph for this function:

◆ imageCount()

int QICNSHandler::imageCount ( ) const
overridevirtual

For image formats that support animation, this function returns the number of images in the animation.

If the image format does not support animation, or if it is unable to determine the number of images, 0 is returned.

The default implementation returns 1 if canRead() returns true; otherwise 0 is returned.

Reimplemented from QImageIOHandler.

Definition at line 799 of file qicnshandler.cpp.

References QList< T >::size().

Referenced by jumpToImage(), and option().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ jumpToImage()

bool QICNSHandler::jumpToImage ( int imageNumber)
overridevirtual

For image formats that support animation, this function jumps to the image whose sequence number is imageNumber.

The next call to read() will attempt to read this image.

The default implementation does nothing, and returns false.

Reimplemented from QImageIOHandler.

Definition at line 807 of file qicnshandler.cpp.

References imageCount().

Referenced by jumpToNextImage().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ jumpToNextImage()

bool QICNSHandler::jumpToNextImage ( )
overridevirtual

For image formats that support animation, this function jumps to the next image.

The default implementation does nothing, and returns false.

Reimplemented from QImageIOHandler.

Definition at line 816 of file qicnshandler.cpp.

References jumpToImage().

+ Here is the call graph for this function:

◆ option()

QVariant QICNSHandler::option ( ImageOption option) const
overridevirtual

Returns the value assigned to option as a QVariant.

The type of the value depends on the option. For example, option(Size) returns a QSize variant.

See also
setOption(), supportsOption()

Reimplemented from QImageIOHandler.

Definition at line 782 of file qicnshandler.cpp.

References QList< T >::at(), icon, imageCount(), nameFromOSType(), QByteArray(), QImageIOHandler::SubType, and supportsOption().

+ Here is the call graph for this function:

◆ read()

bool QICNSHandler::read ( QImage * image)
overridevirtual

Read an image from the device, and stores it in image.

Returns true if the image is successfully read; otherwise returns false.

For image formats that support incremental loading, and for animation formats, the image handler can assume that image points to the previous frame.

See also
canRead()

Implements QImageIOHandler.

Definition at line 662 of file qicnshandler.cpp.

References QList< T >::at(), QDataStream::BigEndian, ICNSEntry::Depth32bit, ICNSEntry::Depth4bit, ICNSEntry::Depth8bit, ICNSEntry::DepthMono, QImageIOHandler::device(), QImage::fromData(), icon, ICNSEntry::JP2, nameFromOSType(), ICNSEntry::PNG, qMin(), qWarning, ICNSEntry::RawIcon, read(), read32bitIcon(), readMask(), ICNSEntry::RLE24, and QList< T >::size().

Referenced by read().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ supportsOption()

bool QICNSHandler::supportsOption ( ImageOption option) const
overridevirtual

Returns true if the QImageIOHandler supports the option option; otherwise returns false.

For example, if the QImageIOHandler supports the \l Size option, supportsOption(Size) must return true.

See also
setOption(), option()

Reimplemented from QImageIOHandler.

Definition at line 777 of file qicnshandler.cpp.

References QImageIOHandler::SubType.

Referenced by option().

+ Here is the caller graph for this function:

◆ write()

bool QICNSHandler::write ( const QImage & image)
overridevirtual

Writes the image image to the assigned device.

Returns true on success; otherwise returns false.

The default implementation does nothing, and simply returns false.

Reimplemented from QImageIOHandler.

Definition at line 724 of file qicnshandler.cpp.

References QByteArray::constData(), QImageIOHandler::device(), ICNSBlockHeaderSize, Qt::IgnoreAspectRatio, imageData, isBlockHeaderValid(), QIODevice::isWritable(), ICNSBlockHeader::length, nameForCompressedIcon(), nameToOSType(), ICNSBlockHeader::ostype, qMax(), qMin(), QByteArray::size(), Qt::SmoothTransformation, ICNSBlockHeader::TypeIcns, ICNSBlockHeader::TypeToc, and QIODeviceBase::WriteOnly.

+ Here is the call graph for this function:

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