Я подал радар об этом для iOS 13, потому что у меня есть двуязычное японское / английское приложение. Некоторые поля являются японскими, а некоторые - английскими, поэтому, очевидно, имеет смысл представить пользователю правильный тип клавиатуры, вместо того чтобы заставлять их переворачиваться назад и вперед 20 раз.
Для этого был обходной путь, и это было послеUIKit вызывает textInputMode, в главном потоке вы можете сделать это:
// has to be done after the textInputMode method is called
if #available(iOS 13, *) {
textField.keyboardType = textField.keyboardType
}
Это заставит клавиатуру перезагрузиться после ответа с нужным вам textInputMode. Я проинформировал их об ошибке и об обходном пути для получения правильного поведения.
Так что в iOS 13.1 ошибка не была исправлена, однако они заблокировали мой обходной путь.
Приятно. Я не буду сообщать им об ошибках снова. Скорее, если я найду обходной путь, я просто воспользуюсь им.
Так что, похоже, теперь они молча отключают эту функцию. И это особенность, это буквально цель этого вызова метода, чтобы выяснить, какой режим ввода должен быть представлен пользователю.
Он все еще работает нормально хотя, если у вас есть другойязык и хочу выбрать английский.
Так что, если мой пользователь установит японский язык в качестве выбора клавиатуры, тогда я могу заставить английскую клавиатуру подняться. Просто не наоборот. Любые попытки получить японский режим ввода заканчиваются на английской клавиатуре.
РЕДАКТИРОВАТЬ:
Существует другой путь, который вы можете обойти, но он включает в себя обнаружение и использование внутреннего API, которыйне просто. Вы должны были бы по существу найти функции, используемые для управления результатами нажатия кнопки глобуса. Если вы сделаете это, вы по сути будете имитировать нажатия пользователя, и у него будет широкий диапазон эффектов, то есть клавиатура будет заменена и для других приложений. Так что это не рекомендуется, 100% это не получится в App Store. Я не хочу публиковать его из-за результатов моего последнего обходного пути.
Я думаю, что понять Apple не так просто. Все, что я знаю, это:
- API не функционирует как опубликовано
- было сообщено, и они не исправили ошибку
- с момента сообщения о нихсломал (намеренно или нет) обходной путь
Таким образом, будущие обходные пути следует скрывать до тех пор, пока их намерения не станут ясными и / или они не исправят эту ошибку (что они и должны делать). Простая отмена части API без публикации изменений является серьезной ошибкой.