-
Notifications
You must be signed in to change notification settings - Fork 30.2k
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
refine when accessibility signals play in code editor #204257
Comments
+1 |
Thanks for the issue. Re:
I have commented in #204258. This is a result of using Re:
Tracking the issue of playing the alert/audio cue repeatedly while within the line here: #188285 For now, given you find this disruptive, could you disable the alerts and keep the audio cues on? Also cc @rperez030 and @jooyoungseo |
Another problem that someone brought to my attention is that, if one doesn't type very fast, you start getting alert as you type which can be distracting. One possibility that comes to mind, and I don't know how feasible that would be, is to use delays. for example, when moving the cursor between lines, the status message would only be triggered if someone remains for, let's say, more than a second in a given line, which would indicate they are actually listening to the content and not just navigating. The delay while typing should be even longer, probably 5 seconds, which would indicate that the person stopped typing. |
Thanks for this feedback @rperez030. Seems like we should probably disable the in line audio cues (warning, error, debugger on breakpoint) until this is sorted out. I don't think it will be a quick fix. Do you think these should be disabled as a candidate @rperez030 or is disabling them in insider's sufficient? |
I am leaning toward just fixing this in insider's. Users can disable the settings if they find them disruptive. |
I think using |
I agree with some of the above, but the real problem is the messages don’t make since. If you are sighted and you have a red line under two characters you know there is a problem, there. If you are blind and the line says error and nothing else, how is a screen reader user supposed to know where that error is? I have been coding long enough that I can figure it out but if this is supposed to help people find errors quickly. The current method is not helping blind people find the error it is only helping find the line. I might be wrong because I am 100% blind and the last time, I could see to code was with THE Commodores 20 and 64, and the Atari 800XL But if I made this feature for python and someone typed the following: df my_function(): Now if I move to the line, I get an Error and a warning. I have no idea what the warning is and if I am a new python programmer, I have no idea what the error is. Let’s say my cursor is on my_function and I arrow left and right. It should not keep saying errors and warning that is true because hopefully it is clear that the error is on the df. If I arrow over the part of the code that has the red underline or whatever it is then it should say error and or beep, but it shouldn’t say error unless I am arrowing on the error, or I arrow up and down on to the line with error. That way I can move around without hearing a lot of repeated warnings and errors that make no since and make it hard for a lesser skilled screen reader user to even read the code. If you can’t tell what the error is like the whole line is redlined, then it should only say error or warning once when I arrow to that line or that line is focused by jumping to it by a goto or search. It should only beep once as well. The error messages should also be off by default. Having the sounds on by default is fine but having the messages on by default is just too much. There is another problem too. As I backspace it says error and warning a lot. I am sure that is a part of this same problem. I personally think that the error beep should not be at 300 milliseconds by default when you stop typing. So many coders who are blind and use this use this to learn coding as well as code on a regular basis. For those of us who type fast enough and think in code 300 MS is fine but for many people who are learning and using code completion get more error reports because they don’t complete a line of code fast enough. I think the default should be closer to 3 seconds before it starts alerting you that you have done something wrong. This gives a blind person time to review their line of code and it will help if they are just making a correction and get rid of the beep, beep, beep, that we get right now. The error beeps and messages if on should be quick when you land on a line but not while you’re typing. Remember when it all comes down to it this is just an indicator that there is something wrong. If a person wants to know what is wrong as a blind user, they will do CTRL+SHIFT+m to get the messages. If it read out what the error was rather than just error, error, error, maybe it would help but even that could be too annoying. It is better to indicate and then let the user press a key to read what is being indicated. That way if a person needs more, they can activate more information. If you give them too much, they can’t get rid of it as easily. It is like too much cold is better than too much hot. I can put on a lot of wintry weather gear to stay warm but if I must take off all my clothes to stay cool people are going to go nuts. If a person who is not extra skilled with a screen reader hears too much, they go nuts . If they get indications that there is a problem and can ask for more help, then that makes for a powerful tool. All these things should have settings which so far, they do. The problem is many of the default settings right now are both good and bad Speed for beep bad, number of messages bad. Having error beeps on by default good. Easy to get to errors and back good. WE want information but be as a sighted person would not want their whole screen flashing bright red for each two character error. We don’t’ want to hear to much. We do need to be able to know what is being indicated though. |
@krperry thanks for your thoughts, I consulted with screen reader users before enabling this by default. I'm happy to revisit that though, as I indicated above, since it seems there are some issues with the experience that will be addressed over time. |
I know you did. I also know it is important to understand the range of skill levels. Those who have high multi modal skill levels may want more but those who have lower may have trouble switching away from the higher because of their lower skills. It is better to have good lower amounts of information that can be set higher for those with the high skills to do it rather than frustrating low skill coders before they even get started.
Wow did I just write that. I hope that makes since because I am not sure I can clean it up much.
From: Megan Rogge ***@***.***>
Sent: Monday, February 5, 2024 10:34 PM
To: microsoft/vscode ***@***.***>
Cc: krperry ***@***.***>; Mention ***@***.***>
Subject: Re: [microsoft/vscode] Problematic Behavior of Audio Cues and Accessibility-Related Text Notifications in Code Editor (Issue #204257)
@krperry <https://github.com/krperry> thanks for your thoughts, I consulted with screen reader users before enabling this by default.
I'm happy to revisit that thought as I indicated above since it seems there are some issues with the experience that will be addressed over time.
—
Reply to this email directly, view it on GitHub <#204257 (comment)> , or unsubscribe <https://github.com/notifications/unsubscribe-auth/AB5J6YIUBG6VOOEOFL7HOUDYSGQDLAVCNFSM6AAAAABCYMOZ2OVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTSMRYG4ZDIMBQGI> .
You are receiving this because you were mentioned.Message ID: ***@***.***>
|
Given the feedback we're receiving, I would feel inclined for a candidate. I still believe having them on by default is a good idea, but at least I could not anticipate the disruption during inline cursor navigation, and especially while typing. |
@krperry I have the same problem that you have in this case since I also don't see what is being communicated visually, but I suspect this is somewhat ambiguous to everyone. Using your example, if I arrow over the df part of the code I get a warning. If I then use the shortcut to reveal the tooltip (CTRL +K followed by CTRL +I), I get the following: ""df" is not definedPylancereportUndefinedVariable(function) df: AnyView Problem (Alt+F8)". in other words, Pylance believe df could be an undefined variable and it is triggering a warrning, not an error, so although not verry helpful, it seems like we are getting the right alert. If I then move to the name of the function, I get an error and a warning combine, and the tooltip reveals the following: ""df" is not definedPylancereportUndefinedVariableStatements must be separated by newlines or semicolonsPylance"my_function" is not definedPylancereportUndefinedVariable(function) my_function: AnyView Problem (Alt+F8)". In other words, we are still carrying the warning from the first portion of the line + what it believes is another statement in the same line, which is treated like an error. Helpful or not, this leads me to believe we are receiving the same information via the alerts that a sighted user is receiving visually. I also can see how all of this wouldn't make any sense to someone who is getting started, whether blind or sighted, but a blind student would have to deal with the overhead of having to figure out the UI itself and the interaction with the screen reader. In that case, it probably make sense to suggest the beginner user to disable the alerts and rely on the problems pane. To me, there are 3 problems here that need addressing:
I'm sure we'll sort all of this out in time. |
I think you miss understand. I just talked to a sighted coder. The df has a red light bulb or something like that. If I error through the line right and left it shouldn’t be giving me warning on the rest of the line unless you are visually getting a warning on the rest of the line. According to the sighted coder I just talked to he sees only the warning on the df I wouldn’t have to do the information if it would say error when I arrowed to the df but not on the rest. Arrowing up and down are different because that should indicate the error as I move to the line. Then I should be able to move right and left and find warnings or errors by sound or alert if set.
As for number 3 in your comment below I think just setting the delay later is better than disabling the errors totally when typing.
From: Roberto Perez ***@***.***>
Sent: Tuesday, February 6, 2024 11:48 AM
To: microsoft/vscode ***@***.***>
Cc: krperry ***@***.***>; Mention ***@***.***>
Subject: Re: [microsoft/vscode] Problematic Behavior of Audio Cues and Accessibility-Related Text Notifications in Code Editor (Issue #204257)
I agree with some of the above, but the real problem is the messages don’t make since. If you are sighted and you have a red line under two characters you know there is a problem, there. If you are blind and the line says error and nothing else, how is a screen reader user supposed to know where that error is?
@krperry <https://github.com/krperry> I have the same problem that you have in this case since I also don't see what is being communicated visually, but I suspect this is somewhat ambiguous to everyone. Using your example, if I arrow over the df part of the code I get a warning. If I then use the shortcut to reveal the tooltip (CTRL +K followed by CTRL +I), I get the following: ""df" is not definedPylancereportUndefinedVariable(function) df: AnyView Problem (Alt+F8)". in other words, Pylance believe df could be an undefined variable and it is triggering a warrning, not an error, so although not verry helpful, it seems like we are getting the right alert. If I then move to the name of the function, I get an error and a warning combine, and the tooltip reveals the following: ""df" is not definedPylancereportUndefinedVariableStatements must be separated by newlines or semicolonsPylance"my_function" is not definedPylancereportUndefinedVariable(function) my_function: AnyView Problem (Alt+F8)". In other words, we are still carrying the warning from the first portion of the line + what it believes is another statement in the same line, which is treated like an error. Helpful or not, this leads me to believe we are receiving the same information via the alerts that a sighted user is receiving visually.
I also can see how all of this wouldn't make any sense to someone who is getting started, whether blind or sighted, but a blind student would have to deal with the overhead of having to figure out the UI itself and the interaction with the screen reader. In that case, it probably make sense to suggest the beginner user to disable the alerts and rely on the problems pane.
To me, there are 3 problems here that need addressing:
1. The same alert is repeated as I navigate for every character. It should only be announced when it changes, for example, when I move to the second statement in the above example.
2. alerts shouldn't be announced for the wrong line. If I add the following code, and I move quickly from top to bottom with the down arrow key, NVDA will announce error for the second line when it shouldn't.:
df my_function():
print ("Hello from a function")
3. Alerts shouldn't be fired when the user is supposed to be typing or it would cause disruption.
Point 2 could be addressed by the use of alerts, but alerts are handled in different ways by voiceover and Windows based screen readers. As we saw when we were testing the first version of this, Voiceover cancels the read out of the line when the alert is fired. Using status on macOS and alert on Windows might be a solution, but even that could potentially be disrupted for someone who relies on braille only since the alert will be triggered when the cursor reach the line anyway. I only use Braille for support and certainly know when navigating a file quickly, so it wouldn't affect me. To me, the ideal solution for point 2 could be using status, but managing the time when the alert is fired. Another possibility would be not to have alerts at all during inline navigation. I personally don't need them at all in that case, but perhaps I'm just used to not having them and figurint out what is wrong by reading the line.
Point 3 could be addressed by waiting until the user is idle for a few seconds after typing alphanumeric keys to fire aan alert given that it is possible, or by not firing alerts at all when entering characters in the editor.
I'm sure we'll sort all of this out in time.
—
Reply to this email directly, view it on GitHub <#204257 (comment)> , or unsubscribe <https://github.com/notifications/unsubscribe-auth/AB5J6YNUZEOK352XKHBB7MLYSJND7AVCNFSM6AAAAABCYMOZ2OVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTSMZQGMZTANRVGI> .
You are receiving this because you were mentioned.Message ID: ***@***.***>
|
Off by default would be better than disabled.
From: Roberto Perez ***@***.***>
Sent: Tuesday, February 6, 2024 10:53 AM
To: microsoft/vscode ***@***.***>
Cc: krperry ***@***.***>; Mention ***@***.***>
Subject: Re: [microsoft/vscode] Problematic Behavior of Audio Cues and Accessibility-Related Text Notifications in Code Editor (Issue #204257)
Thanks for this feedback @rperez030 <https://github.com/rperez030> .
Seems like we should probably disable the in line audio cues (warning, error, debugger on breakpoint) until this is sorted out. I don't think it will be a quick fix. Do you think these should be disabled as a candidate @rperez030 <https://github.com/rperez030> or is disabling them in insider's sufficient?
Given the feedback we're receiving, I would feel inclined for a candidate.
I still believe having them on by default is a good idea, but at least I could not anticipate the disruption during inline cursor navigation, and especially while typing.
—
Reply to this email directly, view it on GitHub <#204257 (comment)> , or unsubscribe <https://github.com/notifications/unsubscribe-auth/AB5J6YMBIQRSG3O5BBSCK5LYSJGWLAVCNFSM6AAAAABCYMOZ2OVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTSMZQGEYDCNRSG4> .
You are receiving this because you were mentioned.Message ID: ***@***.***>
|
Meeting notes created with @hediet
|
@jooyoungseo and @rperez030 , we are considering allowing line and column change accessibility signals from being debounced separately. When a user navigates between lines and lands in a column with a marker (for example error, if the line and column related signals are debounced separately, this means the sound could play twice. I'm wondering if we should have separate sounds / announcements to indicate:
|
a signal should not play twice, even if the user happens to land in a place where both the line and the column has a marker. That wouldn't make sense from a ux perspective in my opinion. For a user that relies on speech, when navigating by line with the up or down arrow keys, the position of the cursor within the line doesn't matter, unless the user is going to take an action on that particular line. For a screen reader user that relies on braille, it doesn't matter either because a braille display can only display one flash message at a time. |
Cases: x = debounce of line change signal
Note that inherent in this "play signal E" notion is that the position has not changed by the time that occurs. If the position has changed, we will cancel all debounced events. |
We will need to test to see if The reason we switched to that was characters in the editor when typing were not being read as that announcement was getting overridden by the |
aria.alert could potentially interrupt the reading of the current line in macOS. What about the use of a delay system as proposed in PR #205320? That sounds like a more definitive solution to the problem of managing signals to be, given that we could incorporate that work. |
Next, there is the difference between errors, warnings, etc. and breakpoints, folded areas, etc. What should we call these? Diagnostics: errors, warnings, etc. |
@rperez030 yes, we're investigating doing something like that. However, isn't it still true that an |
status messages are queued, but if the user does something such as moving around or typing before the status message is announced, the queue is overridden. Playing audio cues when they are no longer relevant I think is more of a concern for me. |
good to know, so seems we can stick with using |
@meganrogge can you verify? |
This all seems to be working better. I stil have to tell students when they want to make the delay when the error sounds are played they have to go to settings and sett the first itme which is I think Hover delay to something like 1 to 5 seconds. They can't just find that setting because it doesn't say "this slows down how often accessibility sounds happen". At least the setting can be set though. All the other stuff in this issue works so much better. The only one that is still a bit anoying is if you have an error in a line and you are typing to fix the error while in the error. Every key press beeps like the error. I am not sure there is much you can do about that and once you fix the error it stops which is great. I would consider this issue is fixed. |
That is odd, it should be delayed by 1 second. |
A 1-second delay, in my opinion, does not significantly improve user experience. Ideally, this delay should be configurable, with a default setting of at least 3 seconds. setting |
@rperez030 thanks for that feedback. @hediet what do you think about making this configurable? |
I'm all up for making the delays configurable! Can you add the settings? |
Type: Bug
I'm grouping together in this single issue several issues related to audio cues and accessibility-related text notifications in the editor. This is because they appear to be closely related and likely share a common cause. It is suspected that the triggering mechanism for both the audio cue and the text alert is the same, leading to the observed problematic behavior.
In the Visual Studio Code editor, there are issues related to the audio cues that have been present in previous versions. Additionally, with the introduction of accessibility-related text notifications in v1.86, new problems have arisen. These notifications, intended for screen reader users, are triggered when the cursor encounters lines with errors, warnings, breakpoints, etc. The issues with these features are as follows:
Both the audio cues and accessibility-related text notifications are triggered whenever the cursor moves within the line, such as when using Control+left/right to navigate to the previous/next word. This is particularly disruptive for the text notifications, as the repeated reading of the word "error", "warning", etc., often interrupts the normal verbalization of the screen reader. It would be more effective if these cues and notifications were only triggered when moving to a different line.
There appears to be a slight delay before the accessibility-related notification is announced. If the user moves too quickly between lines, the notification is not read in sync with the corresponding line, or sometimes it is read multiple times. It would be more efficient if the notification for a line was cancelled when the user moves to another line, ensuring it is always synchronized with the appropriate line.
An advanced approach could be to have different audio cues for line-specific errors/warnings/breakpoints and "inline" errors/warnings/breakpoints. One suggestion would be to use the same sound but with different pitches for these two types of cues. This would not be necessary for certain audio cues that are only line-specific (such as folded code) or triggered by specific events (such as task audio cues).
VS Code version: Code 1.86.0 (0504748, 2024-01-31T10:28:19.990Z)
OS version: Windows_NT x64 10.0.19045
Modes:
The text was updated successfully, but these errors were encountered: