Android 将ImageView放置在居中按钮的左侧
我试图将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"
<?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">