基线对齐的 TextInputLayout 和 Spinner

Posted

技术标签:

【中文标题】基线对齐的 TextInputLayout 和 Spinner【英文标题】:Baseline aligned TextInputLayout and Spinner 【发布时间】:2017-02-19 19:20:17 【问题描述】:

我尝试对齐微调器并按基线编辑文本,但它不起作用:

它在将支持库依赖项从 24.1.1 更新到 24.2.1(support-v4、appcompat-v7、设计)后开始发生。 这是我的 xml 代码:

        <RelativeLayout
            android:id="@+id/email_layout"
            android:layout_
            android:layout_
            android:orientation="horizontal">

            <android.support.v7.widget.AppCompatSpinner
                android:id="@+id/spinner"
                style="@style/MailSpinner"
                android:layout_
                android:layout_
                android:layout_alignParentEnd="true"
                android:dropDownWidth="wrap_content" />
            <android.support.design.widget.TextInputLayout
                android:id="@+id/text_input_layout"
                android:layout_
                android:layout_
                android:layout_marginEnd="8dp"
                android:layout_alignBaseline="@id/spinner"
                android:layout_toStartOf="@id/spinner"
                android:baselineAlignedChildIndex="0">
                <android.support.v7.widget.AppCompatEditText
                    android:id="@+id/edit_text"
                    android:layout_
                    android:layout_
                    android:hint="E-mail"
                    android:ellipsize="end"
                    android:imeOptions="actionNext"
                    android:inputType="textEmailAddress"
                    android:textSize="16sp"/>
            </android.support.design.widget.TextInputLayout>


        </RelativeLayout>

MailSpinner 样式:

<style name="MailSpinner" parent="Widget.AppCompat.Spinner.Underlined">
    <item name="android:background">@drawable/spinner_textfield_background</item>
    <item name="backgroundTint">@color/spinner_tint</item>
    <item name="backgroundTintMode">src_atop</item>
</style>

【问题讨论】:

请添加您的spinner_textfield_background drawable 和spinner_tint 颜色资源。 @Sevastyan 我无法再访问此代码 那很糟糕。虽然基线对齐,但Spinner 的下划线与EditText 的下划线不对齐。 【参考方案1】:

基本上TextInputLayout 没有为其父级提供基线值。我们需要通过扩展TextInputLayout 来传递EditText 的正确基线。这对我有用,但是,我不确定基线是否会由于来自TextInputLayout 的其他事件而改变。

public class CTextInputLayout extends TextInputLayout 
    public CTextInputLayout(Context context) 
        super(context);
    

    public CTextInputLayout(Context context, AttributeSet attrs) 
        super(context, attrs);
    

    public CTextInputLayout(Context context, AttributeSet attrs, int defStyleAttr) 
        super(context, attrs, defStyleAttr);
    

    @Override
    public int getBaseline()
    
        EditText editText = getEditText();
        return editText.getPaddingTop() + editText.getBaseline();
    

【讨论】:

【参考方案2】:

我认为提示标签浮动时这个版本更好

public class CTextInputLayout extends TextInputLayout 
public CTextInputLayout(Context context) 
    super(context);


public CTextInputLayout(Context context, AttributeSet attrs) 
    super(context, attrs);


public CTextInputLayout(Context context, AttributeSet attrs, int defStyleAttr) 
    super(context, attrs, defStyleAttr);


@Override
public int getBaseline() 
    EditText editText = getEditText();
    return getMeasuredHeight() - (editText.getMeasuredHeight() - editText.getBaseline());


【讨论】:

【参考方案3】:

这是在设置 TextInputLayout 错误文本时正确对齐的版本:

public class BaselineTextInputLayout extends TextInputLayout 
    public BaselineTextInputLayout(Context context) 
        super(context);
    

    public BaselineTextInputLayout(Context context, AttributeSet attrs) 
        super(context, attrs);
    

    public BaselineTextInputLayout(Context context, AttributeSet attrs, int defStyleAttr) 
        super(context, attrs, defStyleAttr);
    

    @Override
    public int getBaseline() 
        EditText editText = getEditText();
        if (editText == null)  return 0; 
        return editText.getTop() + editText.getBaseline();
    

【讨论】:

以上是关于基线对齐的 TextInputLayout 和 Spinner的主要内容,如果未能解决你的问题,请参考以下文章

将 SwiftUI 文本与另一个文本的基线和顶部对齐

CSS垂直对齐和基线位置

如何在 Jetpack Compose 中按基线对齐行元素

Apple Watch:如何在基线处对齐两个不同字体大小的标签?

将字段标签的基线与文本输入中的文本基线对齐

CSS之基线对齐