缩放所有布局元素以适应横向模式
Scale all layout elevemts to fit landscape mode
我有一个 activity 布局定义如下:
<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>
在纵向模式下生成以下内容:
[
但是,当切换到横向模式时,按钮消失了:
如何让缺失的 TextView
出现在横向模式下,
或者更好 - 缩放所有项目以适应新方向?
基本上,文本视图是重要的视图 - 我希望它们可见,即使以缩小 Button
and\or ImageView
为代价
我尝试从包含 TextView
-
的最内部 LinearLayout
中删除 android:layout_weight="1"
行
这会使文本在横向模式下出现,但会使 Button
消失:
(这也使得整个布局在纵向模式下对齐到顶部而不是屏幕中心)
谢谢
这种情况下的最佳做法是拥有 2 个布局文件,每个方向一个。
在您的 /res 目录下创建一个新文件夹,并在 Android Studio 中将其命名为 layout-land 并将您的布局 xml 景观文件以相同的命名放置。
方向改变后 Android OS 将使用该文件夹中的 xml 文件,而不是尝试调整原始文件。这是定向支持的推荐方法。
在您的 xml 中,您提到 android:layout_margin="50dp" 用于您的 Button 这会影响您的布局渲染以将元素向上推。
这导致隐藏文本视图。尝试以较少的边距修改布局或使用填充作为替代方案。这可能有助于保留渲染中的所有元素。
@Adiel - 在您的 /res 目录下创建一个新文件夹,并在 Android Studio 中将其命名为 layout-land 并将您的布局 xml 景观文件以相同的命名方式放置。
完全同意这一点,因为 Android Studio 允许您根据要求创建一个单独的。确保任何 layout_width 和 layout_heights 被定义为 match_parent 似乎不起作用。
我有一个 activity 布局定义如下:
<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>
在纵向模式下生成以下内容:
[
但是,当切换到横向模式时,按钮消失了:
如何让缺失的 TextView
出现在横向模式下,
或者更好 - 缩放所有项目以适应新方向?
基本上,文本视图是重要的视图 - 我希望它们可见,即使以缩小 Button
and\or ImageView
我尝试从包含 TextView
-
LinearLayout
中删除 android:layout_weight="1"
行
这会使文本在横向模式下出现,但会使 Button
消失:
(这也使得整个布局在纵向模式下对齐到顶部而不是屏幕中心)
谢谢
这种情况下的最佳做法是拥有 2 个布局文件,每个方向一个。
在您的 /res 目录下创建一个新文件夹,并在 Android Studio 中将其命名为 layout-land 并将您的布局 xml 景观文件以相同的命名放置。
方向改变后 Android OS 将使用该文件夹中的 xml 文件,而不是尝试调整原始文件。这是定向支持的推荐方法。
在您的 xml 中,您提到 android:layout_margin="50dp" 用于您的 Button 这会影响您的布局渲染以将元素向上推。 这导致隐藏文本视图。尝试以较少的边距修改布局或使用填充作为替代方案。这可能有助于保留渲染中的所有元素。
@Adiel - 在您的 /res 目录下创建一个新文件夹,并在 Android Studio 中将其命名为 layout-land 并将您的布局 xml 景观文件以相同的命名方式放置。
完全同意这一点,因为 Android Studio 允许您根据要求创建一个单独的。确保任何 layout_width 和 layout_heights 被定义为 match_parent 似乎不起作用。