色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

Android 如何實現彈窗順序&優先級控制

瀏覽:4日期:2022-09-20 09:06:29

一般在項目首頁中,往往會有多個對話框需要彈出,比如活動彈窗、更新彈窗、評分彈窗等等,而且這些彈窗是有優先級順序的。這些彈窗一般是通過接口請求后返回結果再顯示的,如果只有幾個彈窗還好處理,業務邏輯上判斷一下先后顯示就可以。如果有十幾個或者更多,那么處理起來將非常麻煩,而且容易出現問題。

所以封裝一個可以按照優先級順序顯示的彈窗功能就非常有必要,首先功能需求如下:

按優先級順序阻塞式顯示各種類型彈窗,默認從最高優先級開始顯示 只有上一個高優先級彈窗顯示完或者取消顯示,下一個低優先級彈窗才可以顯示 指定顯示某一個彈窗的前提是沒有更高優先級的彈窗需要顯示 在顯示一個彈窗之前需要判斷是否能夠或者需要顯示 根據優先級去查找指定的彈窗,優先級相當于唯一ID 彈窗包括多種類型,Dialog、PopupWindow、Activity等等

接著開始編碼去實現功能,先定一個枚舉類,羅列出支持的彈窗類型,包括Dialog、PopupWindow、Activity等等。

public enum WindowType { DIALOG, POUPOWINDOW, TOAST, SNACKBAR, WIDGET, ACTIVITY, OTHERS}

然后定義彈窗接口IWindow,它定義了彈窗的基本功能。

/*** 窗口約定規則*/public interface IWindow { /** * 彈窗展示 */ void show(Activity activity); /** * 彈窗關閉 */ void dismiss(); /** * 設置窗口關閉監聽 */ void setOnWindowDismissListener(OnWindowDismissListener listener); /** * 設置窗口展示監聽 */ void setOnWindowShowListener(OnWindowShowListener listener);}

以及彈窗顯示和關閉的監聽接口,

/*** 窗口關閉監聽*/public interface OnWindowDismissListener { /** * */ void onDismiss();}/*** 窗口展示監聽*/public interface OnWindowShowListener { void onShow();}

接下來定義個包裹類WindowWrapper去封裝彈窗相關的屬性和狀態,包括彈窗、優先級、能否顯示、窗體類型等等,在處理彈窗顯示邏輯時將會用到。

/*** 窗口參數類*/public class WindowWrapper { /** * 窗口 */ private IWindow mWindow; /** * 優先級,值越大優先級越高 */ private int mPriority; /** * 當前是否處于show狀態 */ private boolean isShowing; /** * 是否滿足show的條件 */ private boolean isCanShow; /** * 彈窗類型 */ private WindowType mWindowType; /** * 彈窗名稱 */ private String mWindowName; private WindowWrapper(Builder builder) { mWindow = builder.window; mPriority = builder.priority; mWindowType = builder.windowType; isCanShow = builder.isCanShow; mWindowName = builder.windowName; } public IWindow getWindow() { return mWindow; } public void setWindow(IWindow window) { this.mWindow = window; } public int getPriority() { return mPriority; } public void setPriority(int priority) { this.mPriority = priority; } public boolean isShowing() { return isShowing; } public void setShowing(boolean showing) { isShowing = showing; } public WindowType getWindowType() { return mWindowType; } public void setWindowType(WindowType mWindowType) { this.mWindowType = mWindowType; } public boolean isCanShow() { return isCanShow; } public void setCanShow(boolean canShow) { isCanShow = canShow; } public String getWindowName() { return mWindowName; } public void setWindowName(String mWindowName) { this.mWindowName = mWindowName; } public static class Builder { /** * 窗口 */ private IWindow window; /** * 優先級,值越大優先級越高 */ private int priority; /** * 彈窗類型 */ private WindowType windowType; /** * 是否滿足show的條件 */ private boolean isCanShow; /** * 彈窗名稱 */ private String windowName; public Builder window(IWindow window) { this.window = window; return this; } public Builder priority(int priority) { this.priority = priority; return this; } public Builder windowType(WindowType type) { this.windowType = type; return this; } public Builder setCanShow(boolean canShow) { isCanShow = canShow; return this; } public String getWindowName() { return windowName; } public Builder setWindowName(String windowName) { this.windowName = windowName; return this; } public WindowWrapper build() { return new WindowWrapper(this); } }}

最后通過WindowTaskManager類去統一組織管理彈窗的添加、顯示、關閉等邏輯,

public class WindowTaskManager { private List<WindowWrapper> mWindows; private static WindowTaskManager mDefaultInstance; private WindowTaskManager() { } /** * 獲取彈窗管理者 */ public static WindowTaskManager getInstance() { if (mDefaultInstance == null) { synchronized (WindowTaskManager.class) {if (mDefaultInstance == null) { mDefaultInstance = new WindowTaskManager();} } } return mDefaultInstance; } /** * 添加彈窗 * * @param windowWrapper 待顯示的彈窗 */ public synchronized void addWindow(Activity activity, WindowWrapper windowWrapper) { if (windowWrapper != null) { if (mWindows == null) {mWindows = new ArrayList<>(); } if (windowWrapper.getWindow() != null) {windowWrapper.getWindow().setOnWindowShowListener(new OnWindowShowListener() { @Override public void onShow() { windowWrapper.setShowing(true); }});windowWrapper.getWindow().setOnWindowDismissListener(new OnWindowDismissListener() { @Override public void onDismiss() { windowWrapper.setShowing(false); mWindows.remove(windowWrapper); showNext(activity); }}); } mWindows.add(windowWrapper); } } /** * 彈窗滿足展示條件 * * @param priority */ public synchronized void enableWindow(Activity activity, int priority, IWindow window) { WindowWrapper windowWrapper = getTargetWindow(priority); if (windowWrapper != null) { if (windowWrapper.getWindow() == null) {window.setOnWindowShowListener(new OnWindowShowListener() { @Override public void onShow() { windowWrapper.setShowing(true); }});window.setOnWindowDismissListener(new OnWindowDismissListener() { @Override public void onDismiss() { windowWrapper.setShowing(false); mWindows.remove(windowWrapper); showNext(activity); }}); } windowWrapper.setCanShow(true); windowWrapper.setWindow(window); show(activity, priority); } } /** * 移除不需要顯示彈窗 * * @param priority */ public synchronized void disableWindow(int priority) { WindowWrapper windowWrapper = getTargetWindow(priority); if (windowWrapper != null && windowWrapper.getWindow() != null) { if (mWindows != null) {mWindows.remove(windowWrapper); } } } /** * 展示彈窗 * 從優先級最高的Window開始顯示 */ public synchronized void show(Activity activity) { WindowWrapper windowWrapper = getMaxPriorityWindow(); if (windowWrapper != null && windowWrapper.isCanShow()) { IWindow window = windowWrapper.getWindow(); if (window != null) {window.show(activity); } } } /** * 顯示指定的彈窗 * * @param priorities */ public synchronized void show(Activity activity, int priorities) { WindowWrapper windowWrapper = getTargetWindow(priorities); if (windowWrapper != null && windowWrapper.getWindow() != null) { WindowWrapper topShowWindow = getShowingWindow(); if (topShowWindow == null) {int priority = windowWrapper.getPriority();WindowWrapper maxPriorityWindow = getMaxPriorityWindow();if (maxPriorityWindow != null && windowWrapper.isCanShow() && priority >= maxPriorityWindow.getPriority()) { if (windowWrapper.getWindow() != null) { windowWrapper.getWindow().show(activity); }} } } } /** * 清除彈窗管理者 */ public synchronized void clear() { if (mWindows != null) { for (int i = 0, size = mWindows.size(); i < size; i++) {if (mWindows.get(i) != null) { IWindow window = mWindows.get(i).getWindow(); if (window != null) { window.dismiss(); }} } mWindows.clear(); } WindowHelper.getInstance().onDestroy(); } /** * 清除彈窗管理者 * * @param dismiss 是否同時dismiss掉彈窗管理者維護的彈窗 */ public synchronized void clear(boolean dismiss) { if (mWindows != null) { if (dismiss) {for (int i = 0, size = mWindows.size(); i < size; i++) { if (mWindows.get(i) != null) { IWindow window = mWindows.get(i).getWindow(); if (window != null) { window.dismiss(); } }} } mWindows.clear(); } WindowHelper.getInstance().onDestroy(); } /** * 展示下一個優先級最大的Window */ private synchronized void showNext(Activity activity) { WindowWrapper windowWrapper = getMaxPriorityWindow(); if (windowWrapper != null && windowWrapper.isCanShow()) { if (windowWrapper.getWindow() != null) {windowWrapper.getWindow().show(activity); } } } /** * 獲取當前棧中優先級最高的Window(優先級相同則返回后添加的彈窗) */ private synchronized WindowWrapper getMaxPriorityWindow() { if (mWindows != null) { int maxPriority = -1; int position = -1; for (int i = 0, size = mWindows.size(); i < size; i++) {WindowWrapper windowWrapper = mWindows.get(i);if (i == 0) { position = 0; maxPriority = windowWrapper.getPriority();} else { if (windowWrapper.getPriority() >= maxPriority) { position = i; maxPriority = windowWrapper.getPriority(); }} } if (position != -1) {return mWindows.get(position); } else {return null; } } return null; } private synchronized WindowWrapper getTargetWindow(int priority) { if (mWindows != null) { for (int i = 0, size = mWindows.size(); i < size; i++) {WindowWrapper windowWrapper = mWindows.get(i);if (windowWrapper != null && windowWrapper.getPriority() == priority) { return windowWrapper;} } } return null; } /** * 獲取當前處于show狀態的彈窗 */ private synchronized WindowWrapper getShowingWindow() { if (mWindows != null) { for (int i = 0, size = mWindows.size(); i < size; i++) {WindowWrapper windowWrapper = mWindows.get(i);if (windowWrapper != null && windowWrapper.getWindow() != null && windowWrapper.isShowing()) { return windowWrapper;} } } return null; }}

WindowTaskManager類有三個主要方法:

addWindow(Activity activity, WindowWrapper windowWrapper) enableWindow(Activity activity, int priority, IWindow window) disableWindow(int priority)

需要按順序顯示的對話框統一使用addWindow方法添加,這是還未進行網絡請求之前就要調用的。作用是告訴WindowTaskManager一共有多少個彈窗需要按順序顯示。當網絡請求返回之后,如果需要顯示彈窗就調用enableWindow方法去顯示,如果不需要顯示彈窗就調用disableWindow方法,將這個彈窗從顯示隊列中移除。

以上就是按順序顯示彈窗的主要邏輯,使用的話窗體先繼承IWindow,實現相關方法。然后通過操作WindowTaskManager類就可以了。具體使用方法參見源碼。

項目地址:github.com/Geekince/Pr…

彩蛋:

需要在DialogFragment中顯示DialogFragment時候,最好不要直接在DialogFragment啟動顯示,而是在DialogFragment的消失回調中啟動顯示。因為當前一個DialogFragment消失的時候,getChildFragmentManager可能會失效,應該在外層使用getFragmentManager。

以上就是Android 如何實現彈窗順序&優先級控制的詳細內容,更多關于Android 實現彈窗順序和優先級控制的資料請關注好吧啦網其它相關文章!

標簽: Android
相關文章:
主站蜘蛛池模板: 九九视频精品在线 | 国产黄色网 | 特级毛片永久久免费观看 | 欧美日一级 | 日本视频在线免费播放 | 久久国产成人午夜aⅴ影院 久久国产成人亚洲精品影院老金 | 日韩高清一级 | 国产日韩精品一区在线不卡 | 国产成人深夜福利短视频99 | 久久99精品久久久久久三级 | 国产精品久久久久久久久久久搜索 | 成人在免费观看视频国产 | 精品国产成人综合久久小说 | 精品国产_亚洲人成在线高清 | 免费又黄又爽又猛大片午夜 | a级国产 | 久草网在线 | 日韩欧美毛片免费观看视频 | 玖玖精品在线视频 | 免费a级毛片网站 | 亚洲一区二区免费看 | 日日操夜夜爽 | 亚洲日韩aⅴ在线视频 | 一区二区三区四区视频在线 | 国产va精品网站精品网站精品 | 国产视频亚洲 | 一区二区影视 | 亚洲欧美综合网 | 99久久综合精品国产 | 欧美日韩综合精品一区二区三区 | 国产在视频线精品视频二代 | 91久久香蕉国产线看观看软件 | 最新三级网址 | 99热官网 | 欧美美女网站 | 欧美成性色 | 国产精品亚洲二区 | 国产一区二区三区成人久久片 | 美女131爽爽爽做爰中文视频 | 亚洲视频在线观看地址 | 欧美成人3d动漫专区 |