mirror of
https://github.com/zhuzichu520/FluentUI.git
synced 2025-01-24 12:54:32 +08:00
66 lines
1.8 KiB
QML
66 lines
1.8 KiB
QML
import QtQuick 2.0
|
|
import QtQuick.Controls 2.0
|
|
import FluentUI 1.0
|
|
|
|
Switch {
|
|
id: root
|
|
property var onClickFunc
|
|
width: 40
|
|
implicitWidth: 40
|
|
height: 20
|
|
implicitHeight: 20
|
|
checkable: false
|
|
indicator: Rectangle {
|
|
width: root.width
|
|
height: root.height
|
|
radius: height / 2
|
|
color: {
|
|
if(FluTheme.isDark){
|
|
if(root.checked){
|
|
return FluTheme.primaryColor.dark
|
|
}
|
|
if(switch_mouse.containsMouse){
|
|
return "#3E3E3C"
|
|
}
|
|
return "#323232"
|
|
}else{
|
|
if(root.checked){
|
|
return FluTheme.primaryColor.dark
|
|
}
|
|
if(switch_mouse.containsMouse){
|
|
return "#F4F4F4"
|
|
}
|
|
return "#FFFFFF"
|
|
}
|
|
}
|
|
border.width: 1
|
|
border.color: root.checked ? Qt.lighter(FluTheme.primaryColor.dark,1.2) : "#666666"
|
|
|
|
Rectangle {
|
|
x: root.checked ? root.implicitWidth - width - 4 : 4
|
|
width: root.height - 8
|
|
height: root.height - 8
|
|
radius: width / 2
|
|
scale: switch_mouse.containsMouse ? 1.2 : 1.0
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
color: root.checked ? "#FFFFFF" : "#666666"
|
|
// border.color: "#D5D5D5"
|
|
Behavior on x {
|
|
NumberAnimation { duration: 200 }
|
|
}
|
|
}
|
|
}
|
|
MouseArea{
|
|
id:switch_mouse
|
|
anchors.fill: parent
|
|
hoverEnabled: true
|
|
onClicked: {
|
|
if(root.onClickFunc){
|
|
root.onClickFunc()
|
|
}else{
|
|
root.checked = !root.checked
|
|
}
|
|
}
|
|
}
|
|
}
|