it-swarm.com.ru

Как создать TextInputLayout с OutlineBox программно

Я хочу создать TextInputLayout со стилем Widget.MaterialComponents.TextInputLayout.OutlinedBox. Я пробовал много способов, но не смог получить требуемый результат. Вот мой код.

TextInputLayout textInputLayout = new TextInputLayout(getActivity(),null,R.style.Widget_MaterialComponents_TextInputLayout_OutlinedBox);
textInputLayout.setHint("My Hint");
TextInputEditText editText = new TextInputEditText(textInputLayout.getContext());
textInputLayout.addView(editText);
parentView.addView(textInputLayout);

Я также попробовал:

TextInputLayout textInputLayout = new TextInputLayout(getActivity(),null,TextInputLayout.BOX_BACKGROUND_OUTLINE);

Я хочу создать вид, как это .  enter image description here

7
Deepak Vajpayee

ОБНОВЛЕНИЕ

Благодаря @ Майк М. 

Вам нужно использовать TextInputLayout.setBoxBackgroundMode() метод для использования стиля OutlineBox

setBoxBackgroundMode (int boxBackgroundMode)

  • Установите режим для фона окна (заполненный, контур или нет).

Тогда вам нужно использовать TextInputLayout.BOX_BACKGROUND_OUTLINE) Constants

ПРИМЕЧАНИЕ: Чтобы получить угол в OutlineBox объекта TextInputLayout, вам нужно использовать setBoxCornerRadii() method

ОБРАЗЕЦ КОДА

public class MainActivity extends AppCompatActivity {

    LinearLayout parentView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        parentView = findViewById(R.id.parentView);

        TextInputLayout emailTextInputLayout = new TextInputLayout(this, null, R.style.Widget_MaterialComponents_TextInputLayout_OutlinedBox);

        emailTextInputLayout.setHint("Please Enter Email Address");
        emailTextInputLayout.setBoxBackgroundMode(TextInputLayout.BOX_BACKGROUND_OUTLINE);
        emailTextInputLayout.setBoxCornerRadii(5, 5, 5, 5);
        TextInputEditText edtEmail = new TextInputEditText(emailTextInputLayout.getContext());
        emailTextInputLayout.addView(edtEmail);

        parentView.addView(emailTextInputLayout);


        TextInputLayout passTextInputLayout = new TextInputLayout(this, null, R.style.Widget_MaterialComponents_TextInputLayout_OutlinedBox);

        passTextInputLayout.setHint("Please Enter Password");
        passTextInputLayout.setBoxBackgroundMode(TextInputLayout.BOX_BACKGROUND_OUTLINE);
        passTextInputLayout.setBoxCornerRadii(5, 5, 5, 5);
        TextInputEditText edtPass = new TextInputEditText(passTextInputLayout.getContext());
        passTextInputLayout.addView(edtPass);

        parentView.addView(passTextInputLayout);


    }

}

РЕЗУЛЬТАТ

 enter image description here

На основе этого ответа: https://stackoverflow.com/questions/3246447/how-to-set-the-style-attribute-programmatics-in-Android

  • Динамическое изменение стиля в настоящее время не поддерживается. Вы должны установить стиль перед созданием представления (в XML).

Это причина того, что TextInputLayout программно не принимает установку стиля структуры в штучной упаковке.

Вот простое решение:

Вы можете использовать LayoutInflater

  • Создает файл макета XML в соответствующие ему объекты View.

DEMO

Создать новый макет

<?xml version="1.0" encoding="utf-8"?>
<Android.support.design.widget.TextInputLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    Android:id="@+id/userIDTextInputLayout"
    style="@style/Widget.MaterialComponents.TextInputLayout.OutlinedBox"
    Android:layout_width="match_parent"
    Android:layout_height="wrap_content"
    Android:layout_margin="10dp">

    <Android.support.design.widget.TextInputEditText
        Android:id="@+id/userIDTextInputEditText"
        Android:layout_width="match_parent"
        Android:hint="Enter User Name"
        Android:layout_height="wrap_content" />
</Android.support.design.widget.TextInputLayout>

AndroidX (+ Материальные компоненты для Android ):

<?xml version="1.0" encoding="utf-8"?>
<com.google.Android.material.textfield.TextInputLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    Android:id="@+id/userIDTextInputLayout"
    style="@style/Widget.MaterialComponents.TextInputLayout.OutlinedBox"
    Android:layout_width="match_parent"
    Android:layout_height="wrap_content"
    Android:layout_margin="10dp">

    <com.google.Android.material.textfield.TextInputEditText 
        Android:id="@+id/userIDTextInputEditText"
        Android:layout_width="match_parent"
        Android:hint="Enter User Name"
        Android:layout_height="wrap_content" />
</com.google.Android.material.textfield.TextInputLayout>

Теперь с помощью LayoutInflater добавьте это TextInputLayout в требуемый макет

public class MainActivity extends AppCompatActivity {

    LinearLayout rootView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        rootView = findViewById(R.id.rootView);

        View view = LayoutInflater.from(this).inflate(R.layout.temp_layout, null);
        TextInputLayout userNameIDTextInputLayout=view.findViewById(R.id.userIDTextInputLayout);
        TextInputEditText userNameInputEditText = view.findViewById(R.id.userIDTextInputEditText);
        userNameIDTextInputLayout.setHint("Please Enter User Name");
        rootView.addView(view);
    }
}

РЕЗУЛЬТАТ

 Screenshot of app with an outlined text input

Заметка

Если вы хотите добавить TextInputLayout из XML, пожалуйста, проверьте следующий ответ:

Если вы хотите добавить более 5 TextInputLayouts программным способом, рассмотрите возможность использования RecyclerView. Проверьте следующие ответы:

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

9
Nilesh Rathod

Вы можете использовать метод applyStyle, определенный в классе Theme. В Kotlin вы можете получить к нему доступ с помощью свойства theme в экземпляре Context (или подклассе).

Функция applyStyle позволяет добавить стиль к текущей теме, который определяет атрибуты темы, ссылающиеся на стили. После вызова этого метода вы можете передать атрибут в качестве третьего параметра View, например TextInputLayout, который будет применять желаемые стили при соблюдении темы.

Я использовал эту технику в Splitties (библиотека, которую я создал), и есть некоторая документация плюс примеры, которые должны вам помочь: https://github.com/LouisCAD/Splitties/blob/v3.0.0-alpha02/views-dsl /README.md#using-styles-defined-in-xml

Я еще не добавил первоклассную поддержку тем из Material Components в Splitties Views DSL, но вы можете сделать это самостоятельно и даже открыть вопрос, чтобы обсудить его, или внести свой вклад, чтобы он быстрее интегрировался.

1
Louis CAD