-
-
Notifications
You must be signed in to change notification settings - Fork 160
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
nih_plug_vizia: accessibility not working #174
Comments
The Vizia example uses winit and accesskit_winit to install accessibility on the window. There is currently no AccessKit adapter for the baseview crate, so no accessibility tree is exposed. Writing one would hopefully be similar to how we did it for winit. I see that baseview uses raw-window-handle so you should be able to use AccessKit's subclassing adapters. If you go this far, I'd recommend using egui instead because we ensure the AccessKit implementation isn't broken there. |
@DataTriny I'd love to switch to egui, however I don't know anything about it, yet. I wanted to learn about it, but well... the web version of egui seems to be entirely inaccessible for screen readers, all I get on egui.rs is an unlabelled graphic and an empty input field. |
To install accessibility on a window using subclassing, you have to first create the window hidden, install AccessKit hooks then show the window. This is fine for regular apps but I don't know if that would be an issue in the context of VST plugins where the window is a children of the DAW software. Also, baseview currently has no support for creating hidden windows and showing them later. Testing would have to be performed here to see if this path is worth taking. Otherwise AccessKit can directly be wired into baseview, but this would require significant architectural changes to the crate. Finally, nih_plug's widgets would have to be modified because they currently don't take accessibility into account. |
@DataTriny thank you. Itried switching to egui, but no success, same result as with Vizia. Here's my editor fn:
As you can see, really basic, but no accessibility. I then noticed that egui-baseview doesn't enable the accesskit feature by default, so I tried adding this to my cargo.toml:
It seems to work, as it now compiles accesskit into the bundle too, but still no success. Anything I missed? |
@Timtam baseview is the one responsible for managing the window and accessibility is tied to the window (on Windows and macOS). No matter which UI toolkit you use, if the windowing library doesn't cooperate nothing will happen. On Windows, accessibility should be activated when a window receives the WM_GETOBJECT message. As you can see in As stated above, there is a dirtier way to install accessibility by using |
@DataTriny thank you for this inforomation. Your initial comment "If you go this far, I'd recommend using egui instead because we ensure the AccessKit implementation isn't broken there." made me think that using Egui over Vizia would result in an accessible GUI. Does that mean that it'd be more helpful to open an issue over at baseview to ask for AccessKit support? |
@Timtam opening an issue towards the baseview repository would indeed be a good way to start the discussion. Feel free to mention me over there so I can add the necessary technical details. |
Hello,
the Vizia UI framework does have support for screen reader accessibility via the AccessKit crate. That is why I opted for this one in the hope of being able to write accessible VST plugins.
I noticed that nih_plug_vizia currently uses a custom patched version of vizia from here: https://github.com/robbert-vdh/vizia
I thus checked out the tag that is currently used in nih_plug_vizia and built the accesskit example
As you can see when running either Narrator (the windows built-in screen reader) or NVDA (freely available), accessibility support works just fine in standalone mode and all controls are clearly labeled and visible.
However when building a VST3 or CLAP and loading it in a DAW, e.g. REAPER (test version freely available), after focusing the window, the only feedback you get is "Vizia application". All controls are inaccessible. Does that have something to do with the baseview implementation used or something?
I'm waay to unexperienced with this, could someone more experienced take a look? It'd be really awesome to have a working plugin framework that can generate accessible VST/CLAP plugins from scratch available in Rust!
Thank you.
The text was updated successfully, but these errors were encountered: