如何对齐imageview和屏幕中心的两个文本android?

问题描述:

您好我有父布局作为LinearLayout,我需要放置一个imageview在中心和两个textview一个接一个在屏幕中心。屏幕底部是一个图标。如何对齐imageview和屏幕中心的两个文本android?

我放置了一切,但imageview和两个textview不在屏幕中心对齐。这是布局。

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    android:background="@drawable/bg" 
    android:orientation="vertical"> 

    //this image and two textview, i need to place at center of screen 
<LinearLayout 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:gravity="center" 
    android:layout_gravity="center" 
    android:orientation="vertical"> 
    <ImageView 
     android:id="@+id/seat_icon" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:background="@drawable/on_logo" 
     android:layout_marginBottom="@dimen/dp_size20" 
     /> 

    <TextView 
     android:id="@+id/seat_number" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:text="Test1" 
     android:textAllCaps="false" 
     android:textColor="@color/white" 
     android:textSize="16dp" 
     android:gravity="center"/> 
    <TextView 
     android:id="@+id/another_text" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:paddingTop="@dimen/dp_size10" 
     android:paddingBottom="@dimen/dp_size10" 
     android:text="TEst 2" 
     android:textAllCaps="false" 
     android:textColor="@color/white" 
     android:textSize="16dp" 
     android:gravity="center"/> 

</LinearLayout> 
    <RelativeLayout 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:layout_marginBottom="@dimen/dp_size10"> 

     <RelativeLayout 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:weightSum="1" 
      android:layout_alignParentBottom="true" 
      android:layout_alignParentStart="true"> 

      <ImageView 
       android:id="@+id/on_boarding_circle_arrow" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content" 
       android:layout_gravity="center" 
       android:layout_centerInParent="true" 
       android:background="@drawable/circle_arrow" /> 
</RelativeLayout> 
    </RelativeLayout> 
    </LinearLayout> 

我真的搞不清楚我在这个设计中做了什么错误。 ImageView和两个文本放置在屏幕顶部而不是屏幕中央。

+0

如何的输出乌尔得到些什么?显示屏幕 – Gattsu

我已经改变了一些尺寸和图像,纠正这些,你很好去。

试试这个..

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:background="@drawable/bg"> 
    <RelativeLayout 
     android:layout_width="match_parent" 
     android:layout_height="match_parent"> 
     <LinearLayout 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:gravity="center" 
      android:layout_centerInParent="true" 
      android:orientation="vertical"> 
      <ImageView 
       android:id="@+id/seat_icon" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content" 
       android:background="@mipmap/ic_launcher" 
       android:layout_marginBottom="20dp" /> 
      <TextView 
       android:id="@+id/seat_number" 
       android:layout_width="match_parent" 
       android:layout_height="wrap_content" 
       android:text="Test1" 
       android:textAllCaps="false" 
       android:textSize="16dp" 
       android:gravity="center"/> 
      <TextView 
       android:id="@+id/another_text" 
       android:layout_width="match_parent" 
       android:layout_height="wrap_content" 
       android:paddingTop="@dimen/dp_size10" 
       android:paddingBottom="@dimen/dp_size10" 
       android:text="TEst 2" 
       android:textAllCaps="false" 
       android:textColor="@color/white" 
       android:textSize="16dp" 
       android:gravity="center"/> 

     </LinearLayout> 
     <RelativeLayout 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:layout_alignParentBottom="true" 
      android:layout_marginBottom="@dimen/dp_size10"> 

      <RelativeLayout 
       android:layout_width="match_parent" 
       android:layout_height="wrap_content" 
       android:weightSum="1" 
       android:layout_alignParentBottom="true" 
       android:layout_alignParentStart="true"> 

       <ImageView 
        android:id="@+id/on_boarding_circle_arrow" 
        android:layout_width="wrap_content" 
        android:layout_height="wrap_content" 
        android:layout_gravity="center" 
        android:layout_centerInParent="true" 
        android:background="@mipmap/ic_launcher" /> 
      </RelativeLayout> 
     </RelativeLayout> 
    </RelativeLayout> 
</LinearLayout> 

试试这个代码

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    android:background="@drawable/bg" 
    android:orientation="vertical"> 

    //this image and two textview, i need to place at center of screen 
<LinearLayout 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:gravity="center" 
    android:layout_gravity="center" 
    android:orientation="vertical"> 
    <ImageView 
     android:id="@+id/seat_icon" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:background="@drawable/on_logo" 
     android:layout_marginBottom="@dimen/dp_size20" 
     /> 

    <TextView 
     android:id="@+id/seat_number" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:text="Test1" 
     android:textAllCaps="false" 
     android:textColor="@color/white" 
     android:textSize="16dp" 
     android:gravity="center"/> 
    <TextView 
     android:id="@+id/another_text" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:paddingTop="@dimen/dp_size10" 
     android:paddingBottom="@dimen/dp_size10" 
     android:text="TEst 2" 
     android:textAllCaps="false" 
     android:textColor="@color/white" 
     android:textSize="16dp" 
     android:gravity="center"/> 

</LinearLayout> 
    <RelativeLayout 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:layout_marginBottom="@dimen/dp_size10"> 

     <RelativeLayout 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:weightSum="1" 
      android:layout_alignParentBottom="true" 
      android:layout_alignParentStart="true"> 

      <ImageView 
       android:id="@+id/on_boarding_circle_arrow" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content" 
       android:layout_gravity="center" 
       android:layout_centerInParent="true" 
       android:background="@drawable/circle_arrow" /> 
</RelativeLayout> 
    </RelativeLayout> 
    </LinearLayout> 

RelativeLayout底部的问题。并添加android:gravity="center"到父LinearLayout

只需添加机器人:在你的根的LinearLayout比重=“中心”,并删除最后的RelativeLayout,看看

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    android:orientation="vertical"> 

    <LinearLayout 
     android:layout_centerInParent="true" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:gravity="center" 
     android:layout_gravity="center_vertical" 
     android:orientation="vertical"> 
     <ImageView 
      android:id="@+id/seat_icon" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:layout_marginBottom="20dp" 
      /> 

     <TextView 
      android:id="@+id/seat_number" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:text="Test1" 
      android:textAllCaps="false" 
      android:textColor="@color/Grey" 
      android:textSize="16dp" 
      android:gravity="center"/> 
     <TextView 
      android:id="@+id/another_text" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:paddingTop="10dp" 
      android:paddingBottom="10dp" 
      android:text="TEst 2" 
      android:textAllCaps="false" 

      android:textSize="16dp" 
      android:gravity="center"/> 

    </LinearLayout> 
    <RelativeLayout 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:layout_alignParentBottom="true" 
     > 

     <RelativeLayout 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:layout_alignParentBottom="true" 
      > 

      <ImageView 
       android:id="@+id/on_boarding_circle_arrow" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content" 
       android:layout_gravity="center" 
       android:layout_centerInParent="true" 
       android:background="@drawable/acircle" /> 
     </RelativeLayout> 
    </RelativeLayout> 
</RelativeLayout> 

的问题是,您使用的线性布局,因此正在调整布局。所以你需要使用相对布局,它会工作

切 'layout_gravity',并从孩子的LinearLayout '重力' 参数并粘贴到家长的LinearLayout

<LinearLayout 

    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:gravity="center" 
    android:layout_gravity="center" 
    android:orientation="vertical"> 

<LinearLayout 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:orientation="vertical"> 
      <ImageView 
       android:id="@+id/seat_icon" 
       android:layout_width="match_parent" 
       android:layout_height="wrap_content" 
     /> 
Your code.... 

>