如何在Android中像iOS一样拉伸和移动特定的视图/屏幕?

时间:2018-08-27 07:17:48

标签: android ios android-layout

我不知道如何确切地提出这个问题,但是IOS具有一项功能,他们可以通过拉伸将其移动到标题栏下方。在ios应用中,他们有一个标题栏,其中有编辑文本。它们会在屏幕启动时隐藏编辑文本,并且在滚动recyclerview的同时显示屏幕信息并显示它。他们可以通过向上滚动来再次隐藏它,但是滚动不是必需的。因此,它更多的是拉伸效果而不是滚动效果。

这是我主要活动的代码

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/root_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/app_background_color"
android:fitsSystemWindows="true">
<RelativeLayout
    android:id="@+id/ll_toolbar"
    android:layout_width="match_parent"
    android:layout_height="@dimen/toolbar_height"
    android:layout_alignParentTop="true"
    android:background="@color/toolbar_color">
    <ImageView
        android:id="@+id/iv_logo"
        android:layout_width="100dp"
        android:layout_height="30dp"
        android:layout_centerInParent="true"
        android:layout_gravity="center_horizontal"
        android:contentDescription="@string/app_name"
        app:srcCompat="@drawable/my_airlines_logo_small" />
    <LinearLayout
        android:layout_width="@dimen/date_time_view_width"
        android:layout_height="match_parent"
        android:layout_alignParentEnd="true"
        android:background="@color/toolbar_color"
        android:gravity="center_horizontal"
        android:orientation="vertical">
        <TextView
            android:id="@+id/tv_date"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textColor="@color/white_color"
            android:textSize="@dimen/date_text_size" />
        <TextView
            android:id="@+id/tv_time"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textColor="@color/white_color"
            android:textSize="@dimen/time_text_size" />
    </LinearLayout>
</RelativeLayout>
<LinearLayout
    android:id="@+id/ll_search_bar"
    android:layout_width="match_parent"
    android:layout_height="@dimen/toolbar_height"
    android:layout_below="@id/ll_toolbar"
    android:layout_gravity="center"
    android:background="@color/toolbar_color"
    android:gravity="center"
    android:orientation="horizontal"
    android:visibility="gone">
    <EditText
        android:id="@+id/"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_margin="@dimen/drawable_text_padding"
        android:background="@drawable/search_bar_background"
        android:drawablePadding="@dimen/drawable_text_padding"
        android:drawableStart="@drawable/search"
        android:ellipsize="end"
        android:gravity="start|center"
        android:hint="@string/search_hint"
        android:imeOptions="actionDone"
        android:inputType="text"
        android:lines="1"
        android:padding="@dimen/drawable_text_padding"
        android:textColor="@color/white_color"
        android:textColorHint="@color/search_text_color"
        android:textSize="@dimen/toolbar_text_size" />
</LinearLayout>
<TextView
    android:id="@+id/tv_header"
    android:layout_width="match_parent"
    android:layout_height="@dimen/toolbar_height"
    android:layout_below="@id/ll_search_bar"
    android:background="@color/header_background_color"
    android:gravity="center"
    android:textColor="@color/white_color"
    android:textSize="@dimen/toolbar_text_size"
    android:textStyle="bold" />
<!-- As the main content view, the view below consumes the entire
     space available using match_parent in both dimensions. -->
<FrameLayout
    android:id="@+id/container"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_above="@+id/bottom_navigation"
    android:layout_below="@id/tv_header" />
<android.support.design.widget.BottomNavigationView
    android:id="@+id/bottom_navigation"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    app:itemBackground="@color/secondary_color"
    app:itemIconTint="@drawable/bottom_bar_color_selector"
    app:itemTextColor="@drawable/bottom_bar_color_selector"
    app:menu="@menu/bottom_navigation_main" />

所以在

  

“ id /容器”

我加载一个片段,该片段充当另外两个分别包含recyclerview的片段的持有者。我所了解的是我需要对协调器/可折叠工具栏布局进行一些操作。但是我不知道如何进行。如果不能完全做到这一点,我们能否实现一些目标呢?

0 个答案:

没有答案