框架布局的自动调整

Automatic adjustment of framelayout

我需要做这样的事情:

此应用程序的用户界面有一个区域包含多个彩色矩形,另一个区域包含一个 SeekBar。当用户拖动 SeekBar 时,矩形会逐渐改变颜色。

我正在使用框架布局(我不知道是否有更好的东西)但是我硬编码了每个框架布局的大小,当然,这是一个坏主意。 如何调整框架布局并保持关系?

这是我的 activity_main.xml:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
    android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity"
    android:background="@color/black">

    <SeekBar
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/seekBar"
        android:indeterminate="false"
        android:layout_alignParentBottom="true"
        android:layout_alignParentLeft="true"
        android:layout_alignParentStart="true"
        android:layout_alignParentRight="true"
        android:layout_alignParentEnd="true" />

    <FrameLayout
        android:id="@+id/first_block"
        android:layout_width="150dp"
        android:layout_height="240dp"
        android:layout_alignParentTop="true"
        android:layout_alignParentLeft="true"
        android:layout_alignParentStart="true"
        android:layout_alignParentBottom="false"></FrameLayout>

    <FrameLayout
        android:id="@+id/first_block_b"
        android:layout_width="150dp"
        android:layout_height="240dp"
        android:layout_above="@+id/seekBar"
        android:layout_below="@id/first_block"
        android:layout_alignParentLeft="true"
        android:layout_alignParentStart="true"
        android:layout_marginTop="5dp"></FrameLayout>

    <FrameLayout
        android:id="@+id/second_block"
        android:layout_width="190dp"
        android:layout_height="165dp"
        android:layout_alignParentTop="true"
        android:layout_alignParentRight="true"
        android:layout_alignParentEnd="true"></FrameLayout>

    <FrameLayout
        android:id="@+id/med_block"
        android:layout_width="190dp"
        android:layout_height="165dp"
        android:layout_alignParentTop="false"
        android:layout_alignParentRight="true"
        android:layout_below="@id/second_block"
        android:layout_alignParentEnd="true"
        android:layout_marginTop="5dp"></FrameLayout>

    <FrameLayout
        android:id="@+id/last_block"
        android:layout_width="190dp"
        android:layout_height="165dp"
        android:layout_alignParentTop="false"
        android:layout_alignParentRight="true"
        android:layout_below="@id/med_block"
        android:layout_alignParentEnd="true"
        android:layout_marginTop="5dp"></FrameLayout>

</RelativeLayout>

感谢您的帮助!

尝试

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">

<LinearLayout
    android:orientation="horizontal"
    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_weight="1">

    <LinearLayout
        android:orientation="vertical"
        android:layout_width="0dp"
        android:layout_weight="1"
        android:layout_height="match_parent">

        <FrameLayout
            android:id="@+id/first_block"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1"/>

        <FrameLayout
            android:id="@+id/first_block_b"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1"/>

    </LinearLayout>

    <LinearLayout
        android:orientation="vertical"
        android:layout_width="0dp"
        android:layout_weight="1"
        android:layout_height="match_parent">

        <FrameLayout
            android:id="@+id/second_block"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1"/>

        <FrameLayout
            android:id="@+id/med_block"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1"/>

        <FrameLayout
            android:id="@+id/last_block"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1"/>

    </LinearLayout>

</LinearLayout>

<SeekBar
    android:id="@+id/seekBar"
    android:indeterminate="false"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" />

</LinearLayout>

上面使用了嵌套的权重,这有时对性能不利,但考虑到你正在尝试做的事情,这是除了在代码中计算它们的最佳选择。