我正在创建一个屏幕来输入引脚编号。我使用了垂直线性布局。在这个线性布局中,我创建了4个水平线性布局。在这些线性布局中,我有固定宽度和高度的按钮。对于相同字体大小的按钮文本,它显示得很好,但当我减小最后两个按钮的字体大小时,这两个按钮将在水平线性布局中剪裁。请查看屏幕截图以获得更好的解释。
具有不同的按钮字体大小
具有相同的按钮字体大小(40sp)
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
style="@style/RootLayout"
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<include layout="@layout/actionbar_login"/>
<TextView
style="@style/TextViewLarge"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:layout_marginTop="40dp"
android:text="@string/welcome"/>
<TextView
style="@style/TextViewNormal"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:layout_marginTop="5dp"
android:text="@string/enter_pin"/>
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:layout_marginTop="30dp"
android:orientation="horizontal">
<View
android:layout_width="15dp"
android:layout_height="15dp"
android:layout_marginRight="20dp"
android:background="@drawable/circle_gray"/>
<View
android:layout_width="15dp"
android:layout_height="15dp"
android:layout_marginRight="20dp"
android:background="@drawable/circle_gray"/>
<View
android:layout_width="15dp"
android:layout_height="15dp"
android:layout_marginRight="20dp"
android:background="@drawable/circle_gray"/>
<View
android:layout_width="15dp"
android:layout_height="15dp"
android:layout_marginRight="20dp"
android:background="@drawable/circle_gray"/>
<View
android:layout_width="15dp"
android:layout_height="15dp"
android:layout_marginRight="20dp"
android:background="@drawable/circle_gray"/>
<View
android:layout_width="15dp"
android:layout_height="15dp"
android:background="@drawable/circle_gray"/>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_horizontal"
android:orientation="horizontal">
<Button
android:layout_width="70dp"
android:layout_height="70dp"
android:layout_marginRight="30dp"
android:background="@drawable/selector_pin_button"
android:text="@string/_1"
android:textColor="@drawable/selector_pin_button_text"
android:textSize="40sp"/>
<Button
android:layout_width="70dp"
android:layout_height="70dp"
android:layout_marginRight="30dp"
android:background="@drawable/selector_pin_button"
android:text="@string/_2"
android:textColor="@drawable/selector_pin_button_text"
android:textSize="40sp"/>
<Button
android:layout_width="70dp"
android:layout_height="70dp"
android:background="@drawable/selector_pin_button"
android:text="@string/_3"
android:textColor="@drawable/selector_pin_button_text"
android:textSize="40sp"/>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_horizontal"
android:orientation="horizontal">
<Button
android:layout_width="70dp"
android:layout_height="70dp"
android:layout_marginRight="30dp"
android:background="@drawable/selector_pin_button"
android:text="@string/_4"
android:textColor="@drawable/selector_pin_button_text"
android:textSize="40sp"/>
<Button
android:layout_width="70dp"
android:layout_height="70dp"
android:layout_marginRight="30dp"
android:background="@drawable/selector_pin_button"
android:text="@string/_5"
android:textColor="@drawable/selector_pin_button_text"
android:textSize="40sp"/>
<Button
android:layout_width="70dp"
android:layout_height="70dp"
android:background="@drawable/selector_pin_button"
android:text="@string/_6"
android:textColor="@drawable/selector_pin_button_text"
android:textSize="40sp"/>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_horizontal"
android:orientation="horizontal">
<Button
android:layout_width="70dp"
android:layout_height="70dp"
android:layout_marginRight="30dp"
android:background="@drawable/selector_pin_button"
android:text="@string/_7"
android:textColor="@drawable/selector_pin_button_text"
android:textSize="40sp"/>
<Button
android:layout_width="70dp"
android:layout_height="70dp"
android:layout_marginRight="30dp"
android:background="@drawable/selector_pin_button"
android:text="@string/_8"
android:textColor="@drawable/selector_pin_button_text"
android:textSize="40sp"/>
<Button
android:layout_width="70dp"
android:layout_height="70dp"
android:background="@drawable/selector_pin_button"
android:text="@string/_9"
android:textColor="@drawable/selector_pin_button_text"
android:textSize="40sp"/>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_horizontal"
android:orientation="horizontal">
<Button
android:layout_width="70dp"
android:layout_height="70dp"
android:layout_marginRight="30dp"
android:background="@drawable/selector_pin_button"
android:text="0"
android:textColor="@drawable/selector_pin_button_text"
android:textSize="40sp"/>
<Button
android:layout_width="70dp"
android:layout_height="70dp"
android:layout_marginRight="30dp"
android:background="@drawable/selector_pin_button"
android:text="@string/_0"
android:textColor="@drawable/selector_pin_button_text"
android:textSize="40sp"/>
<Button
android:layout_width="70dp"
android:layout_height="70dp"
android:background="@drawable/selector_pin_button"
android:text="0"
android:textColor="@drawable/selector_pin_button_text"
android:textSize="40sp"/>
</LinearLayout>
</LinearLayout>
这是因为Android中的Button作为视图有一些基本参数(样式),用于将文本设置为"文本"参数,将图像设置为"背景"等等。只需尝试为您的任务使用其他视图元素即可。例如,简单的TextView。
另一个问题是,它是你的父母ViewGroup的包装,这可能会因为不同的原因而增加他的规模。