OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "athena/activity/public/activity_view_manager.h" | 5 #include "athena/activity/public/activity_view_manager.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <map> | 8 #include <map> |
9 | 9 |
10 #include "athena/activity/activity_widget_delegate.h" | 10 #include "athena/activity/activity_widget_delegate.h" |
11 #include "athena/activity/public/activity.h" | 11 #include "athena/activity/public/activity.h" |
12 #include "athena/activity/public/activity_manager.h" | 12 #include "athena/activity/public/activity_manager.h" |
13 #include "athena/activity/public/activity_view_model.h" | 13 #include "athena/activity/public/activity_view_model.h" |
14 #include "athena/screen/public/screen_manager.h" | 14 #include "athena/screen/public/screen_manager.h" |
15 #include "ui/aura/window.h" | 15 #include "ui/aura/window.h" |
16 #include "ui/views/view.h" | 16 #include "ui/views/view.h" |
17 #include "ui/views/widget/widget.h" | 17 #include "ui/views/widget/widget.h" |
18 #include "ui/views/widget/widget_observer.h" | 18 #include "ui/views/widget/widget_observer.h" |
19 | 19 |
20 namespace athena { | 20 namespace athena { |
21 namespace { | 21 namespace { |
22 | 22 |
23 typedef std::map<Activity*, views::Widget*> ActivityWidgetMap; | 23 typedef std::map<Activity*, views::Widget*> ActivityWidgetMap; |
24 | 24 |
25 views::Widget* CreateWidget(Activity* activity) { | 25 views::Widget* CreateWidget(Activity* activity) { |
26 ActivityViewModel* view_model = activity->GetActivityViewModel(); | 26 ActivityViewModel* view_model = activity->GetActivityViewModel(); |
27 views::Widget* widget = new views::Widget; | 27 views::Widget* widget = view_model->CreateWidget(); |
28 if (widget) | |
29 return widget; | |
30 widget = new views::Widget; | |
28 views::Widget::InitParams params(views::Widget::InitParams::TYPE_WINDOW); | 31 views::Widget::InitParams params(views::Widget::InitParams::TYPE_WINDOW); |
29 params.delegate = new ActivityWidgetDelegate(view_model); | 32 params.delegate = new ActivityWidgetDelegate(view_model); |
30 params.activatable = views::Widget::InitParams::ACTIVATABLE_YES; | |
Jun Mukai
2014/09/10 23:35:38
why this removed? is it a default value?
oshima
2014/09/11 00:12:34
This was necessary when window type was TYPE_WINDO
| |
31 widget->Init(params); | 33 widget->Init(params); |
32 return widget; | 34 return widget; |
33 } | 35 } |
34 | 36 |
35 ActivityViewManager* instance = NULL; | 37 ActivityViewManager* instance = NULL; |
36 | 38 |
37 class ActivityViewManagerImpl : public ActivityViewManager, | 39 class ActivityViewManagerImpl : public ActivityViewManager, |
38 public views::WidgetObserver { | 40 public views::WidgetObserver { |
39 public: | 41 public: |
40 ActivityViewManagerImpl() { | 42 ActivityViewManagerImpl() { |
(...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
110 ActivityViewManager* ActivityViewManager::Get() { | 112 ActivityViewManager* ActivityViewManager::Get() { |
111 return instance; | 113 return instance; |
112 } | 114 } |
113 | 115 |
114 void ActivityViewManager::Shutdown() { | 116 void ActivityViewManager::Shutdown() { |
115 CHECK(instance); | 117 CHECK(instance); |
116 delete instance; | 118 delete instance; |
117 } | 119 } |
118 | 120 |
119 } // namespace athena | 121 } // namespace athena |
OLD | NEW |