android 视图之间的额外空格
Posted
技术标签:
【中文标题】android 视图之间的额外空格【英文标题】:Extra whitespace between android Views 【发布时间】:2017-02-17 12:49:51 【问题描述】:在下面的布局中,在 AppBarLayout
之后和 RecyclerView
之前,出现了一些额外的空白,我无法弄清楚它是如何出现的。
我已经检查了边距和所有内容,似乎没问题。
同样由于同样的原因,我相信 RecyclerView 的最后一个元素是从布局视图中裁剪出来的。
任何帮助表示赞赏。
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_
android:layout_>
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/transMain"
android:layout_
android:layout_
android:fitsSystemWindows="true">
<android.support.design.widget.AppBarLayout
android:id="@+id/app_bar"
android:layout_
android:layout_
android:fitsSystemWindows="true"
android:theme="@style/AppTheme.AppBarOverlay">
<android.support.design.widget.CollapsingToolbarLayout
android:id="@+id/toolbar_layout"
android:layout_
android:layout_
android:fitsSystemWindows="true"
android:paddingLeft="12dp"
app:contentScrim="?android:attr/colorPrimary"
app:layout_scrollFlags="exitUntilCollapsed">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbarAct"
android:layout_
android:layout_
android:background="@color/colorPrimary"
app:layout_scrollFlags="scroll">
<RelativeLayout
android:layout_
android:layout_>
<!--button was here-->
<LinearLayout
android:layout_
android:layout_
android:orientation="horizontal">
<RelativeLayout
android:id="@+id/monthSelLay"
android:layout_
android:layout_>
<TextView
android:id="@+id/monthButton"
android:layout_
android:layout_
android:layout_marginTop="8dp"
android:textColor="#000"
android:textSize="14sp" />
<ImageView
android:layout_
android:layout_
android:layout_marginTop="12dp"
android:layout_toRightOf="@id/monthButton"
android:src="@drawable/ic_keyboard_arrow_down_black_24dp" />
</RelativeLayout>
<RelativeLayout
android:id="@+id/syncLay"
android:layout_
android:layout_>
<TextView
android:id="@+id/syncButton"
android:layout_
android:layout_
android:layout_marginLeft="50dp"
android:layout_marginTop="8dp"
android:text="SyncUp"
android:textAlignment="center"
android:textColor="#000" />
<ImageView
android:layout_
android:layout_
android:layout_marginTop="5dp"
android:layout_toRightOf="@+id/syncButton"
android:src="@drawable/ic_cached_black_48dp" />
</RelativeLayout>
</LinearLayout>
<!--switch was here-->
</RelativeLayout>
</android.support.v7.widget.Toolbar>
</android.support.design.widget.CollapsingToolbarLayout>
<android.support.v7.widget.SearchView
android:id="@+id/searchTrans"
android:layout_
android:layout_
android:layout_below="@+id/toolbar"
android:layout_gravity="center_horizontal"
android:layout_marginBottom="10dp"
android:layout_marginTop="10dp"
android:background="#fff"
android:hint="Start typing an Amount/Description"
android:textColor="#000"
android:textColorHint="#ccc"
app:tabMode="scrollable" />
<!--need to change the background as an object oval prbbly-->
</android.support.design.widget.AppBarLayout>
<android.support.v7.widget.RecyclerView
android:id="@+id/trans"
android:layout_
android:layout_
android:layout_gravity="center_horizontal"
app:layout_behavior="@string/appbar_scrolling_view_behavior">
</android.support.v7.widget.RecyclerView>
</android.support.design.widget.CoordinatorLayout>
<android.support.design.widget.FloatingActionButton
android:id="@+id/fab"
android:layout_
android:layout_
android:layout_gravity="bottom|end"
android:layout_margin="@dimen/fab_margin"
android:src="@drawable/ic_add_black_24dp"
app:backgroundTint="@color/colorAccent"
app:elevation="6dp"
app:pressedTranslationZ="12dp" />
</FrameLayout>
在第一张图片中,我稍微向上滚动以显示空白。
裁剪了 RecyclerView
的最后一个元素。
【问题讨论】:
【参考方案1】:从你的 RecyclerView 中删除这一行
android:layout_gravity="center_horizontal"
【讨论】:
这类问题已经问过:***.com/questions/37209342/….【参考方案2】:删除这一行:
android:layout_gravity="center_horizontal"
或
将您的协调员高度设为wrap_content
。
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/transMain"
android:layout_
android:layout_
android:fitsSystemWindows="true">
【讨论】:
仅供参考,后者不起作用。更改android:layout_gravity
确实。以上是关于android 视图之间的额外空格的主要内容,如果未能解决你的问题,请参考以下文章
Android Spinner:删除文本和下拉图标之间的多余空格
如何在android studio中删除视图之间的空间[重复]