Android 将ImageView放置在居中按钮的左侧

Android 将ImageView放置在居中按钮的左侧,android,android-studio,imageview,android-togglebutton,Android,Android Studio,Imageview,Android Togglebutton,我试图将ImageView对象放置在线性布局对象(即两个按钮的父对象)的左侧。我基本上希望两个按钮水平居中,屏幕上的图像位于居中按钮的左侧。我仍然希望按钮保持水平居中,放置的图像视图不应该居中,只应该在侧面 任何建议都非常好。我可能用错误的布局来解决我的问题,但以下是我尝试过的: <?xml version="1.0" encoding="utf-8"?> <RelativeLayout android:id="@+id/gameSettingsContainer"

我试图将ImageView对象放置在线性布局对象(即两个按钮的父对象)的左侧。我基本上希望两个按钮水平居中,屏幕上的图像位于居中按钮的左侧。我仍然希望按钮保持水平居中,放置的图像视图不应该居中,只应该在侧面

任何建议都非常好。我可能用错误的布局来解决我的问题,但以下是我尝试过的:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    android:id="@+id/gameSettingsContainer"
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fitsSystemWindows="true"
    tools:context="com.example.vb1115.multchoicequestion.LaunchScreen"
    android:orientation="vertical"
    android:gravity="center_horizontal">
    <LinearLayout
        android:id="@+id/buttonContainer"
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:orientation="horizontal"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">
        <ToggleButton android:id="@+id/mathButton"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textOff="Math"
            android:textOn="Math"
            android:text="Math"/>
        <ToggleButton android:id="@+id/bioButton"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textOff="Biology"
            android:textOn="Biology"
            android:text="Biology"/>
    </LinearLayout>
    <ImageView
        android:id="@+id/animatedArrow"
        android:src="@mipmap/green_arrow"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_alignParentLeft="true"
        android:layout_toLeftOf="@id/buttonContainer"/>
</RelativeLayout>

虽然我没有Android Studio要测试,但我已经可以做一些假设了

首先,无需使用android:orientation=“vertical”或android:gravity=“center\u horizontal”进行根相对论

第二,要定位两个子元素,请对线性布局使用
android:layout\u centerHorizontal
,并对图像视图保持
android:layout\u alignParentLeft

这应该开始好一点了。。。主要的想法是,在相对论中,让孩子们决定自己的位置通常更有效。。。希望这会有所帮助。

这里是解决方案

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    android:id="@+id/gameSettingsContainer"
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fitsSystemWindows="true">

    <LinearLayout
        android:id="@+id/buttonContainer"
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_centerHorizontal="true"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal">

        <ToggleButton
            android:id="@+id/mathButton"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Math"
            android:textOff="Math"
            android:textOn="Math"/>

        <ToggleButton
            android:id="@+id/bioButton"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Biology"
            android:textOff="Biology"
            android:textOn="Biology"/>
    </LinearLayout>

    <ImageView
        android:id="@+id/animatedArrow"
        android:layout_toStartOf="@+id/buttonContainer"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@mipmap/green_arrow"/>
</RelativeLayout>

无需android Studio进行测试:

要将线性布局居中于相对位置,请使用布局\u centerHorizontal=“true”


对于要均匀分布和居中的每个按钮,请使用layout_weight=“1”(因此每个按钮都具有相同的重量)和gravity=“center\u horizontal”


然后将ImageView放置到按钮容器的布局开始处

<ImageView
        android:id="@+id/animatedArrow"
        android:src="@mipmap/green_arrow"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_toStartOf="@+id/buttonContainer">

这很有效,谢谢!!也感谢您的澄清。
    <ToggleButton android:id="@+id/mathButton"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textOff="Math"
        android:textOn="Math"
        android:text="Math"
        android:layout_weight="1"
        android:layout_gravity="center_horizontal"/>
    <ToggleButton android:id="@+id/bioButton"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textOff="Biology"
        android:textOn="Biology"
        android:text="Biology"
        android:layout_weight="1"
        android:layout_gravity="center_horizontal"/>
<ImageView
        android:id="@+id/animatedArrow"
        android:src="@mipmap/green_arrow"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_toStartOf="@+id/buttonContainer">