X-Git-Url: http://cgit.sxemacs.org/?p=harmattan%2Fcameraplus;a=blobdiff_plain;f=qml%2FFlashButton.qml;h=02029137b628a7beefd2f54f9c6bad295ccd060f;hp=80034b0732edba4dca9e39b69b8fe0f1bc9bd5c4;hb=b37d0ab04228a193a8302417f0657a73c8fdbd3f;hpb=b49c9adf02cc8fdd2157f4205cdf5731b63f876a diff --git a/qml/FlashButton.qml b/qml/FlashButton.qml index 80034b0..0202913 100644 --- a/qml/FlashButton.qml +++ b/qml/FlashButton.qml @@ -1,71 +1,56 @@ // -*- qml -*- -import QtQuick 1.1 -import com.nokia.meego 1.1 -import QtCamera 1.0 - -Selector { - id: button - property alias value: flash.value +/*! + * This file is part of CameraPlus. + * + * Copyright (C) 2012-2013 Mohammed Sameer + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + */ + +import QtQuick 2.0 +import QtCamera 1.0 - iconSource: flashIcon(flash.value); +CameraToolIcon { + id: button - title: qsTr("Flash mode"); + iconSource: cameraTheme.flashIcon(settings.imageFlashMode) - Flash { - id: flash - camera: cam - // TODO: hardcoding - value: Flash.Auto - } + property list toolsModel: [ + ToolsModelItem {icon: cameraTheme.flashAutoIconId; value: Flash.Auto }, + ToolsModelItem {icon: cameraTheme.flashOnIconId; value: Flash.On }, + ToolsModelItem {icon: cameraTheme.flashOffIconId; value: Flash.Off }, + ToolsModelItem {icon: cameraTheme.flashRedEyeIconId; value: Flash.RedEye } + ] - function flashIcon(val) { - var x = row.children.length; - var i = 0; - for (i = 0; i < x; i++) { - if (row.children[i].value == val) { - return row.children[i].normalIcon; - } - } + property CameraToolBarTools tools: CameraToolBarTools { + CameraLabel { + height: parent ? parent.height : 0 + text: qsTr("Flash") + verticalAlignment: Text.AlignVCenter } - widget: Row { - id: row - height: button.checked ? 64 : 0 - width: button.checked ? (children.length * height) + (children.length - 1) * spacing : 0 - spacing: 10 - - Behavior on width { - // TODO: seems animation is not working - PropertyAnimation { duration: 250; } - } - - CheckButton { - normalIcon: "image://theme/icon-m-camera-flash-auto" - checkedIcon: "image://theme/icon-m-camera-flash-auto-pressed" - controller: flash - value: Flash.Auto - } - - CheckButton { - normalIcon: "image://theme/icon-m-camera-flash-always" - checkedIcon: "image://theme/icon-m-camera-flash-always-pressed" - controller: flash - value: Flash.On - } - - CheckButton { - normalIcon: "image://theme/icon-m-camera-flash-off" - checkedIcon: "image://theme/icon-m-camera-flash-off-pressed" - controller: flash - value: Flash.Off - } + Repeater { + model: parent != null && parent.visible ? toolsModel : undefined - CheckButton { - normalIcon: "image://theme/icon-m-camera-flash-red-eye" - checkedIcon: "image://theme/icon-m-camera-flash-red-eye-pressed" - controller: flash - value: Flash.RedEye - } + delegate: CheckButton { + iconSource: icon + onClicked: settings.imageFlashMode = value + checked: settings.imageFlashMode == value + visible: !(overlay.cam.quirks.hasQuirk(Quirks.NoRedEyeFlash) && value == Flash.RedEye) + } } + } }