• SystemUI控制状态栏通知面板自动展开和收起


    前言

    在项目开发中,出现了这样的需求,需要语言控制状态栏的通知面板展开和收起,同时手动滑出通知面板时需要在一段时间后自动收起面板。针对需求需要对SystemUI源码进行修改处理。

    控制通知面板定时自动收起

    1.NotificationPanelView处理

    目录如下:

    com.android.systemui.statusbar.phone.NotificationPanelView

    首先需要在NotificationPanelView中增加监听接口:

        private OnPanelChangedListener mOnPanelChangedListener;
    
        public void setOnPanelChangedListener(OnPanelChangedListener listener) {
            mOnPanelChangedListener = listener;
        }
    
        public interface OnPanelChangedListener {
            void onPanelCollapsed();
            void onPanelOpened();
            void onPanelTouch(int action);
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    接着在面板展开onExpandingFinishedonClosingFinished时回调展开和收起的状态。

        @Override
        protected void onExpandingFinished() {
            super.onExpandingFinished();
            ...此处代码省略
            if (mOnPanelChangedListener != null) {
                mOnPanelChangedListener.onPanelOpened();
            }
        }
        
        @Override
        protected void onClosingFinished() {
            super.onClosingFinished();
            resetVerticalPanelPosition();
            setClosingWithAlphaFadeout(false);
            if (mOnPanelChangedListener != null) {
                mOnPanelChangedListener.onPanelCollapsed();
            }
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    面板触摸时不能自动收起,需要重写dispatchTouchEvent方法并回调监听:

        @Override
        public boolean dispatchTouchEvent(MotionEvent ev) {
            if (mOnPanelChangedListener != null) {
                mOnPanelChangedListener.onPanelTouch(ev.getAction());
            }
            return super.dispatchTouchEvent(ev);
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    2.StatusBar处理

    目录如下:

    com.android.systemui.statusbar.phone.StatusBar

    makeStatusBarView()方法mNotificationPanel初始化时设置监听:
    在这里插入图片描述

    mNotificationPanel.setOnPanelChangedListener(new NotificationPanelView.OnPanelChangedListener() {
                @Override
                public void onPanelCollapsed() {
                    mHandler.removeMessages(MSG_CLOSE_PANELS);
                }
    
                @Override
                public void onPanelOpened() {
                    mHandler.removeMessages(MSG_CLOSE_PANELS);
                    mHandler.sendEmptyMessageDelayd(MSG_CLOSE_PANELS, AUTO_COLLAPSED_TIME);
    
                }
    
                @Override
                public void onPanelTouch(int action) {
                    if (action == MotionEvent.ACTION_DOWN) {
                        mHandler.removeMessages(MSG_CLOSE_PANELS);
                    } else if (action == MotionEvent.ACTION_CANCEL || action == MotionEvent.ACTION_UP) {
                        mHandler.sendEmptyMessageDelayd(MSG_CLOSE_PANELS, AUTO_COLLAPSED_TIME);
                    }
                }
            });
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    原理为对通知面板收起消息MSG_CLOSE_PANELS的处理。

    控制通知面板展开和收起

    StatusBar中,可通过调用已有的togglePanel()方法控制通知面板的展开和收起,当前展开则收起,当前收起则展开。
    在这里插入图片描述
    以上不满足需求,则可增加下面方法控制展开和收起:

        public void togglePanel(boolean expanded) {
            if (expanded) {
                animateExpandNotificationsPanel();
            } else {
                animateCollapsePanels();
            }
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    增加一个状态控制保证准确控制展开或者准确收起。
    此场景可应用于语音控制通知面板展开/收起,或者其他应用交互控制展开/收起。

    结语

    以上为原生SystemUI源码的修改,具体与其他应用的通信/交互逻辑按需实现。

  • 相关阅读:
    ATFX汇市:欧央行利率决议来袭,能够逆转欧元跌势吗?
    数据结构之Trie树
    NR 物理层编码 S1 -概述
    A-LEVEL Chemistry考点分析
    React有slot吗?
    数据结构与算法01-算法的评估(大O表示法) 算法的优化方向
    【LeetCode】2656. K个元素的最大和
    华为三层交换机:ACL的基本实验
    SpringMVC(八):SSM整合
    ocr的场景应用--发票识别
  • 原文地址:https://blog.csdn.net/CJohn1994/article/details/126495954