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 ヾ(◍°∇°◍)ノ゙


  • 2020-11-17 17:08:28

    用js编写WebAssembly ,WebAssembly 现状与实战

    自从 JavaScript 诞生起到现在已经变成最流行的编程语言,这背后正是 Web 的发展所推动的。Web 应用变得更多更复杂,但这也渐渐暴露出了 JavaScript 的问题:

  • 2020-11-17 17:28:06

    AssemblyScript 开发WebAssembly 教程

    WebAssembly 以及通过 AssemblyScript 的扩展,不会使每个网站都神奇地变得更快,但是这并不重要。 WebAssembly 之所以令人兴奋,是因为它可以使更多的应用在 Web 变得中可行。

  • 2020-11-17 21:15:48

    如何保障 API 接口的安全性?前端如何加密

    一、1. HTTP 请求中的来源识别 二、2. 数据加密 三、3. 数据签名 四、4. 时间戳 五、5. AppID 六、6. 参数整体加密 七、7. 限流 八、8. 黑名单 九、1. 压缩 十、2. 混淆 undefined、3. 加密

  • 2020-11-18 14:34:00

    当你写爬虫抓不到APP请求包的时候该怎么办?

    提示:因为高级篇以后的APP将无法使用很通用的方式处理,每种类型甚至是每个APP的反抓包处理方式都会有差别,所以这个系列以后会以【高级篇-具体类型】的形式来写。

  • 2020-11-21 20:41:51

    Kotlin Sealed class类详解

    Sealed class(密封类) 是一个有特定数量子类的类,看上去和枚举有点类似,所不同的是,在枚举中,我们每个类型只有一个对象(实例);而在密封类中,同一个类可以拥有几个对象。

  • 2020-11-22 20:53:43

    Dagger2之Kotlin写法

    修饰构造方法 修饰变量,在宿主类里,引入要注入的实例

  • 2020-11-22 20:56:13

    Dagger2使用详解

    简单的说,就是一个工厂模式,由Dagger负责创建工厂,帮忙生产instance。遵从Java规范JSR 330,可以使用这些注解。现在不研究Dagger2是如何根据注解去生成工厂的,先来看看工厂是什么东西,理解为什么可以实现了DI(Dependency Injection),如何创建IoC(Inverse of Control)容器。

  • 2020-11-22 21:00:28

    dagger.android--Fragment,BaseFragment

    1 使用Fragment参数来代替Activity参数 2 使用 @FragmentKey来代替@ActivityKey 3 使用HasFragmentInjector来代替@HasActivityInjector 4 AndroidInjection.inject(Fragment)方法,在Fragment的onAttach()中调用,而不是在onCreate()中 5 Fragment的Module添加位置,和Activity是不同的,它取决于Fragment需要的其他依赖注入

  • 2020-11-22 21:12:30

    Dependency Injection with Dagger2,Fragment

    標註@Provides的method若有parameter的話,Dagger會找出其擁有的該型態物件來使用。我們在Module內新增了DataModel將其列入Dagger的管理下,接著在provideFactory()增加parameter變成provideFactory(DataModel dataModel),Dagger就會找出其管理的DataModel給provideFactory使用。