如何在没有 ActionBar 的片段中实现 SearchView
How to implement SeachView in fragment without ActionBar
我有 BottomNavigationBar
,在 MainActivity
中有 3 个片段。 MainActivity
没有操作栏。
现在我必须在我的第二个片段中实现 SearchView
。我需要一个类似 WhatsApp 的 Searview。目前,我已经实现了它但是当我点击搜索视图时它的 EditText
没有设置它的高度和宽度为 match_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>
代码
final TextView txtHeader = (TextView) view.findViewById(R.id.txtHeader);
final SearchView searchView = (SearchView) view.findViewById(R.id.search_bar);
searchView.setQueryHint("Search");
searchView.setOnSearchClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
txtHeader.setVisibility(View.GONE);
}
});
searchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
@Override
public boolean onQueryTextSubmit(String s) {
return false;
}
@Override
public boolean onQueryTextChange(String s) {
//my code here for search
return false;
}
});
试试这个
<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>
代码
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;
}
});
我有 BottomNavigationBar
,在 MainActivity
中有 3 个片段。 MainActivity
没有操作栏。
现在我必须在我的第二个片段中实现 SearchView
。我需要一个类似 WhatsApp 的 Searview。目前,我已经实现了它但是当我点击搜索视图时它的 EditText
没有设置它的高度和宽度为 match_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>
代码
final TextView txtHeader = (TextView) view.findViewById(R.id.txtHeader);
final SearchView searchView = (SearchView) view.findViewById(R.id.search_bar);
searchView.setQueryHint("Search");
searchView.setOnSearchClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
txtHeader.setVisibility(View.GONE);
}
});
searchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
@Override
public boolean onQueryTextSubmit(String s) {
return false;
}
@Override
public boolean onQueryTextChange(String s) {
//my code here for search
return false;
}
});
试试这个
<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>
代码
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;
}
});