我已經花了大約2-3小時尋找解決方案。但無論我嘗試使用哪種stackoverflow答案,它都無法正常工作。中心TextView沒有重疊圖像(centerHorizontal和toRightOf)
我所需要的是一個簡單的佈局(一個CardView內),在左側的ImageView的和在佈局中的中心的文本(相對於其父)不會與圖像重疊。
當我設置android:layout_centerHorizontal="true"
時,TextView居中,但如果我的文本太長,它會在左側覆蓋我的圖像。如果我設置android:layout_toRightOf="@+id/answer1_image"
我的文本不會重疊,但不居中。將兩個參數結合在一起TextView不會居中。
這裏是我的問題的截圖和第2張卡我的XML代碼:
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
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=".QuestionsActivity">
<android.support.v7.widget.CardView
xmlns:card_view="http://schemas.android.com/apk/res-auto"
android:id="@+id/answer1_card"
android:layout_width="match_parent"
android:layout_height="80dp"
android:foreground="?android:attr/selectableItemBackground"
android:onClick="answer1_submitted"
app:cardUseCompatPadding="true"
card_view:cardCornerRadius="4dp">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="4dp">
<ImageView
android:id="@+id/answer1_image"
android:layout_width="80dp"
android:layout_height="80dp"
android:layout_alignParentLeft="true"
android:scaleType="fitStart"
app:srcCompat="@mipmap/ic_launcher"/>
<TextView
android:id="@+id/answer1_text"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_centerHorizontal="true"
android:gravity="center"
android:layout_toRightOf="@+id/answer1_image"
android:layout_centerInParent="true"
android:text="@string/answer1"
android:textSize="20sp"/>
</RelativeLayout>
</android.support.v7.widget.CardView>
<android.support.v7.widget.CardView
xmlns:card_view="http://schemas.android.com/apk/res-auto"
android:id="@+id/answer2_card"
android:layout_width="match_parent"
android:layout_height="80dp"
android:foreground="?android:attr/selectableItemBackground"
android:onClick="answer2_submitted"
app:cardUseCompatPadding="true"
card_view:cardCornerRadius="4dp">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="4dp">
<ImageView
android:id="@+id/answer2_image"
android:layout_width="80dp"
android:layout_height="80dp"
android:layout_alignParentLeft="true"
android:scaleType="fitStart"
app:srcCompat="@mipmap/ic_launcher"/>
<TextView
android:id="@+id/answer2_text"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_centerHorizontal="true"
android:gravity="center"
android:text="@string/answer2"
android:textSize="20sp"/>
</RelativeLayout>
</android.support.v7.widget.CardView>
...
謝謝,但這會在我的答案文本的左側添加修正邊距。我想要的行爲是文字始終居中。因此,如果我對「我的問題文本」有一個很長的回答,那麼文本將在圖片旁邊開始。 – G00fY
您是否在搜索:android:textAlignment =「center」 –
因此,給TextView的空間右邊的imageView與「marginRight」的東西,並將android:textAlignment =「center」添加到textView。所以如果你有更長的回答,文字會更接近imageView,但不會超過它。 –