X-Git-Url: http://cgit.sxemacs.org/?a=blobdiff_plain;f=qml%2FFlashButton.qml;h=933b21d0a2229369d2f49dafa5e6f89e27c13a8c;hb=4f63e9377095787edfb4fb1fbe31bd887bb7843a;hp=5ef0188c78424ce4c4ad623afe168c796eb18ba9;hpb=e6ce691009b168270a0e9a7f8dd0c8a369bfd4f0;p=harmattan%2Fcameraplus diff --git a/qml/FlashButton.qml b/qml/FlashButton.qml index 5ef0188..933b21d 100644 --- a/qml/FlashButton.qml +++ b/qml/FlashButton.qml @@ -1,69 +1,55 @@ // -*- qml -*- -import QtQuick 1.1 -import com.nokia.meego 1.1 -import QtCamera 1.0 -Selector { - id: button +/*! + * 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 - property alias value: flash.value +CameraToolIcon { + id: button - iconSource: flashIcon(flash.value); + iconId: 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: "/usr/share/themes/blanco/meegotouch/icons/icon-m-camera-flash-auto.png" - checkedIcon: "/usr/share/themes/blanco/meegotouch/icons/icon-m-camera-flash-auto-pressed.png" - controller: flash - value: Flash.Auto - } - - CheckButton { - normalIcon: "/usr/share/themes/blanco/meegotouch/icons/icon-m-camera-flash-always.png" - checkedIcon: "/usr/share/themes/blanco/meegotouch/icons/icon-m-camera-flash-always-pressed.png" - controller: flash - value: Flash.On - } - - CheckButton { - normalIcon: "/usr/share/themes/blanco/meegotouch/icons/icon-m-camera-flash-off.png" - checkedIcon: "/usr/share/themes/blanco/meegotouch/icons/icon-m-camera-flash-off-pressed.png" - controller: flash - value: Flash.Off - } + Repeater { + model: parent != null && parent.visible ? toolsModel : undefined - CheckButton { - normalIcon: "/usr/share/themes/blanco/meegotouch/icons/icon-m-camera-flash-red-eye.png" - checkedIcon: "/usr/share/themes/blanco/meegotouch/icons/icon-m-camera-flash-red-eye-pressed.png" - controller: flash - value: Flash.RedEye - } + delegate: CheckButton { + iconId: icon + onClicked: settings.imageFlashMode = value + checked: settings.imageFlashMode == value + } } + } }