让图标挤进我想要的位置时遇到很多麻烦。我查看了3个不同的Stack Overflow问题,并尝试将图像放在RelativeLayout,LinearLayout和TableRow中。所有都有各种XML选项。从来没有设法让图标向右移动并在分配空间的顶部和底部之间居中。在下图中,红色是现在的位置,蓝色是我想要的地方。这是一张图片(现在看起来如何,这是不正确的)和代码(imageView1是我要对齐的):
代码:
<?xml version="1.0" encoding="utf-8"?>
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent" android:layout_height="match_parent"
android:id="@+id/loginScrollView">
<TableLayout android:layout_width="fill_parent"
android:layout_height="wrap_content" android:orientation="vertical"
android:padding="5dp">
<ImageView android:id="@+id/logoImageView"
android:layout_width="wrap_content" android:layout_height="wrap_content"
android:src="@drawable/logo" android:contentDescription="@string/app_name" />
<TextView android:id="@+id/demoTextView"
android:layout_width="wrap_content" android:layout_height="wrap_content"
android:text="@string/logDetails" android:gravity="center_horizontal|center" />
<EditText android:id="@+id/emailEditText"
android:layout_width="match_parent" android:layout_height="wrap_content"
android:hint="@string/loginHint" android:imeOptions="actionNext"
android:inputType="textEmailAddress" android:padding="20dp" />
<EditText android:id="@+id/passEditText"
android:layout_width="match_parent" android:layout_height="wrap_content"
android:hint="@string/password" android:imeOptions="actionDone"
android:inputType="textPassword" android:padding="20dp" />
<TableRow android:id="@+id/rememberTableRow"
android:layout_width="wrap_content" android:layout_height="wrap_content">
<TextView android:id="@+id/rememberTextView"
android:layout_width="wrap_content" android:layout_height="wrap_content"
android:text="@string/rememberDetails" android:layout_gravity="center" />
<CheckBox android:id="@+id/rememberCheckBox"
android:layout_width="wrap_content" android:layout_height="wrap_content"
android:padding="20dp" />
<ImageView
android:id="@+id/imageView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:onClick="showPopup"
android:src="@drawable/abs__ic_menu_moreoverflow_holo_dark" android:layout_weight="1" android:layout_gravity="center|right"/>
</TableRow>
<TableRow android:id="@+id/buttonTableRow"
android:layout_width="match_parent" android:layout_height="wrap_content">
<Button android:id="@+id/registerButton" android:layout_width="0dip"
android:layout_height="wrap_content" android:layout_gravity="bottom"
android:layout_weight="1" android:text="@string/register" />
<Button android:id="@+id/loginButton" android:layout_width="0dip"
android:layout_height="wrap_content" android:layout_gravity="bottom"
android:layout_weight="1" android:text="@string/login" />
</TableRow>
</TableLayout>
</ScrollView>
以下是我已经查看并试图用作解决方案的SO问题: Aligning ImageView to right of the layout android Aligning with center in android with hierarchical Layouts Android ImageButton not displaying on right side of the screen
答案 0 :(得分:1)
据我所知,有多种选择。我会给你两个:
第一个选项是在包含溢出图标的ImageView上设置scaletype。您将占用所有剩余可用空间并将scaletype设置为fitEnd
。这会将图标一直放在右边。
<ImageView android:id="@+id/imageView1"
android:layout_width="0dp" android:layout_height="wrap_content"
android:layout_gravity="center_vertical" android:scaleType="fitEnd"
android:layout_weight="1" android:onClick="showPopup"
android:src="@drawable/abs__ic_menu_moreoverflow_normal_holo_dark" />
你可以通过在CheckBox上设置1
的权重来实现相同的效果,这将使得带有溢出图标的ImageView一直向右“推送”(感谢TableRow的行为类似于一个LinearLayout)。然后,您可以简单地使ImageView包装其内容。在这种情况下,您可能需要仔细检查可点击区域是否没有奇怪的副作用。
<TableRow android:id="@+id/rememberTableRow"
android:layout_width="wrap_content" android:layout_height="wrap_content">
<TextView android:id="@+id/rememberTextView"
android:layout_width="wrap_content" android:layout_height="wrap_content"
android:layout_gravity="center" android:text="@string/rememberDetails" />
<CheckBox android:id="@+id/rememberCheckBox"
android:layout_width="0dp" android:layout_height="wrap_content"
android:layout_weight="1" android:padding="20dp" />
<ImageView android:id="@+id/imageView1"
android:layout_width="wrap_content" android:layout_height="wrap_content"
android:layout_gravity="center_vertical" android:onClick="showPopup"
android:src="@drawable/abs__ic_menu_moreoverflow_normal_holo_dark" />
</TableRow>