diff options
author | Dmytro Poplavskiy <dmytro.poplavskiy@nokia.com> | 2012-01-24 10:56:52 +1000 |
---|---|---|
committer | Qt by Nokia <qt-info@nokia.com> | 2012-01-27 08:26:47 +0100 |
commit | 155c48b97e7ff5f4d70b777e0a954f42826276f0 (patch) | |
tree | 69caa387b99025df91fe57e8617e1dbc55c82f89 /tests/auto/unit/qmultimedia_common | |
parent | 817fb006c7583a852ca07df004994d1a5226d162 (diff) |
Moved zoom related properties out of QCameraFocusControl
Change-Id: I16f9b80ebbacc0b325530e81c291dc030763b65e
Reviewed-by: Michael Goddard <michael.goddard@nokia.com>
Diffstat (limited to 'tests/auto/unit/qmultimedia_common')
4 files changed, 143 insertions, 64 deletions
diff --git a/tests/auto/unit/qmultimedia_common/mockcamera.pri b/tests/auto/unit/qmultimedia_common/mockcamera.pri index 233d5b8a2..22a9dc155 100644 --- a/tests/auto/unit/qmultimedia_common/mockcamera.pri +++ b/tests/auto/unit/qmultimedia_common/mockcamera.pri @@ -9,6 +9,7 @@ HEADERS *= \ ../qmultimedia_common/mockcameraflashcontrol.h \ ../qmultimedia_common/mockcameralockscontrol.h \ ../qmultimedia_common/mockcamerafocuscontrol.h \ + ../qmultimedia_common/mockcamerazoomcontrol.h \ ../qmultimedia_common/mockcameraimageprocessingcontrol.h \ ../qmultimedia_common/mockcameraimagecapturecontrol.h \ ../qmultimedia_common/mockcameraexposurecontrol.h \ diff --git a/tests/auto/unit/qmultimedia_common/mockcamerafocuscontrol.h b/tests/auto/unit/qmultimedia_common/mockcamerafocuscontrol.h index 8cccb4dc0..64524619c 100644 --- a/tests/auto/unit/qmultimedia_common/mockcamerafocuscontrol.h +++ b/tests/auto/unit/qmultimedia_common/mockcamerafocuscontrol.h @@ -51,14 +51,9 @@ class MockCameraFocusControl : public QCameraFocusControl public: MockCameraFocusControl(QObject *parent = 0): QCameraFocusControl(parent), - m_opticalZoom(1.0), - m_digitalZoom(1.0), m_focusMode(QCameraFocus::AutoFocus), m_focusPointMode(QCameraFocus::FocusPointAuto), - m_focusPoint(0.5, 0.5), - m_maxOpticalZoom(3.0), - m_maxDigitalZoom(4.0) - + m_focusPoint(0.5, 0.5) { m_zones << QCameraFocusZone(QRectF(0.45, 0.45, 0.1, 0.1)); } @@ -81,45 +76,6 @@ public: return mode == QCameraFocus::AutoFocus || mode == QCameraFocus::ContinuousFocus; } - qreal maximumOpticalZoom() const - { - return m_maxOpticalZoom; - } - - qreal maximumDigitalZoom() const - { - return m_maxDigitalZoom; - } - - qreal opticalZoom() const - { - return m_opticalZoom; - } - - qreal digitalZoom() const - { - return m_digitalZoom; - } - - void zoomTo(qreal optical, qreal digital) - { - optical = qBound<qreal>(1.0, optical, maximumOpticalZoom()); - digital = qBound<qreal>(1.0, digital, maximumDigitalZoom()); - - if (!qFuzzyCompare(digital, m_digitalZoom)) { - m_digitalZoom = digital; - emit digitalZoomChanged(m_digitalZoom); - } - - if (!qFuzzyCompare(optical, m_opticalZoom)) { - m_opticalZoom = optical; - emit opticalZoomChanged(m_opticalZoom); - } - - maxOpticalDigitalZoomChange(4.0, 5.0); - focusZonesChange(0.50, 0.50, 0.3, 0.3); - } - QCameraFocus::FocusPointMode focusPointMode() const { return m_focusPointMode; @@ -151,6 +107,7 @@ public: void setCustomFocusPoint(const QPointF &point) { m_focusPoint = point; + focusZonesChange(0.50, 0.50, 0.3, 0.3); } QCameraFocusZoneList focusZones() const @@ -158,20 +115,6 @@ public: return m_zones; } - // helper function to emit maximum Optical and Digital Zoom Changed signals - void maxOpticalDigitalZoomChange(qreal maxOptical, qreal maxDigital) - { - if (maxOptical != m_maxOpticalZoom) { - m_maxOpticalZoom = maxOptical; - emit maximumOpticalZoomChanged(m_maxOpticalZoom); - } - - if (maxDigital != m_maxDigitalZoom) { - m_maxDigitalZoom = maxDigital; - emit maximumDigitalZoomChanged(m_maxDigitalZoom); - } - } - // helper function to emit Focus Zones Changed signals void focusZonesChange(qreal left, qreal top, qreal width, qreal height) { @@ -184,14 +127,9 @@ public: } private: - qreal m_opticalZoom; - qreal m_digitalZoom; QCameraFocus::FocusMode m_focusMode; QCameraFocus::FocusPointMode m_focusPointMode; QPointF m_focusPoint; - // to emit maximum Optical and Digital Zoom Changed signals - qreal m_maxOpticalZoom; - qreal m_maxDigitalZoom; // to emit focus zone changed signal QCameraFocusZoneList m_zones; }; diff --git a/tests/auto/unit/qmultimedia_common/mockcameraservice.h b/tests/auto/unit/qmultimedia_common/mockcameraservice.h index 2d3d810c1..53cdf7be6 100644 --- a/tests/auto/unit/qmultimedia_common/mockcameraservice.h +++ b/tests/auto/unit/qmultimedia_common/mockcameraservice.h @@ -46,6 +46,7 @@ #include "../qmultimedia_common/mockcameraflashcontrol.h" #include "../qmultimedia_common/mockcameralockscontrol.h" #include "../qmultimedia_common/mockcamerafocuscontrol.h" +#include "../qmultimedia_common/mockcamerazoomcontrol.h" #include "../qmultimedia_common/mockcameraimageprocessingcontrol.h" #include "../qmultimedia_common/mockcameraimagecapturecontrol.h" #include "../qmultimedia_common/mockcameraexposurecontrol.h" @@ -99,6 +100,7 @@ public: mockExposureControl = new MockCameraExposureControl(this); mockFlashControl = new MockCameraFlashControl(this); mockFocusControl = new MockCameraFocusControl(this); + mockZoomControl = new MockCameraZoomControl(this); mockCaptureControl = new MockCaptureControl(mockControl, this); mockCaptureBufferControl = new MockCaptureBufferFormatControl(this); mockCaptureDestinationControl = new MockCaptureDestinationControl(this); @@ -133,6 +135,9 @@ public: if (qstrcmp(iid, QCameraFocusControl_iid) == 0) return mockFocusControl; + if (qstrcmp(iid, QCameraZoomControl_iid) == 0) + return mockZoomControl; + if (qstrcmp(iid, QCameraImageCaptureControl_iid) == 0) return mockCaptureControl; @@ -183,6 +188,7 @@ public: MockCameraExposureControl *mockExposureControl; MockCameraFlashControl *mockFlashControl; MockCameraFocusControl *mockFocusControl; + MockCameraZoomControl *mockZoomControl; MockImageProcessingControl *mockImageProcessingControl; MockImageEncoderControl *mockImageEncoderControl; MockVideoRendererControl *rendererControl; diff --git a/tests/auto/unit/qmultimedia_common/mockcamerazoomcontrol.h b/tests/auto/unit/qmultimedia_common/mockcamerazoomcontrol.h new file mode 100644 index 000000000..a8c209272 --- /dev/null +++ b/tests/auto/unit/qmultimedia_common/mockcamerazoomcontrol.h @@ -0,0 +1,134 @@ +/**************************************************************************** +** +** Copyright (C) 2012 Nokia Corporation and/or its subsidiary(-ies). +** All rights reserved. +** Contact: http://www.qt-project.org/ +** +** This file is part of the test suite of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL$ +** GNU Lesser General Public License Usage +** This file may be used under the terms of the GNU Lesser General Public +** License version 2.1 as published by the Free Software Foundation and +** appearing in the file LICENSE.LGPL included in the packaging of this +** file. Please review the following information to ensure the GNU Lesser +** General Public License version 2.1 requirements will be met: +** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** In addition, as a special exception, Nokia gives you certain additional +** rights. These rights are described in the Nokia Qt LGPL Exception +** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU General +** Public License version 3.0 as published by the Free Software Foundation +** and appearing in the file LICENSE.GPL included in the packaging of this +** file. Please review the following information to ensure the GNU General +** Public License version 3.0 requirements will be met: +** http://www.gnu.org/copyleft/gpl.html. +** +** Other Usage +** Alternatively, this file may be used in accordance with the terms and +** conditions contained in a signed written agreement between you and Nokia. +** +** +** +** +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +#ifndef MOCKCAMERAZOOMCONTROL_H +#define MOCKCAMERAZOOMCONTROL_H + +#include "qcamerazoomcontrol.h" + +class MockCameraZoomControl : public QCameraZoomControl +{ + Q_OBJECT +public: + MockCameraZoomControl(QObject *parent = 0): + QCameraZoomControl(parent), + m_opticalZoom(1.0), + m_digitalZoom(1.0), + m_maxOpticalZoom(3.0), + m_maxDigitalZoom(4.0) + + { + } + + ~MockCameraZoomControl() {} + + qreal maximumOpticalZoom() const + { + return m_maxOpticalZoom; + } + + qreal maximumDigitalZoom() const + { + return m_maxDigitalZoom; + } + + qreal currentOpticalZoom() const + { + return m_opticalZoom; + } + + qreal currentDigitalZoom() const + { + return m_digitalZoom; + } + + qreal requestedOpticalZoom() const + { + return m_opticalZoom; + } + + qreal requestedDigitalZoom() const + { + return m_digitalZoom; + } + + void zoomTo(qreal optical, qreal digital) + { + optical = qBound<qreal>(1.0, optical, maximumOpticalZoom()); + digital = qBound<qreal>(1.0, digital, maximumDigitalZoom()); + + if (!qFuzzyCompare(digital, m_digitalZoom)) { + m_digitalZoom = digital; + emit requestedDigitalZoomChanged(m_digitalZoom); + emit currentDigitalZoomChanged(m_digitalZoom); + } + + if (!qFuzzyCompare(optical, m_opticalZoom)) { + m_opticalZoom = optical; + emit requestedOpticalZoomChanged(m_opticalZoom); + emit currentOpticalZoomChanged(m_opticalZoom); + } + + maxOpticalDigitalZoomChange(4.0, 5.0); + } + + // helper function to emit maximum Optical and Digital Zoom Changed signals + void maxOpticalDigitalZoomChange(qreal maxOptical, qreal maxDigital) + { + if (maxOptical != m_maxOpticalZoom) { + m_maxOpticalZoom = maxOptical; + emit maximumOpticalZoomChanged(m_maxOpticalZoom); + } + + if (maxDigital != m_maxDigitalZoom) { + m_maxDigitalZoom = maxDigital; + emit maximumDigitalZoomChanged(m_maxDigitalZoom); + } + } + +private: + qreal m_opticalZoom; + qreal m_digitalZoom; + qreal m_maxOpticalZoom; + qreal m_maxDigitalZoom; +}; + +#endif // MOCKCAMERAZOOMCONTROL_H |