Android 如何在没有ActionBar的情况下在片段中实现SeachView

Android 如何在没有ActionBar的情况下在片段中实现SeachView,android,android-fragments,searchview,Android,Android Fragments,Searchview,我有BottomNavigationBar,在MainActivity中有3个片段。main活动没有操作栏 现在我必须在第二个片段中实现一个SearchView。我需要一个类似WhatsApp的Searview。目前,我已经实现了它,但是当我点击searchview时,它的EditText没有设置它的高度和宽度为match\u parent 我还想让后退按钮折叠它。我怎样才能做到这一点 这是我的第二个片段 <LinearLayout xmlns:android="http://schema

我有
BottomNavigationBar
,在
MainActivity
中有3个片段。
main活动
没有操作栏

现在我必须在第二个片段中实现一个
SearchView
。我需要一个类似WhatsApp的Searview。目前,我已经实现了它,但是当我点击searchview时,它的
EditText
没有设置它的高度和宽度为
match\u parent

我还想让后退按钮折叠它。我怎样才能做到这一点

这是我的第二个片段

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:background="@color/white"
android:layout_marginBottom="?attr/actionBarSize"
xmlns:shimmer="http://schemas.android.com/apk/res-auto"
tools:context=".StudentAttendance">

<android.support.v7.widget.Toolbar
    android:background="@drawable/bg_list_item"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <TextView
        android:id="@+id/txtHeader"
        android:text="Student Attendance"
        android:textSize="18sp"
        android:textColor="#767a8c"
        android:fontFamily="@font/circularstdbold"
        android:padding="18dp"
        android:gravity="center"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />
    <android.support.v7.widget.SearchView
        android:id="@+id/search_bar"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">
    </android.support.v7.widget.SearchView>
</android.support.v7.widget.Toolbar>



<com.facebook.shimmer.ShimmerFrameLayout
    android:id="@+id/shimmer_layout"
    shimmer:duration="80"
    android:orientation="vertical"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content">

    <LinearLayout
        android:orientation="vertical"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">
        <include layout="@layout/placeholder_list"/>
        <include layout="@layout/placeholder_list"/>
        <include layout="@layout/placeholder_list"/>
        <include layout="@layout/placeholder_list"/>
        <include layout="@layout/placeholder_list"/>
        <include layout="@layout/placeholder_list"/>
        <include layout="@layout/placeholder_list"/>
    </LinearLayout>
</com.facebook.shimmer.ShimmerFrameLayout>

<LinearLayout
    android:id="@+id/fitall"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical"></LinearLayout>
  </LinearLayout>
试试这个

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

    <RelativeLayout
            android:id="@+id/not"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
    >
        <android.support.v7.widget.SearchView
                 android:layoutDirection="rtl"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content" />
    </RelativeLayout>
</android.support.v7.widget.Toolbar>

你会得到这样的东西。这就是你想要的,对吗

xml

<android.support.v7.widget.Toolbar
    android:background="@drawable/bg_list_item"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <RelativeLayout
        android:id="@+id/not"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        >
        <TextView
            android:id="@+id/txtHeader"
            android:text="Student Attendance"
            android:textSize="18sp"
            android:textColor="#767a8c"
            android:fontFamily="@font/circularstdbold"
            android:padding="18dp"
            android:gravity="center"
            android:layout_width="match_parent"
            android:layout_height="wrap_content" />
        <android.support.v7.widget.SearchView
            android:id="@+id/search_view"
            android:layout_centerVertical="true"
            android:layout_alignParentRight="true"
            android:layout_alignParentEnd="true"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />
    </RelativeLayout>
</android.support.v7.widget.Toolbar>

你的问题是什么?它是编辑文本的宽度。使其匹配\u parent但是如何将edittext设置为匹配\u parent?它是searchview的编辑文本你需要右边的图标吗?我需要右边的图标。然后,当它单击时,其输入字段将打开,宽度匹配父项并在左侧使用左箭头将其再次折叠。更新了答案。我的问题是,当我单击此searchview时,它应该在工具栏中的“我的文本视图”上方以“宽度匹配\父对象”打开它的EditText。当前它的EditText有其默认的SizeEyes。我需要类似这样的内容。这是我告诉你的。同上。只需隐藏后退按钮。
<android.support.v7.widget.Toolbar
    android:background="@drawable/bg_list_item"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <RelativeLayout
        android:id="@+id/not"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        >
        <TextView
            android:id="@+id/txtHeader"
            android:text="Student Attendance"
            android:textSize="18sp"
            android:textColor="#767a8c"
            android:fontFamily="@font/circularstdbold"
            android:padding="18dp"
            android:gravity="center"
            android:layout_width="match_parent"
            android:layout_height="wrap_content" />
        <android.support.v7.widget.SearchView
            android:id="@+id/search_view"
            android:layout_centerVertical="true"
            android:layout_alignParentRight="true"
            android:layout_alignParentEnd="true"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />
    </RelativeLayout>
</android.support.v7.widget.Toolbar>
 final android.support.v7.widget.SearchView searchView = (SearchView) view.findViewById(R.id.search_view);

    searchView.setQueryHint("Search");
    searchView.setMaxWidth(Integer.MAX_VALUE);

    searchView.setOnSearchClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            txtHeader.setVisibility(View.GONE);
        }
    });

    searchView.setOnCloseListener(new SearchView.OnCloseListener() {
        @Override
        public boolean onClose() {
            txtHeader.setVisibility(View.VISIBLE);
            return false;
        }
    });