Почему никто не сделал прогнозный драйвер / библиотеку клавиатуры?

На мобильных устройствах мы привыкли к нашим устройствам, предвидя то, что мы печатаем, и выполняя или исправляя хотя бы некоторые из наших ошибок, повышая скорость ввода текста и, как мы надеемся, точность.

Начиная с T9, с ​​помощью интеллектуальных клавиатур на современных смартфонах и заканчивая логическим завершением чего-то вроде Swype, мобильные устройства становились все лучше и лучше в этом, но я поражен, почему это, похоже, не настаивает на настольных компьютерах.

Да, Word и т. Д. Могут автоматически корректироваться при вводе текста, но учитывая мощность, доступную для современного ПК, даже это бледнеет по сравнению с тем, что может делать смартфон среднего класса. Так почему же это не включено на уровне ОС для всего ввода текста?

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

Существуют ли такие решения? Если нет, то почему?

Редактировать: Возможно, драйвер не того уровня, как насчет библиотеки (DirectType?), Которую Microsoft или Apple предложили бы выполнить эту задачу для любого приложения, в котором она была нужна, с профилями для различных типов текста?

4 ответа

Решение

Это было сделано: "Dasher" является примером использования метода полу-предиктивного ввода для целей доступности. Обычно доступ является единственной причиной, по которой люди делают это, поскольку люди обычно учатся печатать быстрее, чем могут взаимодействовать с системой интеллектуального ввода.

T9 доступен, когда вы набираете короткое текстовое сообщение или пишете письмо. Ваш мобильный телефон знает о том, что вы делаете, поэтому можете включить или отключить T9 в зависимости от контекста. С другой стороны, драйвер клавиатуры не знает, что ты делаешь.

T9 полезен только при наборе коротких текстовых сообщений. Попробуйте набрать что-нибудь другое, и вы увидите слабость Т9. Например, разработчик, пишущий исходный код, или писатель, пишущий роман, имеют огромную разницу для функции автозаполнения. Это означает, что сделать автозаполнение вообще невозможно, что не будет раздражать большую часть времени. Кстати, доступны контекстные функции автозаполнения. Например, Visual Studio, приложение, используемое разработчиками для написания исходного кода, предлагает варианты того, что вы, возможно, захотите набрать, что позволяет писать быстрее и совершать меньше ошибок.

T9 был создан из-за отсутствия правильной клавиатуры: печатать с использованием восьми клавиш не так просто, как печатать на большой удобной клавиатуре с множеством клавиш. Когда вы печатаете на компьютере ключевое слово, я не вижу никакой причины иметь функцию автозаполнения в Microsoft Word или Блокноте, поскольку гораздо быстрее печатать текст, не сводя глаз с экрана (или клавиатуры), а также иметь дело с некоторыми автоматическими меню, всплывающими окнами и т. д. Просто написать несколько абзацев, затем проверить орфографию, чем начать писать слово, прокрутить список предлагаемых слов, выбрать ближайшее предложение, нажмите Enter, возможно, исправьте предложение, а затем начните вводить следующее слово.

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

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

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

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

Надеюсь, это поможет.

В дополнение к вышесказанному, стоимость умственного переключения контекста для обработки предиктивного текста (т. Е. Принятия решения о том, действительно ли это слово вы собираетесь написать, когда он предлагает его) больше, чем перестановка и перепечатывание слова для людей с достаточно высоким уровнем набора текста. скорость.

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