【问题标题】:RelativeLayout height 'wrap_content' does not wrap content相对布局高度 'wrap_content' 不换行内容
【发布时间】:2011-12-24 02:03:30
【问题描述】:

我正在制作一个布局来复制自定义对话框。对于我的对话框的底部,尽管我将 RelativeLayout 高度设置为 wrap_content,但托管正面、中性和负面按钮的 RelativeLayout 具有扩展的高度。

我的布局 XML 如下:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/linearLayout1"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >

<RelativeLayout
    android:id="@+id/relativeLayout1"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" >

    <TextView
        android:id="@+id/TextView_Title"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="5dip"
        android:text="Title"
        android:textAppearance="?android:attr/textAppearanceLarge" />
</RelativeLayout>

<LinearLayout
    android:id="@+id/linearLayout3"
    android:layout_width="match_parent"
    android:layout_height="1dip"
    android:layout_marginBottom="10dip"
    android:layout_marginLeft="0dip"
    android:layout_marginRight="0dip"
    android:layout_marginTop="10dip"
    android:background="@android:drawable/divider_horizontal_dim_dark" >
</LinearLayout>

<TextView
    android:id="@+id/TextView_Message"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginBottom="10dip"
    android:layout_marginLeft="10dip"
    android:layout_marginRight="10dip"
    android:text="TextView" />

<RelativeLayout
    android:id="@+id/relativeLayout2"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@android:drawable/bottom_bar" >

    <Button
        android:id="@+id/Button_Positive"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_toLeftOf="@+id/Button_Neutral"
        android:layout_centerVertical="true"
        android:text="Button" />

    <Button
        android:id="@+id/Button_Neutral"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
        android:text="Button" />

    <Button
        android:id="@+id/Button_Negative"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_toRightOf="@+id/Button_Neutral"
        android:layout_centerVertical="true"
        android:text="Button" />
</RelativeLayout>

Java 活动代码:

public class MainActivity extends Activity
{
    @Override
    public void onCreate(Bundle savedInstanceState)
    {
        requestWindowFeature(Window.FEATURE_NO_TITLE);

        super.onCreate(savedInstanceState);
        setContentView(R.layout.dialog);

        // Assign content references
        TextView message = (TextView) findViewById(R.id.TextView_Message);
        message.setText("Are you sure you want to sign out?");
    }
}

【问题讨论】:

  • 您能否添加一个屏幕截图来说明您所说的“扩展高度”是什么意思?我只是从字面上复制粘贴了您的 xml,它似乎渲染得很好。至少我没有看到您可能指的任何“扩展高度”。这是我看到的截图:i.imgur.com/uL1E9.png
  • 对。 Eclipse 显示它很好。但实际的 Nexus One 设备却没有。真的很奇怪……
  • 也许是运行时发生的事情?您能否添加用于创建自定义对话框的代码?
  • 我观察到,如果您在 Relative Layout 内有 MATCH_PARENT 的内容,而 Relative Layout 的相应参数设置为 WRAP_CONTENT,这也会导致问题。

标签: android android-layout android-widget android-xml


【解决方案1】:

在 Eclipse(如前所述)或 Motorola Defy MB525 中正确渲染布局没有任何问题。但是,如果我将活动的主题设置为 Theme.Dialog,它会显示为纵向挤压,导致只有中性按钮可见。您还可以对问题中提出的布局进行一些简化,例如标题 TextView 的不必要嵌套和(ab)使用 LinearLayout 作为水平分隔线。

我更改了一些小东西,导致下面的布局。或许你可以试试看?

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/root_layout"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <TextView
        android:id="@+id/TextView_Title"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_marginTop="5dip"
        android:gravity="center_horizontal"
        android:text="Title"
        android:textAppearance="?android:attr/textAppearanceLarge" />

    <View
        android:id="@+id/horizontal_divider3"
        android:layout_width="fill_parent"
        android:layout_height="1dip"
        android:layout_marginBottom="10dip"
        android:layout_marginLeft="0dip"
        android:layout_marginRight="0dip"
        android:layout_marginTop="10dip"
        android:background="@android:drawable/divider_horizontal_bright" />

    <TextView
        android:id="@+id/TextView_Message"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginBottom="10dip"
        android:layout_marginLeft="10dip"
        android:layout_marginRight="10dip"
        android:text="TextView" />

    <LinearLayout
        android:id="@+id/button_layout"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@android:drawable/bottom_bar" 
        android:gravity="center">

        <Button
            android:id="@+id/Button_Positive"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Button" />

        <Button
            android:id="@+id/Button_Neutral"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Button" />

        <Button
            android:id="@+id/Button_Negative"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Button" />
    </LinearLayout>

</LinearLayout>

顺便说一句,除了使用 Activity 来模拟对话框,您还可以只将此布局用于“真实”对话框。 Android 开发网站上有一个很好的example on creating custom dialogs

【讨论】:

  • 完美运行,谢谢。为什么渲染的很奇怪?我认为 Eclipse 的 UI 布局呈现与 Android 设备的一致。
  • 说实话:我不确定。我无法在我的设备上重现您的问题。可能它可能是一个糟糕的构建 - 您是否尝试在 Eclipse 中清理您的项目并重新构建它?否则,我想您可以将您的初始布局逐步转换为我发布的内容,并尝试以这种方式确定问题的原因。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-12-17
  • 1970-01-01
  • 2018-05-09
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多