[英]Android relative layout center vertical with margin
在Android的RelativeLayout中,我們可以使用以下代碼在屏幕中心設置textView:
<TextView
android:text="This is TextView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_centerHorizontal="true" />
結果:
top
-
-
-
-
This is TextView (center vertical)
-
-
-
-
bottom
但我需要marginTop
有點底部,我嘗試添加marginTop
但似乎在使用layout_centerVertical=true
它變得不可能。 有解決方案嗎
預期結果(略微下調):
top
-
-
-
-
-
-
This is TextView (center vertical slight to bottom)
-
-
bottom
試試這個:
嘗試使用RelativeLayout,它可以使用重量輕松完成您的要求:
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center_vertical">
<TextView
android:id="@id/dummy"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_centerHorizontal="true" />
<TextView
android:layout_below="@id/dummy"
android:layout_marginTop="10dp"
android:text="This is TextView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
</RelativeLayout>
嘗試使用LinearLayout,它可以使用重量輕松完成您的要求:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1">
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1"
android:gravity="center_vertical">
<TextView
android:text="This is TextView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
</LinearLayout>
</LinearLayout>
為什么要在父視圖中 添加嵌套 視圖 ?
使用paddingTop
屬性。
例:
<RelativeLayout
android:id="@+id/rlParentView"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<ImageView
android:id="@+id/imageView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:paddingTop="10dp"/>
</RelativeLayout>
希望這會幫助你。
我今天遇到了這種問題,我想通了這種方式。 Sapce
和LinearLayout
是一個很好的解決方案。
<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:background="@color/base_background_color">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/base_toolbar_color"
android:minHeight="?attr/actionBarSize"/>
<android.support.v7.widget.RecyclerView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_below="@+id/toolbar"/>
<!-- using LinearLayout to align ProgressBar to center vertical -->
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:orientation="vertical">
<Space
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"/>
<ProgressBar
android:id="@+id/other_profile_progressBar"
style="?android:attr/progressBarStyleLarge"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:indeterminate="false"/>
</LinearLayout>
</RelativeLayout>
如果你不打算為視圖制作翻譯動畫,你可以使用android:translationY
屬性按你想要的方式推送它(推高的負值)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.