QCamera Class

QCameraクラスは、システム・カメラ・デバイス用のインターフェースを提供します。詳細...

Header: #include <QCamera>
CMake: find_package(Qt6 REQUIRED COMPONENTS Multimedia)
target_link_libraries(mytarget PRIVATE Qt6::Multimedia)
qmake: QT += multimedia
In QML: Camera
Inherits: QObject

パブリック・タイプ

enum Error { NoError, CameraError }
enum ExposureMode { ExposureAuto, ExposureManual, ExposurePortrait, ExposureNight, ExposureSports, …, ExposureBarcode }
enum class Feature { ColorTemperature, ExposureCompensation, IsoSensitivity, ManualExposureTime, CustomFocusPoint, FocusDistance }
flags Features
enum FlashMode { FlashOff, FlashOn, FlashAuto }
enum FocusMode { FocusModeAuto, FocusModeAutoNear, FocusModeAutoFar, FocusModeHyperfocal, FocusModeInfinity, FocusModeManual }
enum TorchMode { TorchOff, TorchOn, TorchAuto }
enum WhiteBalanceMode { WhiteBalanceAuto, WhiteBalanceManual, WhiteBalanceSunlight, WhiteBalanceCloudy, WhiteBalanceShade, …, WhiteBalanceSunset }

プロパティ

パブリック関数

QCamera(QObject *parent = nullptr)
QCamera(QCameraDevice::Position position, QObject *parent = nullptr)
QCamera(const QCameraDevice &cameraDevice, QObject *parent = nullptr)
virtual ~QCamera()
QCameraDevice cameraDevice() const
QCameraFormat cameraFormat() const
QMediaCaptureSession *captureSession() const
int colorTemperature() const
QPointF customFocusPoint() const
QCamera::Error error() const
QString errorString() const
float exposureCompensation() const
QCamera::ExposureMode exposureMode() const
float exposureTime() const
QCamera::FlashMode flashMode() const
float focusDistance() const
QCamera::FocusMode focusMode() const
QPointF focusPoint() const
bool isActive() const
bool isAvailable() const
bool isExposureModeSupported(QCamera::ExposureMode mode) const
bool isFlashModeSupported(QCamera::FlashMode mode) const
bool isFlashReady() const
bool isFocusModeSupported(QCamera::FocusMode mode) const
bool isTorchModeSupported(QCamera::TorchMode mode) const
bool isWhiteBalanceModeSupported(QCamera::WhiteBalanceMode mode) const
int isoSensitivity() const
float manualExposureTime() const
int manualIsoSensitivity() const
float maximumExposureTime() const
int maximumIsoSensitivity() const
float maximumZoomFactor() const
float minimumExposureTime() const
int minimumIsoSensitivity() const
float minimumZoomFactor() const
void setCameraDevice(const QCameraDevice &cameraDevice)
void setCameraFormat(const QCameraFormat &format)
void setCustomFocusPoint(const QPointF &point)
void setFocusDistance(float d)
void setFocusMode(QCamera::FocusMode mode)
void setZoomFactor(float factor)
QCamera::Features supportedFeatures() const
QCamera::TorchMode torchMode() const
QCamera::WhiteBalanceMode whiteBalanceMode() const
float zoomFactor() const

パブリックスロット

void setActive(bool active)
void setAutoExposureTime()
void setAutoIsoSensitivity()
void setColorTemperature(int colorTemperature)
void setExposureCompensation(float ev)
void setExposureMode(QCamera::ExposureMode mode)
void setFlashMode(QCamera::FlashMode mode)
void setManualExposureTime(float seconds)
void setManualIsoSensitivity(int iso)
void setTorchMode(QCamera::TorchMode mode)
void setWhiteBalanceMode(QCamera::WhiteBalanceMode mode)
void start()
void stop()
void zoomTo(float factor, float rate)

シグナル

void activeChanged(bool)
void cameraDeviceChanged()
void cameraFormatChanged()
void colorTemperatureChanged() const
void customFocusPointChanged()
void errorChanged()
void errorOccurred(QCamera::Error error, const QString &errorString)
void exposureCompensationChanged(float value)
void exposureModeChanged()
void exposureTimeChanged(float speed)
void flashModeChanged()
void flashReady(bool ready)
void focusDistanceChanged(float)
void focusModeChanged()
void focusPointChanged()
void isoSensitivityChanged(int value)
void manualExposureTimeChanged(float speed)
void manualIsoSensitivityChanged(int)
void maximumZoomFactorChanged(float)
void minimumZoomFactorChanged(float)
void supportedFeaturesChanged()
void torchModeChanged()
void whiteBalanceModeChanged() const
void zoomFactorChanged(float)

詳細説明

QCameraはQMediaCaptureSession 、ビデオ録画や画像撮影に使用できます。

QCameraDevice 、使用可能なカメラを一覧表示し、使用するカメラを選択できます。

const QList<QCameraDevice> cameras = QMediaDevices::videoInputs();
for (const QCameraDevice &cameraDevice : cameras) {
    if (cameraDevice.description() == "mycamera")
        camera = new QCamera(cameraDevice);
}

QCameraをサポートしているハードウェアでは、フォーカスとズームを調整できます。また、近接作業(バーコードの読み取りや文字の認識など)用の「マクロ」モードや、「タッチでフォーカス」(ハードウェアがフォーカスを合わせようとする画像の興味深い部分を示す)などの機能もあります。

camera->setFocusPointMode(QCamera::FocusModeManual);
camera->setCustomFocusPoint(QPointF(0.25f, 0.75f)); // A point near the bottom left, 25% away from the corner, near that shiny vase

minimumZoomFactor() およびmaximumZoomFactor() メソッドは、サポートされるズーム倍率の範囲を提供します。zoomTo() メソッドでは、ズーム倍率を変更することができる。

camera->setZoomFactor(3.0);

カメラフレームの生データをキャプチャした後、カメラのハードウェアとソフトウェアはさまざまな画像処理タスクを実行し、最終的な画像を生成します。この処理には、環境光の色の補正、ノイズの低減、画像の調整などが含まれます。

これらの処理手順の多くは、[カメラ] プロパティで制御できます。たとえば、画像の処理に使用するホワイトバランス(または色温度)を設定できます:

camera->setWhiteBalanceMode(QCamera::WhiteBalanceFluorescent);

カメラフレームの画像処理の詳細については、カメラの画像処理を参照してください。

詳細については、カメラの概要を参照してください。

メンバ型ドキュメント

enum QCamera::Error

この列挙型は、最後のエラーコードを保持します。

定数説明
QCamera::NoError0エラーは発生していません。
QCamera::CameraError1エラーが発生しました。

enum QCamera::ExposureMode

定数説明
QCamera::ExposureAuto0自動モード
QCamera::ExposureManual1マニュアルモード
QCamera::ExposurePortrait2ポートレート露出モード。
QCamera::ExposureNight3ナイトモード。
QCamera::ExposureSports4スポット露光モード。
QCamera::ExposureSnow5雪の露出モード
QCamera::ExposureBeach6ビーチ露出モード
QCamera::ExposureAction7アクションモード5.5以降
QCamera::ExposureLandscape8風景モード。5.5以降
QCamera::ExposureNightPortrait9夜景ポートレートモード。5.5から
QCamera::ExposureTheatre10シアターモード。5.5から
QCamera::ExposureSunset11サンセットモード。5.5以降
QCamera::ExposureSteadyPhoto12静止画モード。5.5から
QCamera::ExposureFireworks13花火モード。5.5から
QCamera::ExposureParty14パーティーモード。5.5から
QCamera::ExposureCandlelight15キャンドルライトモード。5.5から
QCamera::ExposureBarcode16バーコードモード。5.5から

enum class QCamera::Feature
flags QCamera::Featuresカメラがサポートする機能のセット。

カメラがサポートする機能のセットを記述します。返される値は以下の組み合わせです:

定数説明
QCamera::Feature::ColorTemperature0x1カメラはカスタムcolorTemperature の設定をサポートしています。
QCamera::Feature::ExposureCompensation0x2カメラはカスタムexposureCompensation の設定をサポートしています。
QCamera::Feature::IsoSensitivity0x4カメラはカスタムisoSensitivity の設定をサポートしています。
QCamera::Feature::ManualExposureTime0x8カメラはmanual exposure Time の設定をサポートしています。
QCamera::Feature::CustomFocusPoint0x10カメラがcustom focus point の設定をサポートします。
QCamera::Feature::FocusDistance0x20Camera はfocusDistance プロパティの設定に対応しています。

Features型はQFlags<Feature>のtypedefです。Feature値のORの組み合わせが格納されます。

enum QCamera::FlashMode

定数説明
QCamera::FlashOff0フラッシュはオフ
QCamera::FlashOn1フラッシュがオン
QCamera::FlashAuto2自動フラッシュ

enum QCamera::FocusMode

一定説明
QCamera::FocusModeAuto0連続オートフォーカスモード。
QCamera::FocusModeAutoNear1近くの被写体に対する連続オートフォーカスモード。
QCamera::FocusModeAutoFar2遠くの被写体に対する連続オートフォーカスモード。
QCamera::FocusModeHyperfocal3被写界深度を最大にして、超焦点距離までピントを合わせます。被写界深度が最大になるように、超焦点距離までピントを合わせます。
QCamera::FocusModeInfinity4厳密に無限遠にピントを合わせる。
QCamera::FocusModeManual5カメラレンズの焦点距離はfocusDistance に従ってロックされます。

enum QCamera::TorchMode

定数説明
QCamera::TorchOff0トーチはオフです。
QCamera::TorchOn1トーチはオンです。
QCamera::TorchAuto2自動トーチ

enum QCamera::WhiteBalanceMode

一定説明
QCamera::WhiteBalanceAuto0オートホワイトバランスモード。
QCamera::WhiteBalanceManual1マニュアルホワイトバランス。このモードでは、ホワイトバランスはsetColorTemperature() で設定する必要があります。
QCamera::WhiteBalanceSunlight2太陽光ホワイトバランスモード。
QCamera::WhiteBalanceCloudy3曇天ホワイトバランスモード。
QCamera::WhiteBalanceShade4日陰ホワイトバランスモード。
QCamera::WhiteBalanceTungsten5タングステン(白熱灯)ホワイトバランスモード。
QCamera::WhiteBalanceFluorescent6蛍光灯ホワイトバランスモード
QCamera::WhiteBalanceFlash7フラッシュホワイトバランスモード
QCamera::WhiteBalanceSunset8夕焼けホワイトバランスモード

プロパティ記録

active : bool

カメラが現在アクティブであるかどうかを記述する。

アクセス機能

bool isActive() const
void setActive(bool active)

通知シグナル:

void activeChanged(bool)

cameraDevice : QCameraDevice

このカメラに関連付けられているQCameraDevice オブジェクトを返します。

アクセス関数

QCameraDevice cameraDevice() const
void setCameraDevice(const QCameraDevice &cameraDevice)

ノーティファイアシグナル:

void cameraDeviceChanged()

cameraFormat : QCameraFormat

このカメラが現在使用しているカメラフォーマットを返します。

注意: Android ターゲットデバイスで FFMPEG バックエンドを使用する場合、YUV420Pフォーマットを要求すると、フルプレーナ 4:2:0 YUV420P またはセミプレーナ NV12/NV21 のいずれかが返されます。これは、デバイスOEMによって実装されたコーデックに依存します。

アクセス機能

QCameraFormat cameraFormat() const
void setCameraFormat(const QCameraFormat &format)

ノーティファイア信号:

void cameraFormatChanged()

QCameraDevice::videoFormatsも参照

colorTemperature : int

現在のホワイトバランスモードがWhiteBalanceManual の場合、現在の色温度を返す。その他のモードの場合、戻り値は未定義である。

アクセス関数:

int colorTemperature() const
void setColorTemperature(int colorTemperature)

通知シグナル:

void colorTemperatureChanged() const

customFocusPoint : QPointF

このプロパティは、カスタムフォーカスポイントの位置を、相対フレーム座標で表す。QPointF(0,0) は左上フレームポイントを指し、QPointF(0.5,0.5) はフレームセンターを指す。

カスタムフォーカスポイントプロパティはFocusPointCustom フォーカスモードでのみ使用されます。

カスタム・フォーカス・ポイントがサポートされているかどうかは、supportedFeatures() に Feature.CustomFocusPoint フラグを付けて問い合わせることで確認できます。

アクセス関数:

QPointF customFocusPoint() const
void setCustomFocusPoint(const QPointF &point)

通知シグナル:

void customFocusPointChanged()

[read-only] error : const Error

カメラのエラー状態を返します。

アクセス関数:

QCamera::Error error() const

Notifierシグナル:カメラのエラー状態を返します:

void errorChanged()

[read-only] errorString : const QString

カメラのエラー状態を説明する可読文字列を返します。

アクセス関数

QString errorString() const

ノーティファイア信号:

void errorChanged()

exposureCompensation : float

EV単位の露出補正。

露出補正プロパティにより、自動計算された露出を調整することができる。

アクセス関数:

float exposureCompensation() const
void setExposureCompensation(float ev)

通知信号:露出補正値をEV単位で示す:

void exposureCompensationChanged(float value)

exposureMode : QCamera::ExposureMode

使用中の露出モードを保持する。

アクセス機能

QCamera::ExposureMode exposureMode() const
void setExposureMode(QCamera::ExposureMode mode)

アクセス関数:ノーティファイア信号:

void exposureModeChanged()

QCamera::isExposureModeSupportedも参照

[read-only] exposureTime : const float

カメラの露光時間(秒)。

アクセス関数:

float exposureTime() const

ノーティファイア信号:

void exposureTimeChanged(float speed)

minimumExposureTime ()、maximumExposureTime ()、setManualExposureTime ()も参照

flashMode : QCamera::FlashMode

このプロパティは、使用中のフラッシュモードを保持する。

カメラにフラッシュがある場合、特定のフラッシュモードを有効にする。

アクセス関数:

QCamera::FlashMode flashMode() const
void setFlashMode(QCamera::FlashMode mode)

通知シグナル:

void flashModeChanged()

QCamera::FlashModeQCamera::isFlashModeSupportedQCamera::isFlashReadyも参照

[read-only] flashReady : const bool

フラッシュが充電され、使用可能な状態であることを示す。

アクセス機能:

bool isFlashReady() const[see note below]

注意: この関数は、メタオブジェクトシステムおよびQMLから呼び出すことができます。Q_INVOKABLE を参照してください。

通知信号:

void flashReady(bool ready)

focusDistance : float

このプロパティは、カメラデバイスがマニュアルフォーカスモードで動作する場合の レンズフォーカス距離を定義する。有効な値は 0~1 で、0 が最も近いフォーカス距離、1 が最も遠いフォーカス距離となります。最も遠い点は通常無限遠ですが、これはすべてのデバイスに当てはまるとは限りません。

このプロパティは、focusModeFocusModeManual に設定され、supportedFeaturesFeature::FocusDistance フラグを含む場合にのみ、デバイスに適用される。

focusMode が Camera.FocusModeManual に設定されていない間にこのプロパティに値を割り当てた場合、プロパティは値を保存しますが、Camera.FocusModeManual がアクティブになるまでデバイスには影響しません。

有効範囲[0, 1]外の値を割り当てても、このプロパティに影響はありません。

supportedFeaturesFocusDistance フラグが含まれていない場合、このプロパティを設定しようとしても無視されます。

カメラがオートフォーカスモードの場合、本プロパティは更新されない。

デフォルト値は 1 である。

アクセス関数:

float focusDistance() const
void setFocusDistance(float d)

通知信号:

void focusDistanceChanged(float)

focusMode : FocusMode

本プロパティは、現在のカメラのフォーカスモードを保持する。

本プロパティは、カメラデバイスのフォーカスモードを制御する値を保持する。全てのオートフォーカスモードにおいて、カメラデバイスは連続的にフォーカスし続ける。

カメラデバイスが特定のフォーカスモードをサポートしているかどうかを確認するには、対応するFocusMode の値をパラメータとしてisFocusModeSupported 関数に渡します。フォーカスモードの値がサポートされていない場合、この関数は false を返します。このモードを focusMode プロパティに代入しても効果はありません。

focusMode プロパティを Camera.FocusModeManual に設定すると、レンズはfocusDistance に従ってフォーカスをロックします。

アクセス関数

QCamera::FocusMode focusMode() const
void setFocusMode(QCamera::FocusMode mode)

通知シグナル:

isFocusModeSupportedも参照してください

[read-only] focusPoint : const QPointF

オートフォーカスシステムが現在フォーカスに使用しているポイントを返します。

アクセス関数:

QPointF focusPoint() const

通知信号:

void focusPointChanged()

[read-only] isoSensitivity : const int

このプロパティはセンサーの ISO 感度を保持する。

カメラが現在使用している ISO 感度を表す。

アクセス関数:

int isoSensitivity() const

アクセス関数:Notifier signal: このプロパティはセンサーのISO感度を保持する:

void isoSensitivityChanged(int value)

setAutoIsoSensitivity() およびsetManualIsoSensitivity()も参照

manualExposureTime : float

マニュアル露光時間をseconds

アクセス機能

float manualExposureTime() const
void setManualExposureTime(float seconds)

通知信号:

void manualExposureTimeChanged(float speed)

manualIsoSensitivity : int

手動で設定されたISO感度を表す。

このプロパティを-1(デフォルト)に設定すると、カメラが自動的にISO感度を調整します。

アクセス関数

int manualIsoSensitivity() const
void setManualIsoSensitivity(int iso)

通知信号:最大ズーム倍率を返します:

void manualIsoSensitivityChanged(int)

[read-only] maximumZoomFactor : const float

最大ズーム倍率を返す。

ズームに対応していないカメラでは、1.0

アクセス関数:

float maximumZoomFactor() const

通知シグナル:

void maximumZoomFactorChanged(float)

[read-only] minimumZoomFactor : const float

最小ズーム倍率を返します。

ズームに対応していないカメラでは1.0 になります。

アクセス関数:

float minimumZoomFactor() const

通知シグナル

void minimumZoomFactorChanged(float)

[read-only] supportedFeatures : const Features

このカメラがサポートする機能を返します。

アクセス関数:

QCamera::Features supportedFeatures() const

Notifier signal: このカメラでサポートされている機能を返します:

void supportedFeaturesChanged()

QCamera::Featureも参照

torchMode : QCamera::TorchMode

トーチモード このプロパティは、使用中のトーチモードを保持する。

トーチは連続光源です。低照度条件下でのビデオ撮影時に使用できます。トーチモードを有効にすると、通常、現在設定されているフラッシュモードが上書きされます。

アクセス機能:

QCamera::TorchMode torchMode() const
void setTorchMode(QCamera::TorchMode mode)

通知信号:

void torchModeChanged()

QCamera::TorchModeQCamera::isTorchModeSupportedQCamera::flashModeも参照

whiteBalanceMode : WhiteBalanceMode

使用中のホワイトバランスモードを返します。

アクセス関数:

QCamera::WhiteBalanceMode whiteBalanceMode() const
void setWhiteBalanceMode(QCamera::WhiteBalanceMode mode)

アクセス関数:ノーティファイアシグナル:

void whiteBalanceModeChanged() const

zoomFactor : float

このプロパティは現在のズームファクターを保持する。

現在のズーム倍率を取得または設定する。値はminimumZoomFactor からmaximumZoomFactor の間でクランプされる。

アクセス関数:

float zoomFactor() const
void setZoomFactor(float factor)

通知シグナル:

void zoomFactorChanged(float)

メンバ関数ドキュメント

[explicit] QCamera::QCamera(QObject *parent = nullptr)

QCamera をparent で構築します。

複数のカメラが利用可能な場合、システムのデフォルトカメラを選択します。

[explicit] QCamera::QCamera(QCameraDevice::Position position, QObject *parent = nullptr)

指定されたposition にあるハードウェア・カメラを使用する QCamera を構築します。

例えば、携帯電話では、前面カメラと背面カメラを簡単に選択するために使用できます。

指定されたposition にカメラがない場合、またはpositionQCameraDevice::UnspecifiedPosition の場合、デフォルトのカメラが使用されます。

[explicit] QCamera::QCamera(const QCameraDevice &cameraDevice, QObject *parent = nullptr)

カメラ記述cameraDevice およびparent から QCamera を構築します。

[virtual noexcept] QCamera::~QCamera()

カメラオブジェクトを破棄します。

QMediaCaptureSession *QCamera::captureSession() const

このカメラが接続されているキャプチャセッションを返すか、カメラがキャプチャセッションに接続されていない場合はnullptrを返します。

カメラをセッションに接続するにはQMediaCaptureSession::setCamera() を使用します。

[signal] void QCamera::errorOccurred(QCamera::Error error, const QString &errorString)

このシグナルはエラー状態がerror に変化したときに発せられる。エラーの説明はerrorString として提供される。

[signal] void QCamera::exposureCompensationChanged(float value)

露出補正がvalue に変化したときに発せられる信号。

注: プロパティexposureCompensation のノーティファイアシグナル。

float QCamera::exposureTime() const

現在の露光時間を秒単位で返す。

注: プロパティ exposureTime のゲッター関数。

[signal] void QCamera::exposureTimeChanged(float speed)

カメラの露出speed が変更されたことを通知する。

注: プロパティexposureTime に対するノーティファイアシグナル。

[signal] void QCamera::flashReady(bool ready)

フラッシュready の状態が変化したことを示す。

注: プロパティ flashReady に対するノーティファイアシグナル。

[signal] void QCamera::focusModeChanged()

focusMode が変更されたことを示す。

注: プロパティfocusMode に対するノーティファイアシグナル。

bool QCamera::isActive() const

カメラが現在アクティブである場合、true を返す。

注: プロパティactive のゲッター関数。

bool QCamera::isAvailable() const

カメラが使用可能な場合、true を返す。

[invokable] bool QCamera::isExposureModeSupported(QCamera::ExposureMode mode) const

露出mode がサポートされている場合、true を返す。

:この関数はメタオブジェクトシステムおよび QML から呼び出すことができます。Q_INVOKABLE を参照してください。

[invokable] bool QCamera::isFlashModeSupported(QCamera::FlashMode mode) const

フラッシュmode がサポートされている場合、true を返します。

注: この関数はメタオブジェクトシステム経由でも QML からも呼び出すことができます。Q_INVOKABLE を参照してください。

[invokable] bool QCamera::isFlashReady() const

フラッシュが充電されている場合、true を返します。

注意: この関数は、メタ・オブジェクト・システム経由および QML から呼び出すことができます。Q_INVOKABLE を参照してください。

注: プロパティflashReady のゲッター関数です。

[invokable] bool QCamera::isFocusModeSupported(QCamera::FocusMode mode) const

フォーカスmode がカメラでサポートされている場合、true を返します。

FocusModeManual がサポートされていると報告された場合、その機能Feature::FocusDistance もサポートされていると見なされます。

:この関数はメタオブジェクトシステムおよび QML から呼び出すことができます。Q_INVOKABLE を参照してください。

[invokable] bool QCamera::isTorchModeSupported(QCamera::TorchMode mode) const

トーチmode がサポートされている場合、true を返します。

注意: この関数はメタオブジェクトシステム経由でも QML からでも呼び出すことができます。Q_INVOKABLE を参照してください。

[invokable] bool QCamera::isWhiteBalanceModeSupported(QCamera::WhiteBalanceMode mode) const

ホワイトバランスmode がサポートされている場合、true を返します。

注: この関数は、メタオブジェクトシステム経由および QML から呼び出すことができます。Q_INVOKABLE を参照。

[signal] void QCamera::isoSensitivityChanged(int value)

感度がvalue に変化したときに発せられるシグナル。

注: プロパティisoSensitivity のノーティファイアシグナル。

float QCamera::manualExposureTime() const

マニュアル露光時間を秒単位で返し、カメラが自動露光時間を使用している場合は -1 を返す。

注: プロパティ manualExposureTime のゲッター関数。

setManualExposureTime()も参照

float QCamera::maximumExposureTime() const

最大露光時間を秒単位で返す。

int QCamera::maximumIsoSensitivity() const

カメラがサポートする最高ISO感度を返します。

float QCamera::minimumExposureTime() const

最小露光時間(秒)。

int QCamera::minimumIsoSensitivity() const

カメラがサポートする最小 ISO 感度を秒単位で返します。

[slot] void QCamera::setActive(bool active)

activetrue の場合はカメラをオンにし、false の場合はオフにする。

注: プロパティactive に対するセッター関数。

isActive()も参照

[slot] void QCamera::setAutoExposureTime()

自動的に計算された露光時間を使用する

[slot] void QCamera::setAutoIsoSensitivity()

自動感度をオンにする

void QCamera::setCameraDevice(const QCameraDevice &cameraDevice)

カメラオブジェクトをcameraDevice で記述された物理カメラデバイスに接続します。デフォルトで構築されたQCameraDevice オブジェクトをcameraDevice として使用すると、カメラはシステムデフォルトのカメラデバイスに接続されます。

カメラデバイスを切り替えると、QCamera の機能が更新されます。さらに、QCamera の制御プロパティ(focusMode,flashMode,focusDistance,zoomFactor など)も以下のように更新されます:

  • プロパティが新しいデバイスでサポートされている場合、そのプロパティ値がカ メラ・デバイスに適用されます。
  • プロパティがサポートされているが、有効な値の範囲が変更されている場合、プロパティは新しい範囲にクランプされ、カメラデバイスに適用されます。
  • 新しいカメラデバイスがプロパティをサポートしていない場合、プロパティ値はデフォルトにリセットされ、カメラデバイスへの変更は行われません。

注: cameraDevice プロパティのセッター関数。

cameraDevice()も参照

void QCamera::setCameraFormat(const QCameraFormat &format)

format で説明されているフォーマットを使用するようにカメラに指示します。これを使用して、録画と画像キャプチャに使用する特定の解像度とフレームレートを定義できます。

注: Androidターゲット・デバイスでFFMPEGバックエンドを使用する場合、YUV420Pフォーマットを要求すると、完全にプレーナな4:2:0 YUV420Pまたはセミ・プレーナなNV12/NV21のいずれかを受信します。これは、デバイス OEM が実装するコーデックに依存します。

注: cameraFormat プロパティのセッター関数。

cameraFormat()も参照

[slot] void QCamera::setColorTemperature(int colorTemperature)

マニュアルホワイトバランスをcolorTemperature に設定します。 これは、whiteBalanceMode() がWhiteBalanceManual に設定されている場合に使用されます。 単位はケルビンです。

色温度を設定すると、WhiteBalanceManual がサポートされている場合にのみ効果があります。この場合、温度を 0 より大きく設定すると、ホワイトバランスモードは自動的にWhiteBalanceManual に設定されます。温度を 0 に設定すると、ホワイトバランスモードはWhiteBalanceAuto にリセットされます。

注: プロパティ用セッター関数colorTemperature

colorTemperature()も参照

[slot] void QCamera::setWhiteBalanceMode(QCamera::WhiteBalanceMode mode)

ホワイトバランスをmode に設定する。

注: プロパティwhiteBalanceMode のセッター関数。

whiteBalanceMode()も参照

void QCamera::setZoomFactor(float factor)

ズーム倍率factor に、毎秒 1 倍の速度でズームする。

注: zoomFactor プロパティのセッター関数。

zoomFactor()も参照

[slot] void QCamera::start()

カメラを起動します。

setActive(true)と同じ。

何らかの理由でカメラを起動できない場合、errorOccurred() シグナルが出力されます。

[slot] void QCamera::stop()

カメラを停止します。setActive(false)と同じ。

[slot] void QCamera::zoomTo(float factor, float rate)

rate を使用して、ズーム倍率factor にズームします。

rate は秒あたりの2の累乗で指定します。レート1の場合、ズーム・ファクター1から4まで2秒かかる。

注: 特定のレートを使用することは、すべてのカメラでサポートされているわけではありません。サポートされていない場合、ズームは可能な限り速く行われます。

本書に含まれる文書の著作権は、それぞれの所有者に帰属します。 本書で提供されるドキュメントは、Free Software Foundation が発行したGNU Free Documentation License version 1.3に基づいてライセンスされています。 Qtおよびそれぞれのロゴは、フィンランドおよびその他の国におけるThe Qt Company Ltd.の 商標です。その他すべての商標は、それぞれの所有者に帰属します。