缩放所有布局elevemts以适应横向模式

时间:2017-12-18 21:15:07

标签: android android-layout android-relativelayout landscape-portrait

我的活动布局定义如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_height="wrap_content"
    android:layout_width="match_parent"
    android:orientation="horizontal"
    android:padding="0dp"
    android:gravity="center">

    <LinearLayout
        android:orientation="vertical"
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:gravity="center"
            android:orientation="vertical">

            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center"
                android:text="@string/tv_example"
                android:textSize="45sp"
                android:textStyle="bold"
                android:textAlignment="center"
                android:maxLines="2"
                android:ellipsize="end"
                android:padding="5dp"
                android:background="@color/transparent">
            </TextView>

            <EditText
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center"
                android:inputType="number"
                android:text="@string/tv_example"
                android:textSize="40sp"
                android:textStyle="bold|italic"
                android:textAlignment="center"
                android:maxLines="1"
                android:ellipsize="end"
                android:padding="5dp"
                android:background="@color/transparent">
            </EditText>
        </LinearLayout>

        <ImageView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center|bottom"
            android:maxHeight="150dp"
            android:maxWidth="150dp"
            android:src="@mipmap/ic_launcher"
            android:padding="15dp"
            android:adjustViewBounds="true"
            android:scaleType="centerCrop"/>

        <Button
            android:id="@+id/button_item_edit"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center|bottom"
            android:alpha="0.3"
            android:clickable="false"
            android:ellipsize="end"
            android:padding="15dp"
            android:layout_margin="50dp"
            android:text="@string/button_edit"
            android:textAlignment="center"
            android:textSize="25sp"/>
    </LinearLayout>
</RelativeLayout>

在肖像模式下产生以下效果:

[portrait mode[1]

但是,当将其切换到横向模式时,按钮会消失:

landscape mode

如何在横向模式下显示丢失的TextView, 或者更好 - 缩放所有项目以适应新的方向?

基本上,文字观点是重要的观点 - 我希望它们可见,即使以缩小Button和\或ImageView

的尺寸为代价

我尝试从包含android:layout_weight="1"的最内层LinearLayout删除TextView行 -

这会使文本在横向模式下显示,但会使Button消失:

(它还使整个布局在纵向模式下与顶部对齐而不是屏幕中心)

no weight landscape

由于

3 个答案:

答案 0 :(得分:3)

这种情况下的最佳做法是拥有 2个布局文件,每个方向一个。

在/ res目录下创建一个新文件夹,并在Android Studio中将其命名为layout-land,并将具有相同命名的横向布局xml文件放入。

根据方向更改,Android OS将使用该文件夹中的xml文件,而不是尝试调整原始文件夹。这是定向支持的推荐方法。

答案 1 :(得分:0)

在您的xml中,您提到了按钮 android:layout_margin =“50dp”,这会影响您的布局渲染以推送元素。 这导致隐藏textview。尝试使用较少的边距修改布局或使用填充作为替代。这可能有助于保留渲染中的所有元素。

答案 2 :(得分:0)

@Adiel - 在您的 /res 目录下创建一个新文件夹,并在 Android Studio 中将其命名为 layout-land,并将您的布局 xml 文件放置在具有相同命名的景观中。

完全同意这一点,因为 Android Studio 为您提供了根据要求创建单独的选项。确保将任何 layout_width 和 layout_heights 定义为 match_parent 似乎不起作用。