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 #ifndef ATHENA_ACTIVITY_PUBLIC_ACTIVITY_VIEW_MODEL_H_ | 5 #ifndef ATHENA_ACTIVITY_PUBLIC_ACTIVITY_VIEW_MODEL_H_ |
6 #define ATHENA_ACTIVITY_PUBLIC_ACTIVITY_VIEW_MODEL_H_ | 6 #define ATHENA_ACTIVITY_PUBLIC_ACTIVITY_VIEW_MODEL_H_ |
7 | 7 |
8 #include "athena/athena_export.h" | 8 #include "athena/athena_export.h" |
9 #include "base/strings/string16.h" | 9 #include "base/strings/string16.h" |
10 | 10 |
11 typedef unsigned int SkColor; | 11 typedef unsigned int SkColor; |
12 | 12 |
| 13 namespace gfx { |
| 14 class ImageSkia; |
| 15 } |
| 16 |
13 namespace views { | 17 namespace views { |
14 class View; | 18 class View; |
15 } | 19 } |
16 | 20 |
17 namespace athena { | 21 namespace athena { |
18 | 22 |
| 23 // The view model for the representation of the activity. |
19 class ATHENA_EXPORT ActivityViewModel { | 24 class ATHENA_EXPORT ActivityViewModel { |
20 public: | 25 public: |
21 virtual ~ActivityViewModel() {} | 26 virtual ~ActivityViewModel() {} |
22 | 27 |
23 // Called after the view model is attaced to the widget/window tree. | 28 // Called after the view model is attached to the widget/window tree. |
24 virtual void Init() = 0; | 29 virtual void Init() = 0; |
25 | 30 |
26 // Returns a color most representative of this activity. | 31 // Returns a color most representative of this activity. |
27 virtual SkColor GetRepresentativeColor() const = 0; | 32 virtual SkColor GetRepresentativeColor() const = 0; |
28 | 33 |
29 // Returns a title for the activity. | 34 // Returns a title for the activity. |
30 virtual base::string16 GetTitle() const = 0; | 35 virtual base::string16 GetTitle() const = 0; |
31 | 36 |
32 // True if the activity wants to use Widget's frame, or false if the activity | 37 // True if the activity wants to use Widget's frame, or false if the activity |
33 // draws its own frame. | 38 // draws its own frame. |
34 virtual bool UsesFrame() const = 0; | 39 virtual bool UsesFrame() const = 0; |
35 | 40 |
36 // Returns the contents view. | 41 // Returns the contents view which might be NULL if the activity is not |
| 42 // loaded. Note that the caller should not hold on to the view since it can |
| 43 // be deleted by the resource manager. |
37 virtual views::View* GetContentsView() = 0; | 44 virtual views::View* GetContentsView() = 0; |
| 45 |
| 46 // This gets called before the Activity gets (partially) thrown out of memory |
| 47 // to create a preview image of the activity. Note that even if this function |
| 48 // gets called, |GetOverviewModeImage()| could still return an empty image. |
| 49 virtual void CreateOverviewModeImage() = 0; |
| 50 |
| 51 // Returns an image which can be used to represent the activity in e.g. the |
| 52 // overview mode. The returned image can have no size if either a view exists |
| 53 // or the activity has not yet been loaded. In that case |
| 54 // GetRepresentativeColor() should be used to clear the preview area. |
| 55 // Note: We intentionally do not use a layer / view for this. |
| 56 virtual gfx::ImageSkia GetOverviewModeImage() = 0; |
38 }; | 57 }; |
39 | 58 |
40 } // namespace athena | 59 } // namespace athena |
41 | 60 |
42 #endif // ATHENA_ACTIVITY_PUBLIC_ACTIVITY_VIEW_MODEL_H_ | 61 #endif // ATHENA_ACTIVITY_PUBLIC_ACTIVITY_VIEW_MODEL_H_ |
OLD | NEW |