blob: 5ad394657e6b893b6d3670bbc1da620b8ac04093 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
// Copyright (C) 2022 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
// Qt-Security score:significant reason:default
import QtQuick
import QtQuick.Dialogs
import QtQuick.Dialogs.quickimpl
SaturationLightnessPickerImpl {
id: control
implicitWidth: Math.max(background ? background.implicitWidth : 0, contentItem.implicitWidth)
implicitHeight: Math.max(background ? background.implicitHeight : 0, contentItem.implicitHeight)
background: Rectangle {
anchors.fill: parent
color: control.visualFocus ? (control.pressed ? "#cce0ff" : "#f0f6ff") : (control.pressed ? "#d6d6d6" : "#f6f6f6")
border.color: "#353637"
}
contentItem: ShaderEffect {
scale: contentItem.width / width
layer.enabled: true
layer.smooth: true
anchors.fill: parent
property alias hue: control.hue
fragmentShader: "qrc:/qt-project.org/imports/QtQuick/Dialogs/quickimpl/shaders/SaturationLightness.frag.qsb"
}
handle: PickerHandle {
x: control.leftPadding + control.lightness * control.availableWidth - width / 2
y: control.topPadding + (1.0 - control.saturation) * control.availableHeight - height / 2
picker: control
handleColor: control.color
z: 1
}
}
|