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-04 10:46:26

    nuxt.js项目中全局捕获异常并生成错误日志全过程

     需求:客户在使用过程中页面报错时,可以生成错误记录传回服务器,以便改进。   步骤:     一.全局捕获异常,     二.发送到服务端,     三.生成错误日志。   一.全局捕获异常 如图,vue提供了errorHandle这个方法来处理全局异常,更多详细内容参见官网。

  • 2019-12-04 10:47:59

    nuxt.js项目中全局捕获异常并生成错误日志全过程

     需求:客户在使用过程中页面报错时,可以生成错误记录传回服务器,以便改进。   步骤:     一.全局捕获异常,     二.发送到服务端,     三.生成错误日志。   一.全局捕获异常 如图,vue提供了errorHandle这个方法来处理全局异常,更多详细内容参见官网。

  • 2019-12-04 10:48:18

    vue 项目资源文件 static 和 assets 不说区别直接使用?

    assets中资源会webpack构建压缩到你代码中,而static文件直接引用。 static 中长存放类包、插件等第三方的文件,assets里放属资源文件比如自己资源图片、css文件、js文件。 引入资源的方式static文件夹可以使用~/static/方式引入, assets文件夹可以使用 ~@/assets 方式引入

  • 2019-12-05 17:01:36

    Vue 结合 Axios 接口超时统一处理

    当网路慢的时候。又或者公司服务器不在内地的时候,接口数据请求不回来超时报错的情况相信大家肯定遇到过的,这里我把我公司项目请求超时的处理方法分享下,希望看过后有帮助。

  • 2019-12-05 17:13:40

    JS模板工具lodash.template的简单用法

    lodash是从underscore分支的一个项目,之前我写了一篇JS模板工具underscore.template的简单用法,lodash跟underscore很相似,这也简单介绍一下lodash的template方法。 先把underscore的文章中用过的代码贴过来,把underscore的js文件换成lodash的js,其他一字不改,然后我们试试:

  • 2019-12-06 10:47:29

    date-fns日期工具的使用方法详解

    isToday() 判断传入日期是否为今天 isYesterday() 判断传入日期是否为昨天 isTomorrow() 判断传入日期是否为 format() 日期格式化 addDays() 获得当前日期之后的日期 addHours() 获得当前时间n小时之后的时间点 addMinutes() 获得当前时间n分钟之后的时间 addMonths() 获得当前月之后n个月的月份 subDays() 获得当前时间之前n天的时间 subHours() 获得当前时间之前n小时的时间 subMinutes() 获得当前时间之前n分钟的时间 subMonths() 获得当前时间之前n个月的时间 differenceInYears() 获得两个时间相差的年份 differenceInWeeks() 获得两个时间相差的周数 differenceInDays() 获得两个时间相差的天数 differenceInHours() 获得两个时间相差的小时数 differenceInMinutes() 获得两个时间相差的分钟数