Android 仅在三星设备中存在接近传感器问题
Android proximity sensor issue only in Samsung devices
具体场景避免问题:
三星设备中 Activity 的行为有所不同,每次检测到变化时,对于接近度,都会导致仅在三星设备上调用 onPause()/onResume()
。
我正在清除 onPause()
中的接近传感器,这导致了三星设备独有的行为。
希望这可以为遇到此问题的任何人节省一些时间。我从 onPause()
中删除了清除邻近侦听器的调用,现在它在上述设备上按预期工作。
更新:
下面提到的不是唯一的问题,接近传感器并不总是以这种方式运行。另一个问题是 l-o-c:
if (!mWakeLock.isHeld()) mWakeLock.acquire();
随机地,上述设备的 if()
returns false 因此 mWakeLock.acquire()
并不总是被调用。
可能相关的信息:
mWakeLock = mPowerManager.newWakeLock(field, getLocalClassName());
其中
field = PowerManager.PROXIMITY_SCREEN_OFF_WAKE_LOCK or 32
我的接近传感器代码仅在
上不正确
1. 三星 GT-I9082 Android 4.2.2 (API 17) [二重奏]
2. 三星 SM-G925I Android 5.1.1 (API 22) [s6 edge]
代码:
sensorManager = (SensorManager) getSystemService(SENSOR_SERVICE);
sensor = sensorManager.getDefaultSensor(Sensor.TYPE_PROXIMITY);
...new SensorEventListener() {
@Override
public void onSensorChanged(SensorEvent event) {
if (event.sensor.getType() == Sensor.TYPE_PROXIMITY) {
if (event.values[0] <= 5) { //Sleep
turnOffScreen();
} else { //Wake
turnOnScreen();
}...
// registering listener with SensorManager.SENSOR_DELAY_NORMAL);
问题:
两个设备上接近传感器返回的记录值 波动 ,即使我们将手不断放在手机上几秒钟也是如此; 10-15不动。
喜欢:
三星 6 edge-
02-10 20:12:36.532: D/SensorManager(3467): Proximity, val = 8.0 [far]
02-10 20:12:36.532: D/SensorManager(29335): Proximity, val = 8.0 [far]
02-10 20:12:36.532: D/DisplayPowerController(3467): [sensor] setProximitySensorEnabled::unregisterListener
02-10 20:12:36.532: D/PowerManagerService(3467): [s] DisplayPowerCallbacks : onProximityNegative()
02-10 20:12:36.562: I/Sensors(3467): Proximity old sensor_state 33554560, new sensor_state : 33554432 en : 0
02-10 20:12:36.632: I/Sensors(3467): Proximity old sensor_state 33554944, new sensor_state : 33555072 en : 1
02-10 20:12:36.642: D/SensorManager(29335): registerListener :: 5, TMD4903 Proximity Sensor, 200000, 0,
02-10 20:12:36.652: D/SensorManager(29335): Proximity, val = 8.0 [far]
02-10 20:12:36.662: I/Sensors(3467): ProximitySensor - 8(cm)
02-10 20:12:36.672: D/SensorManager(29335): Proximity, val = 8.0 [far]
02-10 20:12:41.752: I/Sensors(3467): Proximity old sensor_state 33554560, new sensor_state : 33554432 en : 0
02-10 20:12:41.822: I/Sensors(3467): Proximity old sensor_state 33554432, new sensor_state : 33554560 en : 1
02-10 20:12:41.842: D/SensorManager(29335): registerListener :: 5, TMD4903 Proximity Sensor, 200000, 0,
02-10 20:12:41.842: D/SensorManager(29335): Proximity, val = 8.0 [far]
02-10 20:12:41.872: I/Sensors(3467): ProximitySensor - 8(cm)
02-10 20:12:41.872: D/SensorManager(29335): Proximity, val = 8.0 [far]
02-10 20:12:50.482: I/Sensors(3467): ProximitySensor - 0(cm)
02-10 20:12:50.482: D/SensorManager(29335): Proximity, val = 0.0 [close]
02-10 20:12:50.482: D/DisplayPowerController(3467): [sensor] setProximitySensorEnabled::registerListener
02-10 20:12:50.482: D/SensorManager(3467): registerListener :: 5, TMD4903 Proximity Sensor, 200000, 0,
02-10 20:12:50.482: D/SensorManager(3467): Proximity, val = 0.0 [close]
02-10 20:12:50.482: D/PowerManagerService(3467): [s] DisplayPowerCallbacks : onProximityPositive()
02-10 20:12:50.482: D/PowerManagerService(3467): [s] DisplayPowerCallbacks : onProximityPositive()
Samsung Duos:波动值在 0.0 和 5.0 上与上面的 8.0 不同
还有哪些方法或排列组合可以成功准确地解决这个问题?
是不是因为传感器不同; GP2A 接近传感器和 APDS-9930/QPDS-T930 接近和光线 ?
已经花了很多时间..徒劳无功
事实证明这是三星设备的一个已注册问题,这里是一组页面,可以帮助遇到此问题的任何人:
使用onWindowFocusChanged。这对我来说很有意义,并且我的与 onPause() 相关的实现在遵循相同的情况下是成功的。
来源和解释:activity-onpause-to-handle-focus
是什么帮助了我:而不是 onPause()
;
@Override
public void onWindowFocusChanged(boolean hasFocus) {
super.onWindowFocusChanged(有焦点);
如果(!有焦点){
clearProximityListeners();
}
}
更多参考:
从完全不同的方面来看,注销时存在 Bug...Otto bus.. 引用:For us, this only appears on Samsung devices. And after a quick search,...
如果答案更清晰,请编辑、更正、改进答案。希望能节省一些时间。
具体场景避免问题:
三星设备中 Activity 的行为有所不同,每次检测到变化时,对于接近度,都会导致仅在三星设备上调用 onPause()/onResume()
。
我正在清除 onPause()
中的接近传感器,这导致了三星设备独有的行为。
希望这可以为遇到此问题的任何人节省一些时间。我从 onPause()
中删除了清除邻近侦听器的调用,现在它在上述设备上按预期工作。
更新:
下面提到的不是唯一的问题,接近传感器并不总是以这种方式运行。另一个问题是 l-o-c:
if (!mWakeLock.isHeld()) mWakeLock.acquire();
随机地,上述设备的 if()
returns false 因此 mWakeLock.acquire()
并不总是被调用。
可能相关的信息:
mWakeLock = mPowerManager.newWakeLock(field, getLocalClassName());
其中
field = PowerManager.PROXIMITY_SCREEN_OFF_WAKE_LOCK or 32
我的接近传感器代码仅在
上不正确
1. 三星 GT-I9082 Android 4.2.2 (API 17) [二重奏]
2. 三星 SM-G925I Android 5.1.1 (API 22) [s6 edge]
代码:
sensorManager = (SensorManager) getSystemService(SENSOR_SERVICE);
sensor = sensorManager.getDefaultSensor(Sensor.TYPE_PROXIMITY);
...new SensorEventListener() {
@Override
public void onSensorChanged(SensorEvent event) {
if (event.sensor.getType() == Sensor.TYPE_PROXIMITY) {
if (event.values[0] <= 5) { //Sleep
turnOffScreen();
} else { //Wake
turnOnScreen();
}...
// registering listener with SensorManager.SENSOR_DELAY_NORMAL);
问题:
两个设备上接近传感器返回的记录值 波动 ,即使我们将手不断放在手机上几秒钟也是如此; 10-15不动。
喜欢:
三星 6 edge-
02-10 20:12:36.532: D/SensorManager(3467): Proximity, val = 8.0 [far]
02-10 20:12:36.532: D/SensorManager(29335): Proximity, val = 8.0 [far]
02-10 20:12:36.532: D/DisplayPowerController(3467): [sensor] setProximitySensorEnabled::unregisterListener
02-10 20:12:36.532: D/PowerManagerService(3467): [s] DisplayPowerCallbacks : onProximityNegative()
02-10 20:12:36.562: I/Sensors(3467): Proximity old sensor_state 33554560, new sensor_state : 33554432 en : 0
02-10 20:12:36.632: I/Sensors(3467): Proximity old sensor_state 33554944, new sensor_state : 33555072 en : 1
02-10 20:12:36.642: D/SensorManager(29335): registerListener :: 5, TMD4903 Proximity Sensor, 200000, 0,
02-10 20:12:36.652: D/SensorManager(29335): Proximity, val = 8.0 [far]
02-10 20:12:36.662: I/Sensors(3467): ProximitySensor - 8(cm)
02-10 20:12:36.672: D/SensorManager(29335): Proximity, val = 8.0 [far]
02-10 20:12:41.752: I/Sensors(3467): Proximity old sensor_state 33554560, new sensor_state : 33554432 en : 0
02-10 20:12:41.822: I/Sensors(3467): Proximity old sensor_state 33554432, new sensor_state : 33554560 en : 1
02-10 20:12:41.842: D/SensorManager(29335): registerListener :: 5, TMD4903 Proximity Sensor, 200000, 0,
02-10 20:12:41.842: D/SensorManager(29335): Proximity, val = 8.0 [far]
02-10 20:12:41.872: I/Sensors(3467): ProximitySensor - 8(cm)
02-10 20:12:41.872: D/SensorManager(29335): Proximity, val = 8.0 [far]
02-10 20:12:50.482: I/Sensors(3467): ProximitySensor - 0(cm)
02-10 20:12:50.482: D/SensorManager(29335): Proximity, val = 0.0 [close]
02-10 20:12:50.482: D/DisplayPowerController(3467): [sensor] setProximitySensorEnabled::registerListener
02-10 20:12:50.482: D/SensorManager(3467): registerListener :: 5, TMD4903 Proximity Sensor, 200000, 0,
02-10 20:12:50.482: D/SensorManager(3467): Proximity, val = 0.0 [close]
02-10 20:12:50.482: D/PowerManagerService(3467): [s] DisplayPowerCallbacks : onProximityPositive()
02-10 20:12:50.482: D/PowerManagerService(3467): [s] DisplayPowerCallbacks : onProximityPositive()
Samsung Duos:波动值在 0.0 和 5.0 上与上面的 8.0 不同
还有哪些方法或排列组合可以成功准确地解决这个问题?
是不是因为传感器不同; GP2A 接近传感器和 APDS-9930/QPDS-T930 接近和光线 ?
已经花了很多时间..徒劳无功
事实证明这是三星设备的一个已注册问题,这里是一组页面,可以帮助遇到此问题的任何人:
使用onWindowFocusChanged。这对我来说很有意义,并且我的与 onPause() 相关的实现在遵循相同的情况下是成功的。
来源和解释:activity-onpause-to-handle-focus
是什么帮助了我:而不是onPause()
;@Override public void onWindowFocusChanged(boolean hasFocus) { super.onWindowFocusChanged(有焦点); 如果(!有焦点){ clearProximityListeners(); } }
更多参考:
从完全不同的方面来看,注销时存在 Bug...Otto bus.. 引用:For us, this only appears on Samsung devices. And after a quick search,...
如果答案更清晰,请编辑、更正、改进答案。希望能节省一些时间。