将 SearchView 与 AppCompatActivity 一起使用会导致 UI 故障
Using SearchView with AppCompatActivity results in UI glitches
我正在尝试创建一个 Android 应用程序,在操作栏中带有搜索按钮,当用户按下搜索按钮时,操作栏上会出现一个搜索文本框,如 Google 的 Messenger 应用程序(见下文)。
我尝试如下所示实现它,但我的应用程序如下所示:
这有一些问题。例如,文本显示带有省略号的 "Search...",这与没有省略号的简单 "Search" 不同,但到目前为止最令人担忧的是,工具栏中没有后退按钮,搜索按钮是向左推得太远,右边的溢出按钮已经被推到了一边。此外,按下我设备上的物理后退按钮不会折叠搜索视图,它只存在于应用程序中。
下面是我用来尝试实现搜索栏的一些代码。我尝试设置一个 SearchViewExpandListener
,如下所示,以便在展开搜索视图时显示后退按钮,但它不起作用。
编辑:我还 运行 在我的 onMenuItemActionExpand
和 onMenuItemActionCollapsed
方法上设置了断点的应用程序,我发现这些方法实际上从未被调用过。
MainActivity.java
import android.content.Context;
import android.support.v4.view.MenuItemCompat;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.SearchView;
import android.support.v7.widget.Toolbar;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
getSupportActionBar().setDisplayShowHomeEnabled(false);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu, menu);
MenuItem searchItem = menu.findItem(R.id.action_search);
SearchView searchView = (SearchView) MenuItemCompat.getActionView(searchItem);
// See above
MenuItemCompat.setOnActionExpandListener(searchItem, new SearchViewExpandListener(this));
MenuItemCompat.setActionView(searchItem, searchView);
searchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
@Override
public boolean onQueryTextSubmit(String s) {
Toast.makeText(MainActivity.this, "You searched " + s, Toast.LENGTH_SHORT).show();
return false;
}
@Override
public boolean onQueryTextChange(String s) {
return false;
}
});
return true;
}
// See above
private class SearchViewExpandListener implements MenuItemCompat.OnActionExpandListener {
private Context context;
public SearchViewExpandListener (Context c) {
context = c;
}
@Override
public boolean onMenuItemActionExpand(MenuItem item) {
((AppCompatActivity) context).getSupportActionBar().setDisplayShowHomeEnabled(true);
return false;
}
@Override
public boolean onMenuItemActionCollapse(MenuItem item) {
((AppCompatActivity) context).getSupportActionBar().setDisplayShowHomeEnabled(false);
return false;
}
}
}
menu.xml
<?xml version="1.0" encoding="utf-8" ?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item
android:id="@+id/action_search"
android:title="Search"
app:actionViewClass="android.support.v7.widget.SearchView"
app:showAsAction="ifRoom"/>
<item android:id="@+id/action_about"
android:title="About"
app:showAsAction="never"/>
</menu>
看来不止我一个人有这个问题。 This guide on implementing a SearchView 似乎遇到了类似的问题。
那么 在 AppCompatActivity 中实现搜索栏的正确方法是什么,它会生成类似于 Google 的 Material 设计指南等中的搜索栏在他们的应用程序中,例如 Google Messenger? 我觉得我过去一直在无休止地谷歌搜索,但我找不到任何对我有帮助的东西。
在 serchView 菜单项 showAsAction
中使用 collapseActionView
标志和 always
app:showAsAction="always|collapseActionView"
collapseActionView
标志指示当用户未与其交互时如何显示小部件:如果小部件在应用栏上,应用应将小部件显示为图标。如果小部件位于溢出菜单中,则应用程序应将小部件显示为菜单项。当用户与操作视图交互时,它会扩展以填充应用栏。
我正在尝试创建一个 Android 应用程序,在操作栏中带有搜索按钮,当用户按下搜索按钮时,操作栏上会出现一个搜索文本框,如 Google 的 Messenger 应用程序(见下文)。
我尝试如下所示实现它,但我的应用程序如下所示:
这有一些问题。例如,文本显示带有省略号的 "Search...",这与没有省略号的简单 "Search" 不同,但到目前为止最令人担忧的是,工具栏中没有后退按钮,搜索按钮是向左推得太远,右边的溢出按钮已经被推到了一边。此外,按下我设备上的物理后退按钮不会折叠搜索视图,它只存在于应用程序中。
下面是我用来尝试实现搜索栏的一些代码。我尝试设置一个 SearchViewExpandListener
,如下所示,以便在展开搜索视图时显示后退按钮,但它不起作用。
编辑:我还 运行 在我的 onMenuItemActionExpand
和 onMenuItemActionCollapsed
方法上设置了断点的应用程序,我发现这些方法实际上从未被调用过。
MainActivity.java
import android.content.Context;
import android.support.v4.view.MenuItemCompat;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.SearchView;
import android.support.v7.widget.Toolbar;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
getSupportActionBar().setDisplayShowHomeEnabled(false);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu, menu);
MenuItem searchItem = menu.findItem(R.id.action_search);
SearchView searchView = (SearchView) MenuItemCompat.getActionView(searchItem);
// See above
MenuItemCompat.setOnActionExpandListener(searchItem, new SearchViewExpandListener(this));
MenuItemCompat.setActionView(searchItem, searchView);
searchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
@Override
public boolean onQueryTextSubmit(String s) {
Toast.makeText(MainActivity.this, "You searched " + s, Toast.LENGTH_SHORT).show();
return false;
}
@Override
public boolean onQueryTextChange(String s) {
return false;
}
});
return true;
}
// See above
private class SearchViewExpandListener implements MenuItemCompat.OnActionExpandListener {
private Context context;
public SearchViewExpandListener (Context c) {
context = c;
}
@Override
public boolean onMenuItemActionExpand(MenuItem item) {
((AppCompatActivity) context).getSupportActionBar().setDisplayShowHomeEnabled(true);
return false;
}
@Override
public boolean onMenuItemActionCollapse(MenuItem item) {
((AppCompatActivity) context).getSupportActionBar().setDisplayShowHomeEnabled(false);
return false;
}
}
}
menu.xml
<?xml version="1.0" encoding="utf-8" ?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item
android:id="@+id/action_search"
android:title="Search"
app:actionViewClass="android.support.v7.widget.SearchView"
app:showAsAction="ifRoom"/>
<item android:id="@+id/action_about"
android:title="About"
app:showAsAction="never"/>
</menu>
看来不止我一个人有这个问题。 This guide on implementing a SearchView 似乎遇到了类似的问题。
那么 在 AppCompatActivity 中实现搜索栏的正确方法是什么,它会生成类似于 Google 的 Material 设计指南等中的搜索栏在他们的应用程序中,例如 Google Messenger? 我觉得我过去一直在无休止地谷歌搜索,但我找不到任何对我有帮助的东西。
在 serchView 菜单项 showAsAction
中使用 collapseActionView
标志和 always
app:showAsAction="always|collapseActionView"
collapseActionView
标志指示当用户未与其交互时如何显示小部件:如果小部件在应用栏上,应用应将小部件显示为图标。如果小部件位于溢出菜单中,则应用程序应将小部件显示为菜单项。当用户与操作视图交互时,它会扩展以填充应用栏。