Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(71)

Side by Side Diff: device/power_save_blocker/power_save_blocker_android.cc

Issue 2371723002: Power Save Blocker: Eliminate passing ViewAndroid as WeakPtr (Closed)
Patch Set: Rebase Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « device/power_save_blocker/power_save_blocker.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "device/power_save_blocker/power_save_blocker.h" 5 #include "device/power_save_blocker/power_save_blocker.h"
6 6
7 #include "base/android/jni_android.h" 7 #include "base/android/jni_android.h"
8 #include "base/bind.h" 8 #include "base/bind.h"
9 #include "base/location.h" 9 #include "base/location.h"
10 #include "base/logging.h" 10 #include "base/logging.h"
11 #include "base/macros.h" 11 #include "base/macros.h"
12 #include "jni/PowerSaveBlocker_jni.h" 12 #include "jni/PowerSaveBlocker_jni.h"
13 #include "ui/android/view_android.h" 13 #include "ui/android/view_android.h"
14 14
15 namespace device { 15 namespace device {
16 16
17 using base::android::AttachCurrentThread; 17 using base::android::AttachCurrentThread;
18 using base::android::ScopedJavaLocalRef; 18 using base::android::ScopedJavaLocalRef;
19 19
20 class PowerSaveBlocker::Delegate 20 class PowerSaveBlocker::Delegate
21 : public base::RefCountedThreadSafe<PowerSaveBlocker::Delegate> { 21 : public base::RefCountedThreadSafe<PowerSaveBlocker::Delegate> {
22 public: 22 public:
23 Delegate(base::WeakPtr<ui::ViewAndroid> view_android, 23 Delegate(scoped_refptr<base::SequencedTaskRunner> ui_task_runner);
24 scoped_refptr<base::SequencedTaskRunner> ui_task_runner);
25 24
26 // Does the actual work to apply or remove the desired power save block. 25 // Does the actual work to apply or remove the desired power save block.
27 void ApplyBlock(); 26 void ApplyBlock(ui::ViewAndroid* view_android);
28 void RemoveBlock(); 27 void RemoveBlock();
29 28
30 private: 29 private:
31 friend class base::RefCountedThreadSafe<Delegate>; 30 friend class base::RefCountedThreadSafe<Delegate>;
32 ~Delegate(); 31 ~Delegate();
33 32
34 base::WeakPtr<ui::ViewAndroid> view_android_;
35
36 base::android::ScopedJavaGlobalRef<jobject> java_power_save_blocker_; 33 base::android::ScopedJavaGlobalRef<jobject> java_power_save_blocker_;
37 34
38 ui::ViewAndroid::ScopedAnchorView anchor_view_; 35 ui::ViewAndroid::ScopedAnchorView anchor_view_;
39 36
40 scoped_refptr<base::SequencedTaskRunner> ui_task_runner_; 37 scoped_refptr<base::SequencedTaskRunner> ui_task_runner_;
41 38
42 DISALLOW_COPY_AND_ASSIGN(Delegate); 39 DISALLOW_COPY_AND_ASSIGN(Delegate);
43 }; 40 };
44 41
45 PowerSaveBlocker::Delegate::Delegate( 42 PowerSaveBlocker::Delegate::Delegate(
46 base::WeakPtr<ui::ViewAndroid> view_android,
47 scoped_refptr<base::SequencedTaskRunner> ui_task_runner) 43 scoped_refptr<base::SequencedTaskRunner> ui_task_runner)
48 : view_android_(view_android), ui_task_runner_(ui_task_runner) { 44 : ui_task_runner_(ui_task_runner) {
49 JNIEnv* env = AttachCurrentThread(); 45 JNIEnv* env = AttachCurrentThread();
50 java_power_save_blocker_.Reset(Java_PowerSaveBlocker_create(env)); 46 java_power_save_blocker_.Reset(Java_PowerSaveBlocker_create(env));
51 } 47 }
52 48
53 PowerSaveBlocker::Delegate::~Delegate() {} 49 PowerSaveBlocker::Delegate::~Delegate() {}
54 50
55 void PowerSaveBlocker::Delegate::ApplyBlock() { 51 void PowerSaveBlocker::Delegate::ApplyBlock(ui::ViewAndroid* view_android) {
56 DCHECK(ui_task_runner_->RunsTasksOnCurrentThread()); 52 DCHECK(ui_task_runner_->RunsTasksOnCurrentThread());
57 53 DCHECK(view_android);
58 if (!view_android_)
59 return;
60 54
61 JNIEnv* env = AttachCurrentThread(); 55 JNIEnv* env = AttachCurrentThread();
62 anchor_view_ = view_android_->AcquireAnchorView(); 56 anchor_view_ = view_android->AcquireAnchorView();
63 const ScopedJavaLocalRef<jobject> popup_view = anchor_view_.view(); 57 const ScopedJavaLocalRef<jobject> popup_view = anchor_view_.view();
64 if (popup_view.is_null()) 58 if (popup_view.is_null())
65 return; 59 return;
66 view_android_->SetAnchorRect(popup_view, gfx::RectF()); 60 view_android->SetAnchorRect(popup_view, gfx::RectF());
67 ScopedJavaLocalRef<jobject> obj(java_power_save_blocker_); 61 ScopedJavaLocalRef<jobject> obj(java_power_save_blocker_);
68 Java_PowerSaveBlocker_applyBlock(env, obj, popup_view); 62 Java_PowerSaveBlocker_applyBlock(env, obj, popup_view);
69 } 63 }
70 64
71 void PowerSaveBlocker::Delegate::RemoveBlock() { 65 void PowerSaveBlocker::Delegate::RemoveBlock() {
72 DCHECK(ui_task_runner_->RunsTasksOnCurrentThread()); 66 DCHECK(ui_task_runner_->RunsTasksOnCurrentThread());
73 ScopedJavaLocalRef<jobject> obj(java_power_save_blocker_); 67 ScopedJavaLocalRef<jobject> obj(java_power_save_blocker_);
74 Java_PowerSaveBlocker_removeBlock(AttachCurrentThread(), obj); 68 Java_PowerSaveBlocker_removeBlock(AttachCurrentThread(), obj);
75 anchor_view_.Reset(); 69 anchor_view_.Reset();
76 } 70 }
77 71
78 PowerSaveBlocker::PowerSaveBlocker( 72 PowerSaveBlocker::PowerSaveBlocker(
79 PowerSaveBlockerType type, 73 PowerSaveBlockerType type,
80 Reason reason, 74 Reason reason,
81 const std::string& description, 75 const std::string& description,
82 scoped_refptr<base::SequencedTaskRunner> ui_task_runner, 76 scoped_refptr<base::SequencedTaskRunner> ui_task_runner,
83 scoped_refptr<base::SingleThreadTaskRunner> blocking_task_runner) 77 scoped_refptr<base::SingleThreadTaskRunner> blocking_task_runner)
84 : ui_task_runner_(ui_task_runner), 78 : ui_task_runner_(ui_task_runner),
85 blocking_task_runner_(blocking_task_runner) { 79 blocking_task_runner_(blocking_task_runner) {
86 // Don't support kPowerSaveBlockPreventAppSuspension 80 // Don't support kPowerSaveBlockPreventAppSuspension
87 } 81 }
88 82
89 PowerSaveBlocker::~PowerSaveBlocker() { 83 PowerSaveBlocker::~PowerSaveBlocker() {
90 if (delegate_.get()) { 84 if (delegate_.get()) {
91 ui_task_runner_->PostTask(FROM_HERE, 85 ui_task_runner_->PostTask(FROM_HERE,
92 base::Bind(&Delegate::RemoveBlock, delegate_)); 86 base::Bind(&Delegate::RemoveBlock, delegate_));
93 } 87 }
94 } 88 }
95 89
96 void PowerSaveBlocker::InitDisplaySleepBlocker( 90 void PowerSaveBlocker::InitDisplaySleepBlocker(ui::ViewAndroid* view_android) {
97 const base::WeakPtr<ui::ViewAndroid>& view_android) {
98 DCHECK(ui_task_runner_->RunsTasksOnCurrentThread()); 91 DCHECK(ui_task_runner_->RunsTasksOnCurrentThread());
99 if (!view_android) 92 DCHECK(view_android);
100 return;
101 93
102 delegate_ = new Delegate(view_android, ui_task_runner_); 94 delegate_ = new Delegate(ui_task_runner_);
103 delegate_->ApplyBlock(); 95 delegate_->ApplyBlock(view_android);
104 } 96 }
105 97
106 } // namespace device 98 } // namespace device
OLDNEW
« no previous file with comments | « device/power_save_blocker/power_save_blocker.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698