/* * Copyright (C) 2011 by Daker Fernandes Pinheiro * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU Library General Public License as * published by the Free Software Foundation; either version 2, or * (at your option) any later version. * * This program 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 General Public License for more details * * You should have received a copy of the GNU Library General Public * License along with this program; if not, write to the * Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ import QtQuick 1.0 import org.kde.plasma.core 0.1 as PlasmaCore import org.kde.qtextracomponents 0.1 /** * Simple progressBar using the plasma theme. * * Some operations take a period of time to be performed and the user needs a * confirmation that the operation is still ongoing. If the user does not get * any confirmation, they might suspect that they did something wrong or that * the device has broken. A progress bar is one of the available mechanisms for * providing this reassurance to the user. */ Item { id: progressBar // Common API /** type:real Minimum value for the progressBar */ property alias minimumValue: range.minimumValue /** type:real Maximum value for the progressBar */ property alias maximumValue: range.maximumValue /** type:real Current value of the progressBar */ property alias value: range.value /** * type:bool * Indicates whether the operation's duration is known or not. The property * can have the following values: * * - true: the operation's duration is unknown, so the progress bar is * animated. The value, minimum, and maximum properties are ignored. * - false: the operation's duration is known, so the progress bar is drawn * to indicate progress between the minimum and maximum values. * * The default value is false. */ property alias indeterminate: indeterminateAnimation.running // Plasma API /** * Orientation of the progressBar: Qt.Horizontal or Qt.Vertical */ property int orientation: Qt.Horizontal width: 100 height: 20 opacity: enabled ? 1.0 : 0.5 RangeModel { id: range // default values minimumValue: 0.0 maximumValue: 1.0 value: 0 positionAtMinimum: 0 positionAtMaximum: backgroundPixmapItem.width } Item { id: contents property bool _isVertical: orientation == Qt.Vertical property int _tileWidth: width width: _isVertical ? progressBar.height : progressBar.width height: _isVertical ? progressBar.width : progressBar.height rotation: _isVertical ? 90 : 0 anchors.centerIn: parent Timer { id: resizeTimer repeat: false interval: 0 running: false onTriggered: { contents._tileWidth = Math.floor(contents.width/(Math.floor(contents.width/(contents.height/1.6)))) if (barFrameSvg.hasElement("hint-bar-stretch")) { barFrameSvg.resizeFrame(Qt.size(barPixmapItem.width, barPixmapItem.height)) } else { barFrameSvg.resizeFrame(Qt.size(contents._tileWidth, contents.height)) } barPixmapItem.pixmap = barFrameSvg.framePixmap() if (backgroundFrameSvg.hasElement("hint-bar-stretch")) { backgroundFrameSvg.resizeFrame(Qt.size(backgroundPixmapItem.width, backgroundPixmapItem.height)) } else { backgroundFrameSvg.resizeFrame(Qt.size(contents._tileWidth, contents.height)) } backgroundPixmapItem.pixmap = backgroundFrameSvg.framePixmap() } } PlasmaCore.FrameSvg { id: barFrameSvg Component.onCompleted: { barFrameSvg.setImagePath("widgets/bar_meter_horizontal") barFrameSvg.setElementPrefix("bar-active") resizeTimer.restart() } } PlasmaCore.FrameSvg { id: backgroundFrameSvg Component.onCompleted: { backgroundFrameSvg.setImagePath("widgets/bar_meter_horizontal") backgroundFrameSvg.setElementPrefix("bar-inactive") resizeTimer.restart() } } QPixmapItem { id: backgroundPixmapItem anchors.fill: parent fillMode: QPixmapItem.TileHorizontally onWidthChanged: resizeTimer.restart() onHeightChanged: resizeTimer.restart() } QPixmapItem { id: barPixmapItem fillMode: QPixmapItem.TileHorizontally width: indeterminate ? contents._tileWidth*2 : range.position height: contents.height visible: indeterminate || value > 0 onWidthChanged: resizeTimer.restart() onHeightChanged: resizeTimer.restart() SequentialAnimation { id: indeterminateAnimation loops: Animation.Infinite onRunningChanged: { if (!running) { barPixmapItem.x = 0 } } PropertyAnimation { target: barPixmapItem property: "x" duration: 800 to: 0 } PropertyAnimation { target: barPixmapItem property: "x" duration: 800 to: backgroundPixmapItem.width - barPixmapItem.width } } } } }