我使用相对布局在XML中创建Android UI。布局以ImageView和TextView为中心。我需要将这两个元素放在彼此的上方和下方。我想这样做,这两个元素占整个宽度的50%。我尝试了一个带有android:layout_weight=".5"
的LinearLayout,但我无法让它在水平和垂直方向都居中。这是我的相对布局,我希望它看起来像这样但是图像占据了宽度的50%,两边都有25%的空白。我还需要用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:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity">
<ImageView
android:id="@+id/activity_main_imageview_logo"
android:src="@drawable/img_main_logo"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:scaleType="centerCrop"
android:paddingBottom="12dp"
android:onClick="imageViewGTTOnClick"
android:adjustViewBounds="true" />
<TextView
android:id="@+id/activity_main_textview_tagline"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/activity_main_textview_tagline"
android:textColor="@color/dark_blue"
android:gravity="center"
android:textSize="28sp"
android:layout_below="@+id/activity_main_imageview_logo"
android:layout_centerHorizontal="true" />
</RelativeLayout>
答案 0 :(得分:5)
这应该可以解决问题:
<LinearLayout 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:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:weightSum="4"
android:gravity="center"
tools:context=".MainActivity"
android:baselineAligned="false">
<LinearLayout
android:layout_width="0dp"
android:orientation="vertical"
android:layout_weight="2"
android:gravity="center_vertical"
android:layout_height="wrap_content">
<ImageView
android:id="@+id/activity_main_imageview_logo"
android:src="@drawable/img_main_logo"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:scaleType="centerCrop"
android:paddingBottom="12dp"
android:onClick="imageViewGTTOnClick"
android:adjustViewBounds="true"/>
<TextView
android:id="@+id/activity_main_textview_tagline"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/activity_main_textview_tagline"
android:textColor="@color/dark_blue"
android:gravity="center"
android:textSize="28sp"/>
</LinearLayout>
</LinearLayout>