13

我想用 Widget.MaterialComponents.TextInputLayout.OutlinedBox 样式创建 TextInputLayout。我尝试了很多方法,但无法获得所需的结果。这是我的代码。

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);

我想创建这样的视图。在此处输入图像描述

4

3 回答 3

24

更新

感谢@Mike M。

您需要使用TextInputLayout.setBoxBackgroundMode()方法来使用 OutlineBox 样式

setBoxBackgroundMode (int boxBackgroundMode)

  • 设置框的背景模式(填充、轮廓或无)。

然后你需要使用TextInputLayout.BOX_BACKGROUND_OUTLINE)常量

注意:要在 TextInputLayout 的 OutlineBox 中获得角落,您需要使用setBoxCornerRadii()方法

示例代码

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);


    }

}

输出

在此处输入图像描述

基于这个答案:https ://stackoverflow.com/questions/3246447/how-to-set-the-style-attribute-programmatically-in-android

  • 当前不支持动态样式更改。您必须在创建视图之前设置样式(在 XML 中)。

这就是TextInputLayout不以编程方式接受设置轮廓盒装样式的原因。

这是简单的解决方案:

您可以使用LayoutInflater

  • 将布局XML文件实例化为其对应的View对象。

演示

创建新布局

<?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);
    }
}

输出

带有轮廓文本输入的应用程序屏幕截图

笔记

如果TextInputLayout要从 XML 添加,请查看以下答案:

如果您想以编程方式添加超过 5TextInputLayout秒,请考虑使用RecyclerView. 查看以下答案:

希望这可以帮助!

于 2018-10-26T04:59:28.993 回答
1

您可以使用类applyStyle上定义的方法Theme。在 Kotlin 中,您可以使用(或子类)实例theme上的属性访问它。Context

applyStyle功能允许您向当前主题添加样式,该样式定义了引用样式的主题属性。调用此方法后,您可以将属性作为 a 的第三个参数传递View, like TextInputLayout,它将在尊重主题的同时应用所需的样式。

我在 Splitties(我编写的一个库)中使用了这种技术,并且有一些文档和示例可以帮助您:https ://github.com/LouisCAD/Splitties/blob/v3.0.0-alpha02/views-dsl/README .md#using-styles-defined-in-xml

我还没有在 Splitties Views DSL 中添加对 Material Components 主题的一流支持,但你可以自己做,你甚至可以打开一个问题来讨论它,或者做出贡献,以便它更快地集成。

于 2019-01-14T13:38:11.583 回答
0

我就是这样做的,请注意您必须将 TextInputLayout 的上下文传递给 TextInputEditText 以便正确传递样式。

[来源:https://material.io/components/text-fields/android#fill-text-field]

val lp = LinearLayout.LayoutParams(
    LinearLayout.LayoutParams.MATCH_PARENT,
    LinearLayout.LayoutParams.WRAP_CONTENT
)

val etInputLayout = TextInputLayout(context)
lp.setMargins(16, 16, 16, 16)
etInputLayout.layoutParams = lp
etInputLayout.boxBackgroundMode = TextInputLayout.BOX_BACKGROUND_OUTLINE
etInputLayout.boxBackgroundColor = Color.WHITE
etInputLayout.setBoxCornerRadii(8f, 8f, 8f, 8f)

val etInput = TextInputEditText(etInputLayout.context)
etInput.layoutParams = lp
etInputLayout.addView(etInput, lp)
于 2021-03-27T11:30:07.450 回答