Отправка отложенных сообщений на дисплей Брайля без блокировки основного потока

Анализ моей проблемы.

Слепые люди используют программу чтения с экрана для взаимодействия с приложениями. Эти программы чтения с экрана произносят содержимое, сообщения и тому подобное с предпочтительной скоростью речи и другими настройками. С точки зрения разработчика, есть и несколько удобных функций: при передаче текста в программу чтения с экрана она может быть напористой (поэтому прервите программу чтения с экрана) или вежливой (программа чтения с экрана завершает чтение текущего текста, прежде чем перейти к следующему. текст).

Однако некоторые слепые (или слепоглухие) дополнительно или исключительно используют дисплей Брайля. Дисплей Брайля (в идеале) отображает текст, который читает программа чтения с экрана, или подходящую версию. В действительности многие программы чтения с экрана лишают пользователей дисплея Брайля определенной информации, если они не настраивают свои дисплеи Брайля для чтения журнала чтения с экрана вместо просмотра текущего приложения.

Я создаю аудио игру с поддержкой Брайля. Что само по себе необычно - большинство аудио игр - это просто аудио.

Моей первой проблемой было то, как заставить программу чтения с экрана произносить сообщения и одновременно передавать их на дисплей Брайля. Решением этой проблемы стала библиотека абстракций программы чтения с экрана Tolk

Он работает как рекламируется, но есть проблема, которую не удается решить: сообщения Брайля отправляются слишком быстро. Из-за использования брайлевских сообщений во многих программах чтения с экрана (если не во всех), если два сообщения отправляются одно за другим, они поступают почти одновременно, не давая пользователю времени прочитать первое сообщение до появления второго (если они заметили первое сообщение вообще).

В Толке есть функция Tolk_IsSpeaking() который возвращает истину, если программа чтения с экрана говорит, и ложь, если нет, ИЛИ, если программа чтения с экрана не реализует такую ​​функцию.


И это главная проблема: у большинства программ чтения с экрана есть буфер, в который передается текст для речи. Если утверждающее сообщение поступает, буфер просто сбрасывается перед добавлением нового сообщения. Это означает, что большинство программ чтения с экрана не знают, разговаривают ли они (в том числе NVDA и JAWS, которые являются моей основной целевой аудиторией), поэтому для тех, кто IsTalking всегда будет оценивать как ложное.

Следовательно, проверка, говорит ли программа чтения с экрана, ожидание ее остановки и последующая отправка следующих сообщений, не работают.

Другое решение, о котором я подумал, - это задержка между двумя сообщениями, которую пользователь может настроить по мере необходимости. Программа чтения с экрана будет говорить нормально, в то время как только сообщения Брайля задерживаются. Реализация этого в основном потоке - плохая идея, так как это заблокирует поток. Однако я не понял, как использовать другой поток для этой задачи.

Основной поток должен был бы начать и отправить сообщение Брайля, а затем поспать некоторое время.

Основной поток должен был бы проверить, завершается ли другой поток (без блокировки!), А затем отправить следующее сообщение.

Если у кого-то есть идея о том, как реализовать вышеупомянутое решение, или имеется в виду другое решение, я бы его по-настоящему оценил.

0 ответов

Другие вопросы по тегам