RelativeLayout中的视图大小不正确

时间:2017-03-17 10:01:19

标签: android android-layout coordinates relativelayout circularreveal

我在下面有一个RelativeLayout。其中有一个可扩展视图和一个显示框架布局。 RevealFrameLayout与屏幕底部对齐,位于ExpandableView下方。当用户点击fab揭示动画将从fab中心开始并显示揭示框架布局。

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

<FrameLayout
    android:id="@+id/expandable_frame"
    android:layout_width="match_parent"
    android:layout_height="250dp"
    android:layout_alignParentTop="true"
    android:background="@color/colorPrimary"
    android:elevation="16dp"
    android:fitsSystemWindows="true"
    android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

    <TextView
        android:id="@+id/app_name_tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom|start"
        android:padding="16dp"
        android:text="@string/app_name"
        android:textAppearance="@style/ExtraLargeText"/>

</FrameLayout>

<TextView
    android:id="@+id/error_tv"
    android:layout_width="match_parent"
    android:layout_height="60dp"
    android:layout_below="@id/expandable_frame"
    android:background="@color/mid_grey"
    android:gravity="center"
    android:textColor="@color/error_red"
    android:visibility="invisible"
    tools:text="@string/error_login"
    tools:visibility="visible"/>

<android.support.design.widget.TextInputLayout
    android:id="@+id/username_til"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_below="@id/error_tv"
    android:layout_marginEnd="16dp"
    android:layout_marginStart="16dp">

    <android.support.design.widget.TextInputEditText
        android:id="@+id/username_tiet"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="@string/username"
        android:inputType="text"
        android:lines="1"
        android:nextFocusDown="@+id/password_tiet"/>

</android.support.design.widget.TextInputLayout>

<android.support.design.widget.TextInputLayout
    android:id="@+id/password_til"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_below="@id/username_til"
    android:layout_marginEnd="16dp"
    android:layout_marginStart="16dp">

    <android.support.design.widget.TextInputEditText
        android:id="@id/password_tiet"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="@string/password"
        android:inputType="textPassword"
        android:lines="1"/>

</android.support.design.widget.TextInputLayout>

<FrameLayout
    android:id="@+id/loading_reveal_view"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:layout_below="@id/expandable_frame"
    android:background="@color/colorAccent"
    android:visibility="invisible">

    <com.wang.avi.AVLoadingIndicatorView
        android:id="@+id/loading_animation_view"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:visibility="invisible"/>

</FrameLayout>

<WebView
    android:id="@+id/web_view"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_alignParentBottom="true"
    android:layout_below="@id/expandable_frame"
    android:visibility="gone"/>

<android.support.design.widget.FloatingActionButton
    android:id="@+id/login_fab"
    android:layout_width="56dp"
    android:layout_height="56dp"
    android:layout_alignParentBottom="true"
    android:layout_alignParentEnd="true"
    android:layout_margin="16dp"
    android:tint="@android:color/white"
    app:srcCompat="@drawable/ic_ok"/>

</RelativeLayout>

我像这样计算晶圆厂的中心:

        int cx = mLoginFab.getRight() - mLoginFab.getMeasuredWidth() / 2;
        int cy = mLoginFab.getBottom() - mLoginFab.getMeasuredHeight() / 2;

但我得到的坐标总是低于fab的位置。它看起来像Reveal Frame Layout的底部是电话屏幕边界。

有谁知道这个布局有什么问题以及如何获得实际的工厂中心坐标?

提前致谢。

1 个答案:

答案 0 :(得分:1)

尝试getWidth()getHeight而不是getMeasuredWidthgetMeasuredHeight。根据{{​​3}}:

  

int getMeasuredWidthAndState()

     

返回此视图的全宽度测量信息,该信息由最近一次调用measure(int,int)计算得出。此结果是由MEASURED_SIZE_MASK和MEASURED_STATE_TOO_SMALL定义的位掩码。 仅在测量和布局计算期间使用。使用getWidth()查看布局后视图的宽度。

重点是我的,这同样适用于getMeasuredWidthgetMeasuredHeight