// Copyright (C) 2017 The Qt Company Ltd. // SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only import QtQuick import QtQuick.Templates as T import QtQuick.Controls.impl import QtQuick.Controls.Imagine import QtQuick.Controls.Imagine.impl T.Tumbler { id: control implicitWidth: Math.max(implicitBackgroundWidth + leftInset + rightInset, implicitContentWidth + leftPadding + rightPadding) implicitHeight: Math.max(implicitBackgroundHeight + topInset + bottomInset, implicitContentHeight + topPadding + bottomPadding) topInset: background ? -background.topInset || 0 : 0 leftInset: background ? -background.leftInset || 0 : 0 rightInset: background ? -background.rightInset || 0 : 0 bottomInset: background ? -background.bottomInset || 0 : 0 readonly property real __delegateHeight: availableHeight / visibleItemCount delegate: Text { text: modelData font: control.font color: control.palette.text opacity: (1.0 - Math.abs(Tumbler.displacement) / (control.visibleItemCount / 2)) * (control.enabled ? 1 : 0.6) horizontalAlignment: Text.AlignHCenter verticalAlignment: Text.AlignVCenter required property var modelData required property int index } contentItem: TumblerView { implicitWidth: 60 implicitHeight: 200 model: control.model delegate: control.delegate path: Path { startX: control.contentItem.width / 2 startY: -control.__delegateHeight / 2 PathLine { x: control.contentItem.width / 2 y: (control.visibleItemCount + 1) * control.__delegateHeight - control.__delegateHeight / 2 } } property real delegateHeight: control.availableHeight / control.visibleItemCount } background: NinePatchImage { source: Imagine.url + "tumbler-background" NinePatchImageSelector on source { states: [ {"disabled": !control.enabled}, {"focused": control.visualFocus}, {"mirrored": control.mirrored}, {"hovered": control.enabled && control.hovered} ] } } }