Device收到通知时,通知指示灯不闪烁的问题

Issue:

"
Reproduction Steps:

  1. Flash the latest product build and boot to system
  2. Send a skype call from DUT2 to DUT1, check DUT1 LED
  3. Wait for the alarm to ring on both UUTs and dismiss after alarm rings, check DUTs LED
  4. Add one event in calendar and wait it trigger out of downtime, check DUTs LED
  5. Send a test mail to DUT1 from DUT2, check DUT2 LED
  6. Start transferring files via Bluetooth, check DUTs LED
  7. Receive an unread message, check DUTs LED
  8. Notification LED doesn't work ==>Problem

"

Solution:

"Solution: Modify the default parameters so that the LED can blink."

1.overlay里新增字段:

device/zebra/common/overlay_gms/frameworks/base/core/res/res/values/config.xml

device/zebra/common/overlay/frameworks/base/core/res/res/values/config.xml

diff 复制代码
diff --git a/overlay/frameworks/base/core/res/res/values/config.xml b/overlay/frameworks/base/core/res/res/values/config.xml
index 4a5f02d..6562f8e 100644
--- a/overlay/frameworks/base/core/res/res/values/config.xml
+++ b/overlay/frameworks/base/core/res/res/values/config.xml
@@ -228,5 +228,6 @@
         <item>screenshot</item>
         <item>bugreport</item>
     </string-array>
-
+    <!--BSPA-193784 enable notification led-->
+    <bool name="config_intrusiveNotificationLed">true</bool>
 </resources>
diff --git a/overlay_gms/frameworks/base/core/res/res/values/config.xml b/overlay_gms/frameworks/base/core/res/res/values/config.xml
index 200c934..1ddf702 100644
--- a/overlay_gms/frameworks/base/core/res/res/values/config.xml
+++ b/overlay_gms/frameworks/base/core/res/res/values/config.xml
@@ -243,5 +243,6 @@
         <item>screenshot</item>
         <item>bugreport</item>
     </string-array>
-
+    <!--BSPA-193784 enable notification led-->
+    <bool name="config_intrusiveNotificationLed">true</bool>
 </resources>

2.frameworks/base/services/core/java/com/android/server/notification/NotificationManagerService.java

diff 复制代码
diff --git a/services/core/java/com/android/server/notification/NotificationManagerService.java b/services/core/java/com/android/server/notification/NotificationManagerService.java
index 93528d4..4028c2a 100644
--- a/services/core/java/com/android/server/notification/NotificationManagerService.java
+++ b/services/core/java/com/android/server/notification/NotificationManagerService.java
@@ -1,6 +1,6 @@
 /*
  * Copyright (C) 2007 The Android Open Source Project
- * Copyright (C) 2021 XXX Technologies Corporation and/or its affiliates.All rights reserved.
+ * Copyright (C) 2021-2022 XXX Technologies Corporation and/or its affiliates. All rights reserved
  *
  * Licensed under the Apache License, Version 2.0 (the "License");
  * you may not use this file except in compliance with the License.
@@ -1576,7 +1576,8 @@
                     cancelAllNotificationsInt(MY_UID, MY_PID, null, null, 0, 0, true, userHandle,
                             REASON_PROFILE_TURNED_OFF, null);
                 }
-            } else if (action.equals(Intent.ACTION_USER_PRESENT)) {
+                //BSPA-193784 not to turn off LED when user passes through lock screen
+            } else if (action.equals(Intent.ACTION_USER_PRESENT) && (!XXXUtils.isXXX().orElse(false))) {
                 // turn off LED when user passes through lock screen
                 if (mNotificationLight != null) {
                     mNotificationLight.turnOff();
@@ -7105,14 +7106,20 @@
         // Suppressed because it's a silent update
         final Notification notification = record.getNotification();
         if (record.isUpdate && (notification.flags & FLAG_ONLY_ALERT_ONCE) != 0) {
-            return false;
+            //BSPA-193784 not feedback 'false' if it is zebra's porject.
+            return XXXUtils.isXXX().orElse(false);
         }
         // Suppressed because another notification in its group handles alerting
         if (record.getSbn().isGroup() && record.getNotification().suppressAlertingDueToGrouping()) {
             return false;
         }
         // not if in call or the screen's on
-        if (isInCall() || mScreenOn) {
+        //BSPA-193784 The light can be on when the screen is on[XXX projcet].
+        if (XXXUtils.isXXX().orElse(false)) {
+            if (isInCall()) {
+                return true;
+            }
+        } else if (isInCall() || mScreenOn) {
             return false;
         }
 
@@ -8336,8 +8343,15 @@
             }
         }
 
-        // Don't flash while we are in a call or screen is on
-        if (ledNotification == null || isInCall() || mScreenOn) {
+        // Don't flash while we are in a call
+        //BSPA-193784 The light can be on when the screen is on[xxx projcet].
+        boolean isXXXNotification = false;
+        if(ZebraUtils.isZebra().orElse(false)) {
+            isXXXNotification = (ledNotification == null || isInCall());
+        } else {
+            isXXXNotification = (ledNotification == null || isInCall() || mScreenOn);
+        }
+        if (isXXXNotification) {
             mNotificationLight.turnOff();
         } else {
             NotificationRecord.Light light = ledNotification.getLight();
@@ -8345,6 +8359,9 @@
                 // pulse repeatedly
                 mNotificationLight.setFlashing(light.color, LogicalLight.LIGHT_FLASH_TIMED,
                         light.onMs, light.offMs);
+            } else if (XXXUtils.isZebra().orElse(false) && light != null && !mNotificationPulseEnabled){
+                mNotificationLight.turnOff();
+                Log.d(TAG, "mNotificationLight.turnOff if Blink light is turned off : ");
             }
         }
     }
相关推荐
kumalab16 分钟前
Android及Harmonyos实现图片进度显示效果
android·华为·harmonyos
ynxw43 分钟前
Unity AR 实现模型交互
android·unity·ar·交互
alexhilton1 小时前
MVI架构:Compose中的响应式状态管理
android·kotlin·android jetpack
宿辞1921 小时前
LINUX中MYSQL的使用
android·linux·mysql
code bean2 小时前
【C#】 C#中 nameof 和 ToString () 的用法与区别详解
android·java·c#
佛系小嘟嘟3 小时前
Android Studio Jetpack Compose毛玻璃特效按钮
android·ide·android studio
用户2018792831675 小时前
MagiskHidePropsConf 原理与实战故事
android
whysqwhw6 小时前
Egloo 项目结构分析
android
Wgllss6 小时前
大型异步下载器(二):基于kotlin+Compose+协程+Flow+Channel+ OKhttp 实现多文件异步同时分片断点续传下载
android·架构·android jetpack
yzpyzp6 小时前
KAPT 的版本如何升级,是跟随kotlin的版本吗
android·kotlin·gradle