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
|
/*
* Copyright (C) 2017 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License
*/
package com.android.dialer.precall.impl;
import android.app.Activity;
import android.app.KeyguardManager;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.view.WindowManager.LayoutParams;
/** A transparent activity to host dialogs for {@link PreCallCoordinatorImpl} */
public class PreCallActivity extends Activity {
private PreCallCoordinatorImpl preCallCoordinator;
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
preCallCoordinator = new PreCallCoordinatorImpl(this);
preCallCoordinator.onCreate(getIntent(), savedInstanceState);
if (getSystemService(KeyguardManager.class).isKeyguardLocked()) {
// Note:
//
// Flag LayoutParams.FLAG_TURN_SCREEN_ON was deprecated in O_MR1, but calling the new API
// setTurnScreenOn(true) doesn't give us the expected behavior.
//
// Calling setTurnScreenOn(true) alone doesn't turn on the screen when the device is locked.
// We must also call KeyguardManager#requestDismissKeyguard, which will bring up the lock
// screen for the user to enter their credentials.
//
// If the Keyguard is not secure or the device is currently in a trusted state, calling
// requestDismissKeyguard will immediately dismiss the Keyguard without any user interaction.
// However, the lock screen will still pop up before it quickly disappears.
//
// If the Keyguard is secure and the device is not in a trusted state, the device will show
// the lock screen and wait for the user's credentials.
//
// Therefore, to avoid showing the lock screen, we will continue using the deprecated flag in
// O_MR1 and later Android versions.
//
// Flag LayoutParams.FLAG_SHOW_WHEN_LOCKED was also deprecated in O_MR1, and the new API
// setShowWhenLocked(boolean) works. However, as the purpose of the two new APIs is to prevent
// an unintentional double life-cycle event, only using one is ineffective.
//
// Therefore, to simplify code and make testing easier, we will also keep using
// LayoutParams.FLAG_SHOW_WHEN_LOCKED.
getWindow().addFlags(LayoutParams.FLAG_SHOW_WHEN_LOCKED | LayoutParams.FLAG_TURN_SCREEN_ON);
}
}
@Override
protected void onRestoreInstanceState(Bundle savedInstanceState) {
super.onRestoreInstanceState(savedInstanceState);
preCallCoordinator.onRestoreInstanceState(savedInstanceState);
}
@Override
public void onResume() {
super.onResume();
preCallCoordinator.onResume();
}
@Override
public void onPause() {
super.onPause();
preCallCoordinator.onPause();
}
@Override
public void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
preCallCoordinator.onSaveInstanceState(outState);
}
}
|