Viadeo Twitter Google Bookmarks ! Facebook Digg del.icio.us MySpace Yahoo MyWeb Blinklist Netvouz Reddit Simpy StumbleUpon Bookmarks Windows Live Favorites 
Logo Documentation Qt ·  Page d'accueil  ·  Toutes les classes  ·  Classes principales  ·  Annotées  ·  Classes groupées  ·  Modules  ·  Fonctions  · 

QCameraImageCapture Class

The QCameraImageCapture class is used for the recording of media content. More...

 #include <QCameraImageCapture>

Inherits: QObject and QMediaBindableInterface.

Public Types

enum CaptureDestination { CaptureToFile, CaptureToBuffer }
flags CaptureDestinations
enum DriveMode { SingleImageCapture }
enum Error { NoError, NotReadyError, ResourceError, OutOfSpaceError, NotSupportedFeatureError, FormatError }

Properties

  • 1 property inherited from QObject

Public Functions

QCameraImageCapture(QMediaObject * mediaObject, QObject * parent = 0)
~QCameraImageCapture()
virtual ~QMediaBindableInterface()
QtMultimedia::AvailabilityError availabilityError() const
QVideoFrame::PixelFormat bufferFormat() const
CaptureDestinations captureDestination() const
QImageEncoderSettings encodingSettings() const
Error error() const
QString errorString() const
QString imageCodecDescription(const QString & codec) const
bool isAvailable() const
bool isCaptureDestinationSupported(CaptureDestinations destination) const
bool isReadyForCapture() const
virtual QMediaObject * mediaObject() const = 0
void setBufferFormat(const QVideoFrame::PixelFormat format)
void setCaptureDestination(CaptureDestinations destination)
void setEncodingSettings(const QImageEncoderSettings & settings)
QList<QVideoFrame::PixelFormat> supportedBufferFormats() const
QStringList supportedImageCodecs() const
QList<QSize> supportedResolutions(const QImageEncoderSettings & settings = QImageEncoderSettings(), bool * continuous = 0) const

Reimplemented Public Functions

virtual QMediaObject * mediaObject() const
  • 31 public functions inherited from QObject

Public Slots

void cancelCapture()
int capture(const QString & file = QString())
  • 1 public slot inherited from QObject

Signals

void bufferFormatChanged(QVideoFrame::PixelFormat format)
void captureDestinationChanged(QCameraImageCapture::CaptureDestinations destination)
void error(int id, QCameraImageCapture::Error error, const QString & errorString)
void imageAvailable(int id, const QVideoFrame & buffer)
void imageCaptured(int id, const QImage & preview)
void imageExposed(int id)
void imageMetadataAvailable(int id, const QString & key, const QVariant & value)
void imageSaved(int id, const QString & fileName)
void readyForCaptureChanged(bool ready)

Protected Functions

virtual bool setMediaObject(QMediaObject * object) = 0

Reimplemented Protected Functions

virtual bool setMediaObject(QMediaObject * mediaObject)
  • 9 protected functions inherited from QObject

Additional Inherited Members

  • 11 static public members inherited from QObject

Detailed Description

The QCameraImageCapture class is used for the recording of media content.

The QCameraImageCapture class is a high level images recording class. It's not intended to be used alone but for accessing the media recording functions of other media objects, like QCamera.

 camera = new QCamera;

 viewfinder = new QCameraViewfinder();
 viewfinder->show();

 camera->setViewfinder(viewfinder);

 imageCapture = new QCameraImageCapture(camera);

 camera->setCaptureMode(QCamera::CaptureStillImage);
 camera->start();
 //on half pressed shutter button
 camera->searchAndLock();

 //on shutter button pressed
 imageCapture->capture();

 //on shutter button released
 camera->unlock();

See also QCamera.

Member Type Documentation

enum QCameraImageCapture::CaptureDestination
flags QCameraImageCapture::CaptureDestinations

ConstantValueDescription
QCameraImageCapture::CaptureToFile0x01Capture the image to a file.
QCameraImageCapture::CaptureToBuffer0x02Capture the image to a buffer for further processing.

The CaptureDestinations type is a typedef for QFlags<CaptureDestination>. It stores an OR combination of CaptureDestination values.

enum QCameraImageCapture::DriveMode

ConstantValueDescription
QCameraImageCapture::SingleImageCapture0Drive mode is capturing a single picture.

enum QCameraImageCapture::Error

ConstantValueDescription
QCameraImageCapture::NoError0No Errors.
QCameraImageCapture::NotReadyError1The service is not ready for capture yet.
QCameraImageCapture::ResourceError2Device is not ready or not available.
QCameraImageCapture::OutOfSpaceError3No space left on device.
QCameraImageCapture::NotSupportedFeatureError4Device does not support stillimages capture.
QCameraImageCapture::FormatError5Current format is not supported.

Property Documentation

readyForCapture : const bool

This property holds whether the service is ready to capture a an image immediately.

It's permissible to call capture() while the camera status is QCamera::ActiveStatus regardless of isReadyForCapture property value. If camera is not ready to capture image immediately, the capture request is queued with all the related camera settings to be executed as soon as possible.

Access functions:

bool isReadyForCapture() const

Notifier signal:

void readyForCaptureChanged(bool ready)

Member Function Documentation

QCameraImageCapture::QCameraImageCapture(QMediaObject * mediaObject, QObject * parent = 0)

Constructs a media recorder which records the media produced by mediaObject.

The parent is passed to QMediaObject.

QCameraImageCapture::~QCameraImageCapture()

Destroys images capture object.

QtMultimedia::AvailabilityError QCameraImageCapture::availabilityError() const

Returns the availability error code.

QVideoFrame::PixelFormat QCameraImageCapture::bufferFormat() const

Returns the buffer image capture format being used.

See also supportedBufferFormats() and setBufferFormat().

void QCameraImageCapture::bufferFormatChanged(QVideoFrame::PixelFormat format) [signal]

Signal emitted when the buffer format for the buffer image capture has changed.

void QCameraImageCapture::cancelCapture() [slot]

Cancel incomplete capture requests. Already captured and queused for proicessing images may be discarded.

int QCameraImageCapture::capture(const QString & file = QString()) [slot]

Capture the image and save it to file. This operation is asynchronous in majority of cases, followed by signals QCameraImageCapture::imageExposed(), QCameraImageCapture::imageCaptured(), QCameraImageCapture::imageSaved() or QCameraImageCapture::error().

If an empty file is passed, the camera backend choses the default location and naming scheme for photos on the system, if only file name without full path is specified, the image will be saved to the default directory, with a full path reported with imageCaptured() and imageSaved() signals.

QCamera saves all the capture parameters like exposure settings or image processing parameters, so changes to camera paramaters after capture() is called do not affect previous capture requests.

QCameraImageCapture::capture returns the capture Id parameter, used with imageExposed(), imageCaptured() and imageSaved() signals.

CaptureDestinations QCameraImageCapture::captureDestination() const

Returns the image capture destination being used.

See also isCaptureDestinationSupported() and setCaptureDestination().

void QCameraImageCapture::captureDestinationChanged(QCameraImageCapture::CaptureDestinations destination) [signal]

Signal emitted when the capture destination has changed.

QImageEncoderSettings QCameraImageCapture::encodingSettings() const

Returns the image encoder settings being used.

See also setEncodingSettings().

Error QCameraImageCapture::error() const

Returns the current error state.

See also errorString().

void QCameraImageCapture::error(int id, QCameraImageCapture::Error error, const QString & errorString) [signal]

Signals that the capture request id has failed with an error and errorString description.

QString QCameraImageCapture::errorString() const

Returns a string describing the current error state.

See also error().

void QCameraImageCapture::imageAvailable(int id, const QVideoFrame & buffer) [signal]

Signal emitted when the frame with request id is available as buffer.

void QCameraImageCapture::imageCaptured(int id, const QImage & preview) [signal]

Signal emitted when the frame with request id was captured, but not processed and saved yet. Frame preview can be displayed to user.

QString QCameraImageCapture::imageCodecDescription(const QString & codec) const

Returns a description of an image codec.

void QCameraImageCapture::imageExposed(int id) [signal]

Signal emitted when the frame with request id was exposed.

void QCameraImageCapture::imageMetadataAvailable(int id, const QString & key, const QVariant & value) [signal]

Signals that a metadata for an image with request id is available. Also includes the key and value of the metadata.

This signal is emitted between imageExposed and imageSaved signals.

void QCameraImageCapture::imageSaved(int id, const QString & fileName) [signal]

Signal emitted when the frame with request id was saved to fileName.

bool QCameraImageCapture::isAvailable() const

Returns true if the images capture service ready to use.

bool QCameraImageCapture::isCaptureDestinationSupported(CaptureDestinations destination) const

Returns true if the image capture destination is supported; otherwise returns false.

See also captureDestination() and setCaptureDestination().

QMediaObject * QCameraImageCapture::mediaObject() const [virtual]

Reimplemented from QMediaBindableInterface::mediaObject().

See also setMediaObject().

void QCameraImageCapture::setBufferFormat(const QVideoFrame::PixelFormat format)

Sets the buffer image capture format to be used.

See also bufferFormat(), supportedBufferFormats(), and captureDestination().

void QCameraImageCapture::setCaptureDestination(CaptureDestinations destination)

Sets the capture destination to be used.

See also isCaptureDestinationSupported() and captureDestination().

void QCameraImageCapture::setEncodingSettings(const QImageEncoderSettings & settings)

Sets the image encoding settings.

If some parameters are not specified, or null settings are passed, the encoder choose the default encoding parameters.

See also encodingSettings().

bool QCameraImageCapture::setMediaObject(QMediaObject * mediaObject) [virtual protected]

Reimplemented from QMediaBindableInterface::setMediaObject().

See also mediaObject().

QList<QVideoFrame::PixelFormat> QCameraImageCapture::supportedBufferFormats() const

Returns the list of supported buffer image capture formats.

See also bufferFormat() and setBufferFormat().

QStringList QCameraImageCapture::supportedImageCodecs() const

Returns a list of supported image codecs.

QList<QSize> QCameraImageCapture::supportedResolutions(const QImageEncoderSettings & settings = QImageEncoderSettings(), bool * continuous = 0) const

Returns a list of resolutions images can be encoded at.

If non null image settings parameter is passed, the returned list is reduced to resolution supported with partial settings like image codec or quality applied.

If the encoder supports arbitrary resolutions within the supported range, *continuous is set to true, otherwise *continuous is set to false.

See also QImageEncoderSettings::resolution().

Cette page est une traduction d'une page de la documentation de Qt, écrite par Nokia Corporation and/or its subsidiary(-ies). Les éventuels problèmes résultant d'une mauvaise traduction ne sont pas imputables à Nokia. Qt 5.0-snapshot
Copyright © 2012 Developpez LLC. Tous droits réservés Developpez LLC. Aucune reproduction, même partielle, ne peut être faite de ce site et de l'ensemble de son contenu : textes, documents et images sans l'autorisation expresse de Developpez LLC. Sinon, vous encourez selon la loi jusqu'à 3 ans de prison et jusqu'à 300 000 E de dommages et intérêts. Cette page est déposée à la SACD.
Vous avez déniché une erreur ? Un bug ? Une redirection cassée ? Ou tout autre problème, quel qu'il soit ? Ou bien vous désirez participer à ce projet de traduction ? N'hésitez pas à nous contacter ou par MP !
 
 
 
 
Partenaires

Hébergement Web