- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何创建它?
如果您尝试使用 Toolbar 并且您已经膨胀了 MenuItems,您很快就会发现您的 Toolbar 布局的宽度会缩小,因此它不会覆盖 MenuItems。
唯一想到的是膨胀布局并将其作为位于 ActionBar 顶部的覆盖层添加到 Window。请记住,如果您不需要在 Toolbar/ActionBar 中扩展 MenuItems,这不是问题,因为这样您就可以占据整个宽度。
最佳答案
所以我采用了将我的 View 添加为叠加层的方法。
/**
* A Material themed search view that should be overlayed on the Toolbar.
*/
public class SearchView extends FrameLayout implements View.onClickListener {
// The search input
private final EditText mSearchEditText;
// The X button to clear the search
private final View mClearSearch;
// Listeners
private onSearchListener mOnSearchListener;
private onSearchCancelListener;
/**
* Interface definition for a callback to be invoked when a search is submitted.
*/
public interface onSearchListener {
void onSearch(String query);
}
/**
* Interface definition for a callback to be invoked when a search is canceled.
*/
public interface onSearchCancelListener {
onCancelSearch();
}
public SearchView(final Context context) {
this(context, null);
}
public SearchView(final Context context, final AttributeSet attrs) {
this(context, attrs, -1);
}
public SearchView(final Context context, final AttributeSet attrs, final int defStyle) {
super(context, attrs, defStyle);
final LayoutInflater factory = LayoutInflater.from(context);
factory.inflate(R.layout.toolbar_searchview, this);
mSearchEditText = (EditText)findViewById(R.id.search_field);
// Show/Hide the "X" button as text is entered/erased
mSearchEditText.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
toggleClearSearchButton(s);
}
@Override
public void afterTextChanged(Editable s) {}
});
// Add listeners for "Enter" or "Search" key events
mSearchEditText.setOnKeyListener(new OnKeyListener() {
@Override
public boolean onKey(View v, int keyCode, KeyEvent event) {
// Allow "Enter" key on hardware keyboard or "Search" key on soft-input to submit
if ((event.getAction() == KeyEvent.ACTION_UP) &&
(keyCode == KeyEvent.KEYCODE_ENTER ||
keyCode == KeyEvent.KEYCODE_SEARCH)) {
final String query = getSearchQuery();
// Do nothing if query is empty
if (!TextUtils.isEmpty(query) && mOnSearchListener != null) {
mOnSearchListener.onSearch(query);
}
return true;
}
return false;
}
});
findViewById(R.id.cancel_search).setOnClickListener(this);
mClearSearch = findViewById(R.id.clear_search);
mClearSearch.setOnClickListener(this);
// Hide this view until we're ready to show it
setVisibility(View.GONE);
setBackgroundColor(Color.WHITE);
}
/**
* Register a callback to be invoked which a search is submitted.
*
* @param l the callback that will run
*/
public void setOnSearchListener(final onSearchListener l) {
mOnSearchListener = l;
}
/**
* Register a callback to be invoked which a search is canceled.
*
* @param l the callback that will run
*/
public void setOnSearchCancelListener(final onSearchCancelListener l) {
mOnSearchCancelListener = l;
}
/**
* Sets the search query.
*
* @param query the query
*/
public void setSearchQuery(final String query) {
mSearchEditText.setText(query);
toggleClearSearchButton(query);
}
/**
* Returns the search query or null if none entered.
*/
public String getSearchQuery() {
return mSearchEditText.getText() != null ? mSearchEditText.getText().toString() : null;
}
/**
* Returns {@code true} if the search view is visible, {@code false} otherwise.
*/
public boolean isSearchViewVisible() {
return getVisibility() == View.VISIBLE;
}
// Show the SearchView
public void display() {
if (isSearchViewVisible()) return;
setVisibility(View.VISIBLE);
setAlpha(0f);
animate().alpha(1f)
.setDuration(200);
}
// Hide the SearchView
public void hide() {
if (!isSearchViewVisible()) return;
clearSearch();
animate().alpha(0f)
.setDuration(200);
// Delay hiding view until animation is complete
postDelayed(new Runnable() {
@Override
public void run() {
setVisibility(View.GONE);
}
}, 200);
}
// LayoutParams for this overlay
public static WindowManager.LayoutParams getSearchViewLayoutParams(final Activity activity) {
final Rect rect = new Rect();
final Window window = activity.getWindow();
window.getDecorView().getWindowVisibleDisplayFrame(rect);
final int statusBarHeight = rect.top;
final TypedArray actionBarSize = activity.getTheme().obtainStyledAttributes(
new int[] {R.attr.actionBarSize});
final int actionBarHeight = actionBarSize.getDimensionPixelSize(0, 0);
actionBarSize.recycle();
final WindowManager.LayoutParams params = new WindowManager.LayoutParams(
rect.right /* This ensures we don't go under the navigation bar in landscape */,
actionBarHeight,
WindowManager.LayoutParams.TYPE_APPLICATION_PANEL,
/* Allow touches to views outside of overlay */
WindowManager.LayoutParams.FLAG_NOT_TOUCH_MODAL,
PixelFormat.TRANSLUCENT);
params.gravity = Gravity.TOP | Gravity.START;
params.x = 0;
params.y = statusBarHeight;
return params;
}
private void toggleClearSearchButton(final CharSequence query) {
mClearSearch.setVisibility(!TextUtils.isEmpty(query) ? View.VISIBLE : View.INVISIBLE);
}
private void clearSearch() {
mSearchEditText.setText("");
mClearSearch.setVisibility(View.INVISIBLE);
}
private void onCancelSearch() {
// Default is to hide this view unless an onSearchCancelListener is available
if (mOnSearchCancelListener != null) {
mOnSearchCancelListener.onCancelSearch();
} else {
hide();
}
}
@Override
public boolean dispatchKeyEvent(@NotNull final KeyEvent event) {
// Handle "Back" key presses
if (event.getAction() == KeyEvent.ACTION_UP &&
event.getKeyCode() == KeyEvent.KEYCODE_BACK) {
onCancelSearch();
return true;
}
return super.dispatchKeyEvent(event);
}
@Override
public void onClick(View v) {
final int id = v.getId();
switch (id) {
case R.id.cancel_search:
onCancelSearch();
break;
case R.id.clear_search:
clearSearch();
break;
}
}
}
这是布局
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize">
<android.support.v7.internal.widget.TintImageView
android:id="@+id/cancel_search"
android:layout_width="56dp"
android:layout_height="match_parent"
android:background="?attr/selectableItemBackgroundBorderless"
android:contentDescription="@string/search"
android:scaleType="center"
android:src="@drawable/abc_ic_ab_back_mtrl_am_alpha" />
<EditText
android:id="@+id/search_actionbar_query_text"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:background="@android:color/transparent"
android:gravity="center_vertical"
android:hint="@string/search_hint"
android:imeOptions="actionSearch|flagNoExtractUi"
android:inputType="text|textNoSuggestions"
android:textColor="@color/search_text_color"
android:textColorHint="@color/search_hint_text_color"
android:singleLine="true"
android:textSize="16sp" />
<android.support.v7.internal.widget.TintImageView
android:id="@+id/clear_search"
android:layout_width="56dp"
android:layout_height="match_parent"
android:background="?attr/selectableItemBackgroundBorderless"
android:scaleType="center"
android:src="@drawable/abc_ic_clear_mtrl_alpha"
android:visibility="invisible" />
</LinearLayout>
这是我们在 Activity 中的实现
public class SearchActivity extends AppCompatActivity implements SearchView.onSearchListener, View.onClickListener {
private static final String BUNDLE_KEY_SEARCH_SHOWN = "key_search_shown";
private static final String BUNDLE_KEY_SEARCH_QUERY = "key_search_query";
// Keep track of whether the SearchView has been added to the window
private boolean mSearchViewAdded = false;
private SearchView mSearchView;
private Toolbar mToolbar;
private WindowManager mWindowManager;
// Bundle passed in to onCreate()
private Bundle mSavedInstanceState;
@Override
protected void onCreate(Bundle icicle) {
super.onCreate(icicle);
mSavedInstanceState = icicle;
mWindowManager = (WindowManager) getSystemService(Context.WINDOW_SERVICE);
// This is just an example so you would need to tie this to your own button. This is here so you can show/hide the SearchView.
findViewById(R.id.sample_btn).setOnClickListener(this);
// You should have added a Toolbar View to your layout already so reference it here by your id you assigned it
mToolbar = (Toolbar)findViewById(R.id.toolbar);
if (mToolbar != null) {
mSearchView = new SearchView(this);
mSearchView.setOnSearchListener(this);
setSupportActionBar(mToolbar);
}
}
@Override
protected void onResume() {
super.onResume();
if (mToolbar != null) {
// Delay adding SearchView until Toolbar has finished loading
mToolbar.post(new Runnable() {
@Override
public void run() {
if (!mSearchViewAdded && mWindowManager != null) {
mWindowManager.addView(mSearchView,
SearchView.getSearchViewLayoutParams(SearchActivity.this));
mSearchViewAdded = true;
if (mSavedInstanceState != null) {
mSearchView.setSearchQuery(
mSavedInstanceState.getString(BUNDLE_KEY_SEARCH_QUERY));
if (mSavedInstanceState.getBoolean(BUNDLE_KEY_SEARCH_SHOWN)) {
mSearchView.display();
}
}
}
}
});
}
}
@Override
protected void onPause() {
super.onPause();
if (mSearchViewAdded) {
try {
mWindowManager.removeView(mSearchView);
} catch (IllegalArgumentException e) {
// Have seen this happen on occasion during orientation change.
}
mSearchViewAdded = false;
}
}
@Override
public void onSaveInstanceState(Bundle outState) {
if (mSearchView != null) {
outState.putBoolean(BUNDLE_KEY_SEARCH_SHOWN, mSearchView.isSearchViewVisible());
outState.putString(BUNDLE_KEY_SEARCH_QUERY, mSearchView.getSearchQuery());
}
}
@Override
public void onClick(View v) {
final int id = v.getId();
switch (id) {
case R.id.sample_btn:
if (mSearchView.isSearchVisible()) {
mSearchView.hide();
} else {
mSearchView.display();
}
break;
}
}
@Override
public void onSearch(final String query) {
// Handle search here
}
}
关于android - 如何制作覆盖整个 ActionBar/Toolbar 的 SearchView,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30133185/
我在我的应用程序中设置了一个操作栏。我通过调用 Activity.getActionBar() 取回 ActionBar .然后我设置了我需要的所有选项卡感谢 ActionBar.addTab()和
我正在为 Android 平板电脑 (XOOM) 开发应用程序,我想知道是否可以将操作栏放在屏幕底部,而不是顶部(这是默认选项) . 谢谢。 最佳答案 如果您在 Activity 中获取 Action
我很想为我用“ActionBar Sherlock”库导入的 ActionBar 设置一个背景图像。但是,我在 Internet 上找不到任何有关如何使用 XML 独特地设置 BackgroundIm
我需要在栏下方显示子菜单,而不是在栏本身的顶部。 复制下面我的 actionbar xml 在activity中(
我已经阅读了 AppCompat 库中的工具栏及其所有功能。我在 android 开发者博客 (here) 中注意到的一些事情是: Toolbar is fully supported in AppC
我试图做一个 Espresso 测试来检查 actionbar 是否隐藏/显示,但我似乎无法弄清楚如何将它与 Espresso.onView(...) 匹配。 Afaik它没有ID,对吧? 非常感谢
我们怎样才能让操作栏和操作栏选项卡变成纯白色。我正在使用 android-support-v7-appcompat 库来支持向后兼容性。 style/Theme.AppCompat.Light.Dar
在 Galaxy S3 上,我遇到一个问题,即 ActionBar 中的一个按钮被配置为 showAsAction="always"并且同时显示在硬件溢出菜单和操作按钮上。我希望它不显示在硬件溢出菜单
我正在学习教程 https://www.youtube.com/watch?v=VVahIc8yENk我得到了错误 java.lang.NullPointerException: Attempt to
背景 我希望在 PreferenceActivity 上显示一个 ActionBar,因为它不适用于 Honeycomb 之前的设备(即使在支持库中)。 因为这样的类在支持库中不可用,所以我不能只调用
我想实现将下载数据并将其设置到 ActionBar 选项卡中的应用程序。我已经实现了它,但我还有一件事要做。我试过添加操作栏列表,像这样 one , 但 android 不允许同时使用 Tabs 和
我希望我的 ActionBar 和 Tabs 看起来像这样。 请忽略颜色 目前看起来是这样 由于我的主题,我必须在 java 中设置自定义 ActionBar。 actionBar.setDispla
我目前正在某些页面上设置 ActionBar 副标题,但在某些页面上我不想有副标题。 我可以简单地将字幕文本设置为空,但这只会删除文本。它仍然占据字幕空间,从而将标题推高。可能很难解释,所以我用图片说
import android.app.ActionBar; import android.app.FragmentTransaction; import android.content.Intent;
我正在使用 ActionBarSherlock ,并尝试隐藏/显示全屏图像的 ActionBar,使用: getSupportActionBar.hide(); 和 getSupportActionB
我在我的简单应用程序上使用 ActionBarSherlock,如果用户在主页/主要 Activity 中,我想隐藏主页按钮。我了解如何使用 setHomeButtonEnabled(false) 执
我发现自己在 3 个单独的 Activity 中为我的 actionBar (actionBarSherlock) 列表重写了相同的代码。所有 3 个都使用相同的 actionBar,它有 3 个项目
我正在使用 ActionBarSherlock 在关于 ActionBar 标签高度的类似问题中,我使用了: @style/blah1 @style/blah2 80dp .
我一直在寻找是否有任何关于如何始终在 ActionBar 下方显示 ActionBar 选项卡的信息,即使当手机横向时也是如此。我知道它会根据屏幕上是否有足够的空间来自动将选项卡放置在 ActionB
我在 ActionBar 上方显示的 ActionBar Tabs 出现了这种奇怪的行为。当我为 ActionBar 设置自定义 View 时,这恰好发生了。我正在使用 Roman Nurik 的示例
我是一名优秀的程序员,十分优秀!