Add volume indicator
This commit is contained in:
53
quickshell/ui/AudioIcon.qml
Normal file
53
quickshell/ui/AudioIcon.qml
Normal file
@@ -0,0 +1,53 @@
|
||||
import Quickshell
|
||||
import Quickshell.Io
|
||||
import QtQuick
|
||||
import QtQuick.Layouts
|
||||
|
||||
import "../constants"
|
||||
import "../services"
|
||||
|
||||
Text {
|
||||
id: root
|
||||
required property TopBar parentWindow
|
||||
|
||||
property string lowVolumeIconGlyph: "\uf027"
|
||||
property string highVolumeIconGlyph: "\uf028"
|
||||
property string iconGlyph: lowVolumeIconGlyph
|
||||
property string volumeText: ""
|
||||
property list<string> volumeDudes: ["⸝(°-°)⸜","ヽ(°∘°)ノ","ヽ(°o°)ノ","ヽ(°O°)ノ","ヽ(°ᗜ°)ノ","ヽ(°〇°)ノ","ᕙ( ᗒᗣᗕ )ᕗ"]
|
||||
property int volumeDudeIndex: 0
|
||||
property int dudeStep: 100 / volumeDudes.length
|
||||
|
||||
property AudioService audioService: AudioService {
|
||||
onVolumeChanged: function (volume) {
|
||||
var dudeIndex = Math.min(Math.floor(volume / root.dudeStep), root.volumeDudes.length - 1);
|
||||
root.text = volume + "% " + root.volumeDudes[dudeIndex];
|
||||
}
|
||||
}
|
||||
|
||||
text: iconGlyph
|
||||
color: Colors.md3.on_primary_fixed
|
||||
|
||||
font {
|
||||
family: Constants.fontFamily
|
||||
pixelSize: Constants.fontSize
|
||||
bold: false
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
|
||||
onClicked: {
|
||||
// TODO open volume control panel
|
||||
}
|
||||
|
||||
onWheel: function (wheel) {
|
||||
if (wheel.angleDelta.y > 0) {
|
||||
root.audioService.volumeUp();
|
||||
} else {
|
||||
root.audioService.volumeDown();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user