gpt4 book ai didi

android - RelativeLayout 高度填充剩余空间

转载 作者:可可西里 更新时间:2023-11-01 18:49:36 27 4
gpt4 key购买 nike

我的 xml 文件中有以下布局:

<RelativeLayout android:layout_width="fill_parent"
android:layout_height="fill_parent">

<FrameLayout android:id="@+id/logoLayout"
android:layout_width="fill_parent"
android:layout_height="wrap_content">
-- some images
</FrameLayout>


<RelativeLayout android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:orientation="vertical"
android:layout_below="@+id/logoLayout">

Button 1
Button 2
Button 3
Button 4

</RelativeLayout>

<RelativeLayout android:orientation="horizontal"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_margin="5dip"
android:layout_alignParentBottom="true">

Button 5
</RelativeLayout>

<RelativeLayout>

也许我没有以最好的方式做到这一点。我想要的:拥有包含 4 个按钮的布局以使用顶部和底部布局之间的整个空间,并且我希望按钮在布局中均匀排列。

是这样的:http://img16.imageshack.us/i/androidq.png/

我添加了整个布局代码:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="@drawable/background">


<!--The header of the page-->
<FrameLayout android:id="@+id/logoLayout"
android:layout_width="fill_parent"
android:layout_height="wrap_content">

<ImageView android:id="@+id/logoBackground"
android:src="@drawable/logo_background_small"
android:layout_width="fill_parent"
android:layout_height="wrap_content"/>

<ImageView android:id="@+id/logoImage"
android:src="@drawable/logo_small"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="left"
android:gravity="center"
android:padding="3dip"/>

<TextView android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/tracks"
android:layout_gravity="center"
android:gravity="right"
android:textSize="22dip"
android:textColor="#ffffff"
android:padding="3dip">
</TextView>

</FrameLayout>


<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:orientation="vertical"
android:layout_below="@+id/logoLayout">

<Button android:id="@+id/btn1"
android:layout_height="wrap_content"
android:layout_width="250dip"
android:drawableLeft="@drawable/img_small_btn_look_around"
android:background="@drawable/main_long_menu_button"
android:text="@string/btn1"
android:textSize="18dip"
android:textColor="#ffffff"
android:layout_marginTop="20dip"
android:onClick="btnMyTracksOnClick">
</Button>

<Button android:id="@+id/btn2"
android:layout_height="wrap_content"
android:layout_width="250dip"
android:drawableLeft="@drawable/img_small_btn_look_around"
android:background="@drawable/main_long_menu_button"
android:text="@string/btn2"
android:textSize="18dip"
android:textColor="#ffffff"
android:layout_marginTop="20dip"
android:layout_below="@+id/btn1">
</Button>

<Button android:id="@+id/btn3"
android:layout_height="wrap_content"
android:layout_width="250dip"
android:drawableLeft="@drawable/img_small_btn_look_around"
android:background="@drawable/main_long_menu_button"
android:text="@string/btn3"
android:textSize="18dip"
android:textColor="#ffffff"
android:layout_marginTop="20dip"
android:layout_below="@+id/btn2">
</Button>

<Button android:id="@+id/btn4"
android:layout_height="wrap_content"
android:layout_width="250dip"
android:drawableLeft="@drawable/img_small_btn_look_around"
android:background="@drawable/main_long_menu_button"
android:text="@string/btn4"
android:textSize="18dip"
android:textColor="#ffffff"
android:layout_marginTop="20dip"
android:layout_below="@+id/bt3">
</Button>
</RelativeLayout>

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_margin="5dip"
android:layout_alignParentBottom="true">

<Button android:layout_width="90dip"
android:layout_height="wrap_content"
android:textSize="20dip"
android:textColor="#ffffff"
android:layout_alignParentLeft="true"
android:background="@drawable/sett_menu_button"
android:text="@string/back"
android:layout_marginLeft="3dip"/>

</RelativeLayout>

</RelativeLayout>

最佳答案

相对布局方法

我遇到过类似的情况,但我使用 RelativeLayout 而不是 LinearLayout 让它工作。

我基本上有 2 个标签( TextView )。顶部标签应填充剩余空间,底部标签是一段文本,应环绕其内容但仍固定在容器底部。这两个 View 都在 RelativeLayout 容器中

所以基本上:

------- parent container top ------------
|
|
|
[label1 (auto expand)]
|
|
|
[label2 (fixed height)]
------- parent container bottom ------------

技术

  1. 对于标签 1,我将宽度和高度的布局参数设置为 MATCH_PARENT,以便它自动展开。
  2. 为标签 1 添加规则,使其位于 ABOVE 标签 2(这是重要部分)

然后对于标签 2:

  1. 使用 MATCH_PARENT 作为宽度,使用 WRAP_CONTENT 作为高度
  2. 然后将标签 2 的规则添加到 ALIGN_PARENT_BOTTOM

这个布局指令告诉Android系统:

标签 2 应包裹其内容并固定到父容器的底部,同时,标签 1 应填充标签 2 上方的剩余空间。

要记住的重要一点是设置为 ALIGN_PARENT_SOMETHING 的 View ,例如ALIGN_PARENT_TOPALIGN_PARENT_BOTTOM 是“优先 View ”。应相对于此“优先 View ”设置应填充剩余空间的所有其他 View 。

基本示例

这是一个使用编程方法的演示:

package com.zhang.relodemo;

import android.graphics.Color;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.Gravity;
import android.view.View;
import android.view.ViewGroup;
import android.widget.RelativeLayout;
import android.widget.TextView;

public class MainActivity extends AppCompatActivity {

// ---------------------------------------------------
// Member Variables
// ---------------------------------------------------

RelativeLayout container;

TextView label1;
TextView label2;

// ---------------------------------------------------
// Property Methods
// ---------------------------------------------------

public RelativeLayout getContainer() {
return container;
}

public void setContainer(RelativeLayout container) {
this.container = container;
}

public TextView getLabel1() {
return label1;
}

public void setLabel1(TextView label1) {
this.label1 = label1;
}

public TextView getLabel2() {
return label2;
}

public void setLabel2(TextView label2) {
this.label2 = label2;
}

// ---------------------------------------------------
// Methods
// ---------------------------------------------------

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);

initViews();
initLayouts();
addViews();
}

void initViews() {
container = new RelativeLayout(this);

label1 = new TextView(this);
label1.setText("The quick brown fox jumped over the lazy dog.");
label1.setBackgroundColor(Color.LTGRAY);
label1.setGravity(Gravity.CENTER);
label1.setTextSize(20);

label2 = new TextView(this);
label2.setText("Label 2 is a short label compared to label1.It has two lines but take up a fraction of the space.");
label2.setBackgroundColor(Color.GRAY);
label2.setTextSize(20);
label2.setTextAlignment(View.TEXT_ALIGNMENT_CENTER);
}

void initLayouts() {
container.setId(View.generateViewId());

label1.setId(View.generateViewId());
label2.setId(View.generateViewId());


// ---------------------------------------------------
// Parent Container Constraints
// ---------------------------------------------------

RelativeLayout.LayoutParams containerLayoutParams = new RelativeLayout.LayoutParams(
ViewGroup.LayoutParams.MATCH_PARENT,
ViewGroup.LayoutParams.MATCH_PARENT
);

container.setLayoutParams(containerLayoutParams);



// ---------------------------------------------------
// Label Constraints
// ---------------------------------------------------

RelativeLayout.LayoutParams label1LayoutParams = new RelativeLayout.LayoutParams(
ViewGroup.LayoutParams.MATCH_PARENT,
ViewGroup.LayoutParams.MATCH_PARENT
);

// --------------------------------------
// THIS IS THE IMPORTANT STEP HERE
//
// It tells label1 to be above label2
// while expanding vertically.
// --------------------------------------
label1LayoutParams.addRule(RelativeLayout.ABOVE, label2.getId());

label1.setLayoutParams(label1LayoutParams);




RelativeLayout.LayoutParams label2LayoutParams = new RelativeLayout.LayoutParams(
ViewGroup.LayoutParams.MATCH_PARENT,
ViewGroup.LayoutParams.WRAP_CONTENT
);

// ------------------------------------------
// this pins label2 to the parent
// container's bottom, preventing label1
// from forcing label2 off bottom of screen
// ------------------------------------------
label2LayoutParams.addRule(RelativeLayout.ALIGN_PARENT_BOTTOM);

label2.setLayoutParams(label2LayoutParams);
}

void addViews() {
getContainer().addView(getLabel1());
getContainer().addView(getLabel2());

this.setContentView(getContainer());
}
}

或其 XML 等价物:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/container">
<TextView
android:id="@+id/label1"
android:text="The quick brown fox jumped over the lazy dog."
android:background="#ccc"
android:gravity="center"
android:textSize="20sp"
android:textAlignment="center"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_above="@id/label2" />

<TextView
android:id="@+id/label2"
android:text="Label 2 is a short label compared to label1.It has two lines but take up a fraction of the space."
android:background="@android:color/darker_gray"
android:textSize="20sp"
android:textAlignment="center"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"/>
</RelativeLayout>

应该给你以下结果:

demo screenshot

关于android - RelativeLayout 高度填充剩余空间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3676095/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com