Флаттер текстовое поле на fireOS firetv / firestick в верхней части текстового поля - PullRequest
0 голосов
/ 10 апреля 2020

При вызове текстового поля на флаттере в fireOS на устройствах Fire TV для поиска, например, виртуальная клавиатура fireOS появляется в верхней части текстового поля и не работает, как на других android устройствах, где клавиатура находится внизу и текстовое поле.

На android устаревшем, например, я могу использовать виджет edittext, и та же клавиатура появляется сверху, но все, что я печатаю, обновляет контроллер на самой виртуальной клавиатуре, потому что клавиатура имеет свое собственное текстовое поле или редактировать текст. Поэтому моя проблема в том, как я могу обновить текст редактирования на виртуальной клавиатуре firetv с помощью флаттера.

enter image description here

1 Ответ

0 голосов
/ 01 мая 2020

Ладно, я нигде не нашел ответа, поэтому мне пришлось заняться каким-то хакерским делом, вот как я его получил, так как flutter - это не go.

Обзор решения:

1.- Итак, сначала проверьте, что вы работаете на Android, вы можете сделать это с помощью if (Platform.is Android) на флаттере.

2.- Если вы на самом деле работаете на android, вы можете открыть канал платформы для нативного android, чтобы проверить фактического производителя (я опубликую, как кодировать ниже).

3.- Проверьте имя производителя или устройства на "Amazon" или "Kindle" или что-то еще, если if (string.contains ("")) добьется цели.

4.- Открыть снова канал платформы на Native Android и откройте диалоговое окно Alert с EditText, перехватите полученную строку и верните ее в флаттер.

И вот так я заставил клавиатуру firetv работать под флаттером.

    if (Platform.isAndroid){

      checkOs().then((String osName){
        print("Device running on: $osName");
        if(osName.contains("Amazon") || osName.contains("AFTN")){
          fireTvKeyboardInput().then((String result){
            buscarTitulo(result);
          });
        }else{
          _showDialog(); // Keyboard for NON FIREOS devices on Android.
        }
      });

    }else{
      //IF Device is not Android Eg. IOS
      _showDialog();
    }

Теперь есть две функции, которые я использовал "checkOs" и "fireTvKeyboardInput", вот код:

Future<String> checkOs() async {
  String myResult = "";
  try {
    myResult = await platform.invokeMethod("checkOS", <String, dynamic>{
      'param1': "hello",
    });
  }catch (e){
    print ("exception: $e");
  }
  return myResult;
}

Future<String> fireTvKeyboardInput() async {
  String myResult = "";
  try {
    myResult = await platform.invokeMethod("fireKeyBoard", <String, dynamic>{
      'param1': "hello",
    });
  }catch (e){
    print ("exception: $e");
  }
  return myResult;
}

На нативном Android, вот код:

                    if(call.method == "checkOS"){
                    val operatingSystem = android.os.Build.MANUFACTURER + "- " + android.os.Build.MODEL
                    result.success(operatingSystem)
                }

                if(call.method == "fireKeyBoard"){

                        val alert = AlertDialog.Builder(this)
                        alert.setMessage("Search")
                        // Set an EditText view to get user input
                        val input = EditText(this)
                        input.hint = "Enter Text"
                        input.inputType = InputType.TYPE_CLASS_TEXT
                        alert.setView(input)
                        input.setOnKeyListener { view, keyCode, keyEvent ->
                            if (keyCode == 66) {
                                val imm = getSystemService(Context.INPUT_METHOD_SERVICE) as InputMethodManager
                                imm.hideSoftInputFromWindow(input.windowToken, 0)
                            }
                            false
                        }
                        alert.setPositiveButton("Ok") { dialog, whichButton ->
                            result.success(input.text.toString());
                        }
                        alert.setNegativeButton("Cancel") { dialog, whichButton ->
                            // Canceled.
                        }
                        alert.show()

                }
...