Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Media Key support on Windows #56

Open
vbabiy opened this issue Mar 2, 2023 · 43 comments
Open

Media Key support on Windows #56

vbabiy opened this issue Mar 2, 2023 · 43 comments
Labels
enhancement New feature or request help wanted Extra attention is needed os:windows

Comments

@vbabiy
Copy link

vbabiy commented Mar 2, 2023

Are you planning on adding media key support?

@dweymouth
Copy link
Owner

dweymouth commented Mar 2, 2023

Edit 10/21/23: repurposing this issue for Windows media key integration since that's the last platform left

Media key support will need to be implemented using the media APIs of each platform. Tracking the completion of each platorm here:


Old invalid info, for historical context

Yes, I definitely would like to add media key support. There is no builtin API in the Fyne toolkit that this project is using for this, however. So I will either A) need to add a media key API to my Fyne fork, or B) find another 3rd party package that can provide media key events. If anyone knows of a 3rd party Go package for media keys, or how to scan for media key events in GLFW (so I can add it to the Fyne fork), please let me know!

@dweymouth dweymouth added enhancement New feature or request help wanted Extra attention is needed labels Mar 2, 2023
@dweymouth dweymouth pinned this issue Mar 3, 2023
@sentriz
Copy link

sentriz commented Mar 6, 2023

i think you need MPRIS https://wiki.archlinux.org/title/MPRIS

at least on linux

@dweymouth
Copy link
Owner

Related: #75

@dusnm dusnm mentioned this issue Apr 18, 2023
@dusnm
Copy link
Contributor

dusnm commented Apr 18, 2023

This is heavily platform dependent. Unix-like systems that implement free desktop standards like D-Bus (this would exclude MacOS) handle media keys through MPRIS. This also provides media controls for desktop environments like Gnome.

I doubt there is a clean way to make this feature cross-platform without implementing a solution for each platform separately.

@dweymouth dweymouth unpinned this issue Jul 15, 2023
@vbabiy
Copy link
Author

vbabiy commented Jul 26, 2023

MPRIS working great on linux (arch).

Great work!

@bvarick
Copy link

bvarick commented Aug 4, 2023

I'm struggling to get the media keys to work on Linux with a flatpak install. I think the permissions are off, but I'm not sure. Its currently listed as owning "org.mpris.MediaPlayer2.Supersonic". I think the ID is "dweymouth.supersonic", so maybe it should match?

@dweymouth
Copy link
Owner

I'm struggling to get the media keys to work on Linux with a flatpak install. I think the permissions are off, but I'm not sure. Its currently listed as owning "org.mpris.MediaPlayer2.Supersonic". I think the ID is "dweymouth.supersonic", so maybe it should match?

You may need to force-update the Flatpak. There was a recently fixed issue with Flatpak MPRIS permissions and the Flatpak manifest was updated but the app version number has not been bumped. See #226

@bvarick
Copy link

bvarick commented Aug 6, 2023

You may need to force-update the Flatpak. There was a recently fixed issue with Flatpak MPRIS permissions and the Flatpak manifest was updated but the app version number has not been bumped. See #226

That worked great, thanks!

@dweymouth dweymouth changed the title Media Key support Media Key support on Windows Oct 21, 2023
@selexin
Copy link

selexin commented Nov 15, 2023

Hey, how's progress going on the Windows Media Key support? Reckon we might see it in 0.90? 🙏

Love your work @dweymouth

@dweymouth
Copy link
Owner

Maybe.. definitely if you know anyone who knows WinAPI C/C++ development and can refer them over here :) Mac media key support was contributed by someone familiar with MacOS dev

@dweymouth
Copy link
Owner

Did a little more digging, and it seems like it may be difficult to get this working on Windows. See this issue here for discussion - but it seems the SystemMediaTransportControls APIs are a bit problematic to use for non-UWP apps, and especially apps built with a cross platform toolkit that never exposes a HWND directly.

@selexin
Copy link

selexin commented Jan 31, 2024

Thanks for the update @dweymouth fingers crossed they eventually make it easier to include windows media key integration. Still loving Supersonic.

@dweymouth
Copy link
Owner

Hmm, it seems like we could adapt Tauon Music Box's idea to access these APIs: Taiko2k/Tauon@6742576#diff-6b63f857d89b9e3a0dbd1cc014f89df23bf20d881fa07638c382044f6c73bf08

They compile a DLL that creates a dummy hidden application window so it can have access to those APIs. Maybe someone with more Win32 dev experience could give this approach a try

@nchietala
Copy link

For those of us on windows this AutoHotKey script will enable play/pause functionality while we wait for an update:

Media_Play_Pause::
    WinGet, targetWindow, ID, ahk_exe Supersonic.exe
    
    if (targetWindow) {
        ControlSend,, {Space}, ahk_id %targetWindow%
    }
    else {
        Run, "C:\Program Files\SuperSonic\Supersonic.exe"
        WinWait, ahk_exe Supersonic.exe,, 10
        WinGet, TargetWindow, ID, ahk_exe Supersonic.exe

        if (TargetWindow) {
            ControlSend,, {Space}, ahk_id %TargetWindow%

            WinClose, ahk_id %TargetWindow%
            ; WinMinimize, ahk_id %TargetWindow%
            ; This assumes that you've set your window to close to the system tray, move the comment ";" to the WinClose line if that is not the case.
        }
    }
return

@dweymouth dweymouth pinned this issue Jun 5, 2024
@ecker00
Copy link

ecker00 commented Aug 8, 2024

Doesn't seem to work for me in KDE (Thumbleweed), guess MPRIS is for Gnome / GTK? (using flatpak version 0.12.0)

@dweymouth
Copy link
Owner

Doesn't seem to work for me in KDE (Thumbleweed), guess MPRIS is for Gnome / GTK? (using flatpak version 0.12.0)

Can you try a direct installation (either build from source or install the release build, if your libmpv is packaged at the same location as on Ubuntu/Debian) instead of Flatpak? That would help see if the issue is in the Flatpak sandboxing or in the app itself

@dweymouth
Copy link
Owner

dweymouth commented Aug 8, 2024

For those of us on windows this AutoHotKey script will enable play/pause functionality while we wait for an update:

Just wanted to add for the Windows users, the AutoHotKey script above could be modified now that Supersonic supports command-line control to running "C:\Program Files\Supersonic\supersonic.exe --play-pause", no need to get the window and send a space bar keystroke to it. This should work more reliably, including when the window is closed to system tray

@EmmaKnijn
Copy link

I'd love this!

@kernal64
Copy link

kernal64 commented Sep 19, 2024

For those of us on windows this AutoHotKey script will enable play/pause functionality while we wait for an update:

Just wanted to add for the Windows users, the AutoHotKey script above could be modified now that Supersonic supports command-line control to running "C:\Program Files\Supersonic\supersonic.exe --play-pause", no need to get the window and send a space bar keystroke to it. This should work more reliably, including when the window is closed to system tray

That's indeed helpful. I discovered, that supersonic also supports command-line parameters --play, --pause, --previous, --next and --volume nn. Is there --volume-up and --volume-down planned? Please provide a list with all valid parameters. Unfortunately --help does nothing - at least on Windows.

I just switched from strawberry to supersonic. Great work!

@dweymouth
Copy link
Owner

Please provide a list with all valid parameters. Unfortunately --help does nothing - at least on Windows.

The reason --help does nothing on Windows is that Windows GUI apps don't get a console attached so there's nowhere to print to. Blame Microsoft ;)

But the output of supersonic --help was attached to this PR description: #403

@FibreTTP
Copy link

FibreTTP commented Sep 27, 2024

A PR was merged back at the end of July adding support for controlling playback in mpv through the SMTC API, here:

This feature hit mpv's stable with the update a few days ago.

The feature is controlled with a new configuration option called media-controls:

(Windows only) Enable integration of media control interface SystemMediaTransportControls. If set to player, only the player will use the controls. Setting it to yes will also enable the controls for libmpv integrations. (default: player)

In standalone mpv, the feature works perfectly. Playing, pausing, and stopping, as well as skipping forward and backward work as expected, in the foreground or background.

Adding m.SetOptionString("media-controls", "yes") to the init. options in backend/player/mpv/player.go, allows this feature to work in Supersonic as well.

Play/pause and stop functionally works fine (see below), but unfortunately skipping backwards is quite buggy. Skipping backwards doesn't do anything unless you have skipped forwards at least once, at which point skipping backwards plays the audio of the previous song, but the UI shows the next song playing.

Playing and pausing messes with the UI, however. The play/pause symbol doesn't update when controlling with SMTC, and the playback progress bar doesn't resume moving when you pause the track with the UI, and play it again with SMTC. Subsequently, if the track ends with the play/pause symbol and playback bar "stuck", when the next track begins playing, both the symbol and the bar will remain stuck (although everything else in the UI changes). Stopping works normally.

Anyway, in order to even have access to the feature, you must use a libmpv built on any commit since the PR was merged. I simply used shinchiro's build to test: https://github.com/shinchiro/mpv-winbuild-cmake/releases/tag/20240926.

(this is a good time to update the libmpv packaged in releases)

@dweymouth
Copy link
Owner

Play/pause and stop functionally works fine (see below), but unfortunately skipping backwards is quite buggy. Skipping backwards doesn't do anything unless you have skipped forwards at least once, at which point skipping backwards plays the audio of the previous song, but the UI shows the next song playing.

Yeah, I'm not surprised this doesn't work well - Supersonic relies on the fact that it is controlling MPV. It actually only loads the current and next song into MPV's play queue for performance (so queuing a 10,000-track playlist is just as instantaneous as queuing 10 tracks), and in the future I'm hoping to support DLNA casting, Subsonic jukebox mode, or other players that aren't MPV. This is why I've been hoping someone familiar with Windows development can help make a DLL that Supersonic can load to interface with SMTC directly. I'm unlikely to pursue using MPV's SMTC as a permanent solution but it is nice in the meantime

@TheStakman
Copy link

TheStakman commented Sep 27, 2024

Doesn't seem to work for me in KDE (Thumbleweed), guess MPRIS is for Gnome / GTK? (using flatpak version 0.12.0)

Can you try a direct installation (either build from source or install the release build, if your libmpv is packaged at the same location as on Ubuntu/Debian) instead of Flatpak? That would help see if the issue is in the Flatpak sandboxing or in the app itself

I haven't tried a direct install yet, but the other day I noticed the media keys not working on Linux Mint via flatpak. So I updated my apt and upgraded packages. Then for some reason the media keys were working. The next day, after a reboot, media keys stopped working. Not sure if that gives you any ideas as far as the flatpak version is concerned. Also, I got a flatpak update for Supersonic today, (which didn't help) but that's weird since the last release of Supersonic was last month?

EDIT: Media keys work when building from source, at least originally. Then I figured I'd test installing from https://github.com/dweymouth/supersonic/releases/download/v0.13.1/Supersonic-0.13.1-linux-x64-libmpv2.tar.xz but the media keys didn't work. Then I tried building from source again, but the media keys didn't work this time. I'm starting to wonder if the issue has something to do with Netflix.

@TheStakman
Copy link

Okay, so after many reboots (thanks NVME drive) I've found out a couple things as far as Linux installations go:

OS: LMDE faye 6 x86_64
Kernel: Linux 6.1.0-12-amd64
DE: Cinnamon 6.2.9
Shell: bash 5.2.15

Flatpak Version

  • If you open Supersonic first thing after reboot and hit the play media key, I get a big don't sign on my desktop as Mint LMDE thinks there's no media. This seems to be consistent every time I do it thins way.
  • If you open Supersonic first thing after reboot and click the play button in the GUI of Supersonic with your mouse, then use the media keys it works.

Libmpv2 Install

  • If you open Supersonic first thing after reboot and only use the media keys it works just fine, or if you click the play button in the GUI then use the media keys.

  • I opened Netflix via Firefox which also uses media keys. While Netflix is up (not even currently playing video), the media keys do not work with Supersonic and only with Netflix, even if I click the play button in the GUI first. After closing Firefox (or just the Netflix tab), the media keys switch back to Supersonic.

    Inversely, if I have media keys working with Supersonic and music playing, then pull up Netflix, the media keys are stuck to Supersonic which is fine. If I close Supersonic the media keys switch over to Netflix.

Build From Source

  • Seems to be the same deal as the Libmpv2 install.

Side Note

  • Not that it will ever matter in normal use, but may help in identifying the issue.

    If you have media keys currently working on one Instance of Supersonic no matter the install method, then open a different one. The media keys will only work for the first one you opened and will not switch over to any other instance of Supersonic. Even if you close out the first one with working media keys.

    Another weird thing is after I closed the working one, then reopened. The media keys sometimes would work, then close and reopen click on play in the GUI then the media keys worked. Then close and reopen, then no matter what I did media keys would not work.

Conclusion

  • While it is annoying that media keys don't work when Netflix is up (which is basically all the time as it doesn't matter if it's actively playing video or not) Something is definitely off when it comes to the Flatpak version compared to the others.

@ungive
Copy link

ungive commented Jan 15, 2025

For SMTC it would be cool if the player reported the following information:

Playback status (playing or paused), song title, artist, album name, live playback position, song duration and the album cover image

That way it could work flawlessly with Music Presence (https://github.com/ungive/discord-music-presence) to show a Discord status for the media that is being played with the player.

Related: ungive/discord-music-presence#146

@dweymouth
Copy link
Owner

Good news! This is finally being worked on and I could benefit from any Windows users testing the build from Github Actions in the linked PR! Specifically anyone using ungive/discord-music-presence since the Windows UI control doesn't seem to show the play time in any way so I'm not sure the implementation is correct.

@ungive
Copy link

ungive commented Jan 17, 2025

... since the Windows UI control doesn't seem to show the play time in any way so I'm not sure the implementation is correct.

You can test your implementation with this command line program I made some time ago that shows all the details reported by SMTC: https://github.com/ungive/media-session-dump

There's a build in the releases.

@FibreTTP
Copy link

@dweymouth Testing this, I seem to be crashing as soon as playback starts, though I can sometimes hear a short moment of the beginning of the track. I believe the logs are normal, too (stable Supersonic prints the same logs):

2025/01/17 20:20:25 Starting supersonic...
2025/01/17 20:20:25 Using config dir: C:\Users\FibreTTP\AppData\Roaming\supersonic
2025/01/17 20:20:25 Using cache dir: C:\Users\FibreTTP\AppData\Local\supersonic
2025/01/17 20:20:25 failed to load theme file "": open C:\Users\FibreTTP\AppData\Roaming\supersonic\themes: The system cannot find the file specified.

@dweymouth
Copy link
Owner

@FibreTTP Which OS version are you on? It seems fine to me on Windows 11 from my (not super extensive) testing. Also did the track that was playing when it crashed have artwork? It sounds like a short moment of the beginning of the track before it crashes may point to problems with loading the album art into Windows's API, because that happens after loading the title/artist.

@FibreTTP
Copy link

@dweymouth I'm on Windows 11 too. You seem to have guessed it with the artwork: playing a track with cover art crashes Supersonic.

I tested with multiple tracks without cover art, and it doesn't crash.

@dweymouth
Copy link
Owner

dweymouth commented Jan 17, 2025

Hmm, strange. I may have to back out the cover art support for SMTC unless someone else can look into it and debug the github.com/supersonic-app/smtc-dll implementation, I can't get it to crash on my end. (All my tracks have cover art and they all seemed to work and show the cover)

@CharlesDelorme
Copy link

Willing to help but don't know Github that much : how to acces the build ? I tried https://github.com/dweymouth/supersonic/actions/workflows/build-windows.yml which points to current release and I don't know where to access from the PR which might be this one #533

@dweymouth
Copy link
Owner

It's here: https://github.com/dweymouth/supersonic/actions/runs/12821661378?pr=533

@CharlesDelorme
Copy link

First simple test with [version 10.0.26100.2894], the keyboard at my office has a single play/pause media button and it works !

I'll do more testing and longtime testing at home.

A question : could this evolution also lead to muting the music when a phone call is received ?

@dweymouth
Copy link
Owner

A question : could this evolution also lead to muting the music when a phone call is received ?

No idea, sorry

@FibreTTP
Copy link

I assume it's trying to read covers from AppData\Local\supersonic\covers\<some_uuid>?

Are the files in there supposed to be 0-bytes with an alternative data stream containing the actual image? Is the SMTC library expecting a normal file and crashing?

Image

@dweymouth
Copy link
Owner

Whoa, well that's the problem. I have no idea why your cached image files are 0 bytes and I'm surprised Supersonic is able to show covers at all on your system! They are supposed to be 300x300px JPGs. What a mystery! What server do you use?

@dweymouth
Copy link
Owner

It's also concerning that the SMTC APIs just crash when given a bad image. And I also didn't see any error code or any other way for the API to communicate an error instead of just crashing :(. I suppose I'll have to try to validate the image somehow beforehand, but first the mystery of why covers are being saved strangely for @FibreTTP. @CharlesDelorme was it able to show cover art in the OS media center for you without crashing?

@FibreTTP
Copy link

Haha, I use LMS.

Yep, looking at the LMS logs, it seems like Supersonic is requesting a cover art with an ID in the format of <im/tr>-<number>:<import_date> (this is presumably how LMS formats its track IDs).

Supersonic writes this filename directly to the filesystem, meaning on NTFS, the file will be called <im/tr>-<number> with an Alternate Data Stream named <import_date>.jpg.

LMS log examples (auth parameters removed and URL decoded):

[2025-Jan-17 17:07:18.575] 1 - [info] "wthttp: 10.64.72.2   GET /rest/getCoverArt?c=supersonic&f=xml&id=tr-14823:1724955552&size=300&v=1.15.0 HTTP/1.1 200 36215"
[2025-Jan-17 17:07:12.559] 1 - [info] "wthttp: 10.64.72.2   GET /rest/getCoverArt?c=supersonic&f=xml&id=im-2514:1665214745v=1.15.0 HTTP/1.1 200 33122"

@dweymouth
Copy link
Owner

Good find! I'll have to call some path sanitizing function (maybe just hashing the ID from the server could be fine) and then it should work. And it's good that this was discovered because I assume Supersonic itself has probably been unable to read its own cover cache files with LMS this whole time (unless Go handles reading Alternate Data Streams -- I'd never even heard of them before)

@CharlesDelorme
Copy link

Covers are in C:\Users[user]\AppData\Local\supersonic\3855131a-b91d-4193-a373-d7cf014f202d\covers and are updated (server is Navidrome [0.54.3]).

I had a hard way finding the "OS media center" but it simply showed when clicking on the network/sound/battery button on the task bar. I can confirm the cover is there too but the app is shown unknown ("Application inconnue" is french for "Unknow application") (when youtube player from a browser it says the browser name, when Foobar2000 is used, unknown).

Image

It also works clicking on the play/pause next/previous buttons in the media center

@CharlesDelorme
Copy link

CharlesDelorme commented Jan 18, 2025

Back home on windows 10 [version 10.0.19045.5247] with a Keyboard Corsair K55 pro XT. There are four keys : stop/previous/play|pause/next and all work.

When the musique is stoped, the name of the app is correctly shown.

Image

Image

I lost the play/pause key at a time (others were ok) but it came back.

I guess this works :-)

@tdkl
Copy link

tdkl commented Jan 18, 2025

Have same results on Windows 10 19045.5371, Logitech G413 TKL SE keyboard media keys all working now, cover is displayed (Navidrome 0.54.4).

Thank you very much, this was the only missing piece in this awesome app.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request help wanted Extra attention is needed os:windows
Projects
None yet
Development

No branches or pull requests