我有一个在ScrollView中有TextView的应用程序。我想把它安排在水平和垂直中心。我尝试了很多选项,如marginTop,marginBottom,paddingTop,paddingBottom,但我还没有找到它的工作原理。目前它隐藏了我的第一个两行从顶部,如果我做了一些更改,它显示所有线条清晰,但比它没有显示在垂直和水平中心。 我该怎么做才能使它垂直和水平居中?
我的XML包含在这里。
由于
<ScrollView
android:id="@+id/scrollView1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_above="@+id/bottomShadow"
android:layout_below="@+id/topShadow" >
<LinearLayout
android:id="@+id/quote"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginTop="6dp"
android:orientation="vertical"
android:padding="3dp" >
<TextView
android:id="@+id/text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal|center"
android:gravity="center"
android:text="In order to succeed ..."
android:textColor="#e8d8a7"
android:lineSpacingMultiplier="1.5"
android:textStyle="bold"
android:textSize="22sp" />
</LinearLayout>
</ScrollView>
答案 0 :(得分:3)
在scrollview中使用 android:fillViewport =“true”
<?xml version="1.0" encoding="utf-8"?>
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/scrollView1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_above="@+id/bottomShadow"
android:fillViewport="true"
android:background="@color/red"
android:layout_below="@+id/topShadow">
<LinearLayout
android:id="@+id/quote"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:orientation="vertical"
>
<TextView
android:id="@+id/text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal|center"
android:gravity="center"
android:text="In order to succeed ..."
android:textColor="#e8d8a7"
android:lineSpacingMultiplier="1.5"
android:textStyle="bold"
android:textSize="22sp"/>
</LinearLayout>
</ScrollView>
答案 1 :(得分:0)
试试这个:
<ScrollView
android:id="@+id/scrollView1"
android:layout_width="match_parent"
android:layout_height="fill_parent"
>
<LinearLayout
android:id="@+id/quote"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginTop="6dp"
android:orientation="vertical"
android:padding="3dp" >
<TextView
android:id="@+id/text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal|center"
android:gravity="center"
android:text="In order to succeed ..."
android:textColor="#e8d8a7"
android:lineSpacingMultiplier="1.5"
android:textStyle="bold"
android:textSize="22sp" />
</LinearLayout>
</ScrollView>
答案 2 :(得分:0)
ScrollView
的高度应为match_parent
LinearLayout
替换为RelativeLayout
Textview
应该有android:layout_centerInParent="true"
所以你的最终修改将是
<ScrollView
android:id="@+id/scrollView1"
android:layout_width="match_parent"
android:layout_height="match_parent"
...
>
您的RelativeLayout
<RelativeLayout
android:id="@+id/quote"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginTop="6dp"
android:orientation="vertical"
android:padding="3dp" >
最后TextView
<TextView
android:id="@+id/text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
...
...
/>
答案 3 :(得分:0)
在这种情况下,您应该在RelativeLayout
内使用scrollview
并将其宽度和高度设置为match_parent
。所以用下面的
<ScrollView
android:id="@+id/scrollView1"
android:fillViewport="true"
android:layout_width="match_parent"
android:layout_height="match_parent">
<RelativeLayout
android:id="@+id/quote"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:padding="3dp" >
<TextView
android:id="@+id/text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:text="In order to succeed ..."
android:textColor="#e8d8a7"
android:textStyle="bold"
android:textSize="22sp" />
</RelativeLayout>
</ScrollView>
你完成了......
答案 4 :(得分:0)
您可以将其添加到xml:
机器人:layout_gravity =&#34; center_vertical | CENTER_HORIZONTAL&#34;