如何折叠主片段工具栏和主工具栏?

时间:2018-04-14 12:54:39

标签: java android image toolbar collapse

我在片段中有一个折叠工具栏,因此工具栏会折叠但看起来很尴尬,因为片段工具栏和主工具栏仍然存在。当我向上滑动时,我怎么也崩溃了?我考虑过将我的代码转换为活动而不是片段,但这会破坏整个事情。

这是我的片段XML代码

<android.support.design.widget.CoordinatorLayout 
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent">

<android.support.design.widget.AppBarLayout
    android:id="@+id/app_bar_layout"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <android.support.design.widget.CollapsingToolbarLayout
        android:id="@+id/collapsing_toolbar"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:contentScrim="?attr/colorPrimary"
        app:layout_scrollFlags="scroll|exitUntilCollapsed">

        <ImageView
            android:src="@drawable/profilepic"
            android:id="@+id/profilePic"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:scaleType="centerCrop"
            app:layout_collapseMode="parallax"
            app:layout_collapseParallaxMultiplier="0.7" />

        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            app:layout_collapseMode="pin">


        </android.support.v7.widget.Toolbar>


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

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

<android.support.v4.widget.NestedScrollView
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@android:color/white"
    app:layout_behavior="@string/appbar_scrolling_view_behavior">


    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@drawable/a"
        android:gravity="center_horizontal"
        android:orientation="vertical">

        <TextView
            android:id="@+id/name"
            android:layout_width="70dp"
            android:layout_height="30dp"
            android:layout_marginTop="12dp"
            android:text="Name"
            android:textColor="@color/white"
            android:textSize="20dp" />

        <TextView
            android:id="@+id/status"
            android:layout_width="70dp"
            android:layout_height="30dp"
            android:layout_marginTop="45dp"
            android:text="Status"
            android:textColor="@color/silver"
            android:textSize="20dp" />

        <TextView
            android:id="@+id/email"
            android:layout_width="70dp"
            android:layout_height="30dp"
            android:layout_marginTop="21dp"
            android:text="Email"
            android:textSize="20dp" />

        <TextView
            android:id="@+id/quote"
            android:layout_width="70dp"
            android:layout_height="30dp"
            android:layout_marginTop="27dp"
            android:text="Quote"
            android:textSize="20dp" />

        <TextView
            android:id="@+id/textView"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Number"
            android:textSize="20dp" />

    </LinearLayout>

</android.support.v4.widget.NestedScrollView>

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

屏幕截图 - http://ibb.co/euoqwn

我希望MESSAGE +的工具栏和片段寻呼机崩溃

3 个答案:

答案 0 :(得分:0)

要隐藏主要活动工具栏并仅显示折叠工具栏,您需要将以下主题设置为清单中的活动: -

<activity
    android:name=".MainActivity"
    android:theme="@style/Theme.AppCompat.Translucent" >
</activity>

在style.xml文件中创建主题: - 的 Theme.Translucent

<style name="Theme.AppCompat.Translucent">
    <item name="android:windowNoTitle">true</item>
    <item name="android:windowBackground">@android:color/transparent</item>
    <item name="android:colorBackgroundCacheHint">@null</item>
    <item name="android:windowIsTranslucent">true</item>
    <item name="android:windowAnimationStyle">@android:style/Animation</item>
</style>

您也可以使用 Theme.NoActionBar 作为替代

 <style name = "NoActionBar" parent = "@android:style/Theme.Holo.Light">
        <item name = "android:windowActionBar">false</item>
        <item name = "android:windowNoTitle">true</item>
    </style>

我希望它可以帮到你。

答案 1 :(得分:0)

将此代码粘贴到您的片段类

@Override
public void onResume() {
    super.onResume();
    ((AppCompatActivity)getActivity()).getSupportActionBar().hide();
}
@Override
public void onStop() {
    super.onStop();
    ((AppCompatActivity)getActivity()).getSupportActionBar().show();
}

答案 2 :(得分:0)

对于您的主Activity,请使用工具栏设置主题。对于您的片段,设置没有工具栏的样式/主题。除了你想要的一个片段之外:将一个片段设置为带有工具栏的样式/主题。

然后以编程方式控制该片段的工具栏。