列表视图的行隐藏

Row of Listview hidden

我需要在框架布局中创建一个列表视图。

这是我的代码:

 <FrameLayout
            android:id="@+id/layout_ejercicios"
            android:layout_width="match_parent"
            android:layout_height="300dp"
            android:layout_alignParentStart="true"
            android:layout_below="@+id/layout_info"
            android:orientation="vertical">

            <ListView
                android:id="@+id/listViewEjercicios"
                android:layout_width="match_parent"
                android:layout_height="match_parent"></ListView>

            <include
                android:id="@+id/tool_bar_ejercicios"
                layout="@layout/toolbar" />

            <android.support.design.widget.FloatingActionButton
                android:id="@+id/fabCrearEntrenamiento"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="bottom|end"
                android:layout_margin="16dp"
                android:clickable="true"
                android:src="@drawable/ic_action_add"
                app:fabSize="normal"
                app:layout_anchor="@id/layout_ejercicios"
                app:layout_anchorGravity="bottom|right|end" />
        </FrameLayout>

它几乎可以正常工作,但第一行总是被工具栏隐藏。 其余行看起来不错。

我尝试在 row_layout.xml 中添加 padding_top,但没有解决方案。

<TextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/rowTextView"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:padding="10dp"
    android:textSize="21sp" >
</TextView>

我该怎么做?

  1. 您使用了 FrameLayout。是的,所有视图在 FrameLayout 中重叠。使用 LinearLayout 因为你设置了 orientation="vertical"

  2. 你应该把工具栏放在其他东西上面

  3. CoordinatorLayout 会更好

例如,

<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
        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:layout_width="match_parent"
        android:layout_height="match_parent"
        android:fitsSystemWindows="true">

    <android.support.design.widget.AppBarLayout
            android:layout_height="wrap_content"
            android:layout_width="match_parent"
            android:theme="@style/AppTheme.AppBarOverlay">

        <android.support.v7.widget.Toolbar
                android:id="@+id/tool_bar_ejercicios"
                android:layout_width="match_parent"
                android:layout_height="?attr/actionBarSize"
                android:background="?attr/colorPrimary"
                app:popupTheme="@style/AppTheme.PopupOverlay"/>

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

    <!-- Some other layout behind the Action Button -->
    <include layout="@layout/list_view"/>

    <android.support.design.widget.FloatingActionButton
            android:id="@+id/fabCrearEntrenamiento"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="bottom|right|end"
            android:layout_margin="@dimen/fab_margin"
            android:src="@drawable/ic_action_add"/>

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

试试这个;

    <?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
    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:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@color/holo_light_background"
    android:fitsSystemWindows="true"
    tools:context=".MainActivity">

    <android.support.design.widget.AppBarLayout
        android:id="@+id/bar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:theme="@style/AppTheme.AppBarOverlay">

        <include
                android:id="@+id/tool_bar_ejercicios"
                layout="@layout/toolbar" />

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

     <FrameLayout
            android:id="@+id/layout_ejercicios"
            android:layout_width="match_parent"
            android:layout_height="300dp"
            android:layout_alignParentStart="true"
            android:layout_below="@+id/layout_info"
            app:layout_behavior="@string/appbar_scrolling_view_behavior"
            android:orientation="vertical">
    <ListView
        android:id="@+id/list"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_below="@id/bar"/>


     <android.support.design.widget.FloatingActionButton
                android:id="@+id/fabCrearEntrenamiento"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="bottom|end"
                android:layout_margin="16dp"
                android:clickable="true"
                android:src="@drawable/ic_action_add"
                app:fabSize="normal"
                app:layout_anchor="@id/layout_ejercicios"
                app:layout_anchorGravity="bottom|right|end" />
   </FrameLayout>
</android.support.design.widget.CoordinatorLayout>