Android 全局Dialog的简单实现

2019-06-04 21:32:05

参考地址 Android 全局Dialog的简单实现

▲ 前言:


这里所说的全局Dialog是指无论当前应用是处于哪一个页面上,都能够及时弹出Dialog来提示用户一些信息,用户体验不会很好,一般应用于优先级非常高的通知。


▲ 分析 :


想要实现无论当前应用是处于哪一个页面上,都能够及时弹出Dialog功能其实很简单,只要能获取到当前显示的Activity就行了,也就是栈顶的Activity。


▲ 实现过程 : 

一般项目中我们都会通过一个类来管理我们的Activity,即AppManager


/**

 * Activity管理类

 * @author Donkor

 */

public class AppManager {

    private static Stack<Activity> activityStack;

    private static AppManager instance;


    private AppManager(){}

    /**

     * 单一实例

     */

    public static AppManager getAppManager(){

        if(instance==null){

            instance=new AppManager();

        }

        return instance;

    }

    /**

     * 添加Activity到堆栈

     */

    public void addActivity(Activity activity){

        if(activityStack==null){

            activityStack=new Stack<Activity>();

        }

        activityStack.add(activity);

    }

    /**

     * 获取当前Activity(堆栈中最后一个压入的)

     */

    public Activity currentActivity(){

        Activity activity=activityStack.lastElement();

        return activity;

    }

    /**

     * 结束当前Activity(堆栈中最后一个压入的)

     */

    public void finishActivity(){

        Activity activity=activityStack.lastElement();

        if(activity!=null){

            activity.finish();

            activity=null;

        }

    }

    /**

     * 结束指定的Activity

     */

    public void finishActivity(Activity activity){

        if(activity!=null){

            activityStack.remove(activity);

            activity.finish();

            activity=null;

        }

    }

    /**

     * 结束指定类名的Activity

     */

    public void finishActivity(Class<?> cls){

        for (Activity activity : activityStack) {

            if(activity.getClass().equals(cls) ){

                finishActivity(activity);

            }

        }

    }

    /**

     * 结束所有Activity

     */

    public void finishAllActivity(){

        for (int i = 0, size = activityStack.size(); i < size; i++){

            if (null != activityStack.get(i)){

                activityStack.get(i).finish();

            }

        }

        activityStack.clear();

    }

    /**

     * 退出应用程序

     */

    public void AppExit(Context context) {

        try {

            finishAllActivity();

            ActivityManager activityMgr= (ActivityManager) context.getSystemService(Context.ACTIVITY_SERVICE);

            activityMgr.restartPackage(context.getPackageName());

            System.exit(0);

        } catch (Exception e) { 

            e.printStackTrace();

        }

    }

}

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

再封装一个BaseActivity类统一管理,给各个Activity继承


/**

 * Activity基类

 * @author Donkor

 */

public abstract class BaseActivity extends AppCompatActivity {


    @Override

    protected void onCreate(@Nullable Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        //将Activity实例添加到AppManager的堆栈

        AppManager.getAppManager().addActivity(this);

    }



    @Override

    protected void onDestroy() {

        super.onDestroy();

        //将Activity实例从AppManager的堆栈中移除

        AppManager.getAppManager().finishActivity(this);

    }


}

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

最后需要MainActivity(主页面、主类)或者Service中处理Dialog的显示问题,通过AppManager获取到当前栈顶的Activity,用于构造Dialog就行了。


Dialog myDialog = new Dialog(AppManager.getAppManager().currentActivity(), R.style.dialog_style);

1

Done ヾ(◍°∇°◍)ノ゙


  • 2019-12-09 15:36:56

    神秘的 shadow-dom 浅析,shadow-root

    顾名思义, shadow-dom,直译的话就是 影子dom ?我觉得可以理解为潜藏在黑暗中的 DOM 结构,也就是我们无法直接控制操纵的 DOM 结构。前端同学经常用开发者工具的话,查看 DOM 结构的时候,肯定看到过下面这样的结构:

  • 2019-12-10 11:13:50

    前端实战-基于Nuxt的SVG使用

    虽然我们在日常开发的时候,在使用iview 或者element ui等组件时,通常会包含一些常用icon;但是在面对一些特定的需求时,或者自己想high一下,这些通用的icon并不能很好的满足我们。这个时候我们可能会拿到一些SVG适量图,但是怎么去使用这些矢量图呢。

  • 2019-12-10 11:15:08

    用CSS给SVG 的内容添加样式

    SVG图形的一个最常见用例是图标系统,其中最常用的SVG sprite技术就是使用SVG<use> 元素在文档中任意位置“实例化”图标。 使用<use>元素实例化图标或任何其它的SVG元素或图像,给元素添加样式时经常会碰到一些问题。这篇文章的目的是尽可能给你介绍一些方法来解决:使用<use>引入的内容添加样式受限的问题。 但是在开始之前,我们先快速浏览一下SVG的主要结构和分组元素,然后慢慢进入use的世界中,以及shadow DOM,然后重回CSS的怀抱。我们会逐步讲解为什么给<use>内容添加样式会比较麻烦,以及有什么好的解决方案。

  • 2019-12-10 16:21:05

    display:flex的子元素无法设置宽度

    子元素有个flex-shrink属性,表示在父元素宽度不够的情况下是自动收缩不?0表示不自动收缩,1表示自动收缩;所以将子元素(图片)添加属性:flex-shrink:0;即

  • 2019-12-10 21:14:11

    axios文件上传功能+formData

    在项目中使用axios上传文件,记得new一个纯净的axios或者考虑用ajax请求。因为axios在项目估计已经用了全局配置请求头等信息,这里的配置可能被全局请求头拦截,导致请求失败。 2.1构造formData 作者:exmexm 链接:https://www.jianshu.com/p/9c708a47d8a5 来源:简书 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 2019-12-11 16:04:15

    CSS中的 “var()” 和 “:root”

    var() var()函数可以代替元素中任何属性中的值的任何部分。var()函数不能作为属性名、选择器或者其他除了属性值之外的值。(这样做通常会产生无效的语法或者一个没有关联到变量的值。)