在安卓中隐藏Tablayout栏

3

我有一个包含toolbarTablayoutviewpager的活动,其中包含像这样的片段:

enter image description here 我想在所有片段上实现toolbar材料搜索。

就像这样enter image description here

但是问题在于TAB栏。 我想在搜索打开时隐藏选项卡栏(Call,Chat,Contact),并在搜索关闭时取消隐藏

如何隐藏选项卡栏?

我正在使用这个库来实现材料搜索视图

布局代码如下

<?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_width="match_parent"
        android:layout_height="wrap_content"
        android:theme="@style/AppTheme.AppBarOverlay">
        <FrameLayout
            android:id="@+id/toolbar_container"
            android:layout_width="match_parent"
            android:layout_height="wrap_content">
        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="?attr/colorPrimary"

            android:minHeight="?attr/actionBarSize"
            app:popupTheme="@style/AppTheme.PopupOverlay" />

        <com.miguelcatalan.materialsearchview.MaterialSearchView
            android:id="@+id/search_view"
            android:layout_width="match_parent"
            android:layout_height="wrap_content" />

        </FrameLayout>

        <android.support.design.widget.TabLayout
            android:id="@+id/tabs"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            app:tabMode="scrollable"
            app:tabGravity="center"/>

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

    <include layout="@layout/content_dashboard" />


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

很高兴能帮忙! - Rucha Bhatt Joshi
1个回答

8

这是你的解决方案,我在片段中尝试了这个。

1. 在主活动中编写以下两种方法,其中包含用于隐藏和显示选项卡布局的tablayout。

    public static void showTabLayout() {
                parentTabs.setVisibility(View.VISIBLE);
            }

    public static void hideTabLayout() {
                parentTabs.setVisibility(View.GONE);

            }

2.创建接口

 public interface FragmentLifecycle {

        public void onPauseFragment();
        public void onResumeFragment();

    }

3. 实现接口并调用隐藏/显示选项卡布局的方法

CameraFragment.java

package demo.com.demo;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;


/**
 * Created by rucha on 24/11/16.
 */
public class CameraFragment extends Fragment implements FragmentLifecycle {

    public CameraFragment() {
        // Required empty public constructor
    }

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        View rootView = null;
        rootView = inflater.inflate(R.layout.fragment_blue,
                container, false);
        setupUI(rootView);
        return rootView;
    }

    private void setupUI(View rootView) {
    }


    @Override
    public void onPauseFragment() {
        MainActivity.showTabLayout();
    }

    @Override
    public void onResumeFragment() {
        MainActivity.hideTabLayout();
    }
}

我希望这对你有所帮助。愉快的编程!

简单而棒的功能,但需要一些修改。onPauseFragment()和onResumeFragment()的名称有点令人困惑,我想在搜索视图显示时隐藏选项卡栏,在搜索视图关闭时也是如此,而不是在onResume和onPause中实现。 - K Guru
@kamran,是的,肯定的,因为我根据我的需求编写了这段代码。但我感觉有些类似于你的情况,所以我发了帖子。我很高兴它解决了你的问题。请发布你的答案,这对其他人也会有帮助。 - Rucha Bhatt Joshi
嗨@schtipoun,抱歉,我也在学习Kotlin;但我还没有达到那个点,如果我得到任何东西,我会在这里发布,同时,如果你得到任何东西,也可以在这里更新,谢谢。 - Rucha Bhatt Joshi
1
@RuchaBhattJoshi 是的,我已经想出如何使用 Companion 对象等来完成它了。稍后我会在这里发布解决方案 :) - schtipoun
如何为此添加动画效果? - Nitin Karale
显示剩余3条评论

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接