与吐司不同,它Snackbar.make(...).show()
只会显示最后一个小吃店,其他小吃店都不见了。
for(int i = 1;i < 11;i++) {
Snackbar.make(..., "number: " + i, Snackbar.LENGTH_SHORT).show();
}
有时,当snackbar 应该在网络任务之后显示而一个应该在网络任务之前显示时,秒snackbar 永远不会显示。
我使用协调器布局。
与吐司不同,它Snackbar.make(...).show()
只会显示最后一个小吃店,其他小吃店都不见了。
for(int i = 1;i < 11;i++) {
Snackbar.make(..., "number: " + i, Snackbar.LENGTH_SHORT).show();
}
有时,当snackbar 应该在网络任务之后显示而一个应该在网络任务之前显示时,秒snackbar 永远不会显示。
我使用协调器布局。
我现在实现了我自己的队列:
protected ArrayList<Snackbar> mSnackbarList = new ArrayList<>();
protected Snackbar.Callback mCallback = new Snackbar.Callback() {
@Override
public void onDismissed(Snackbar snackbar, int event) {
mSnackbarList.remove(snackbar);
if (mSnackbarList.size() > 0)
displaySnackbar(mSnackbarList.get(0));
}
};
public void addQueue(Snackbar snackbar){
setLayoutParams(snackbar);
snackbar.setCallback(mCallback);
boolean first = mSnackbarList.size() == 0;
mSnackbarList.add(snackbar);
if(first)
displaySnackbar(snackbar);
}
public void displaySnackbar(Snackbar snackbar){
snackbar.show();
}
请参考 Android 组件文档:
Snackbars 会自动从屏幕超时。出于可用性原因,snackbars 不应包含访问核心用例的唯一方法。它们不应该是持久的或堆叠的,因为它们在屏幕上的其他元素之上(来源)