Update To 11.40.268.0
[platform/framework/web/crosswalk.git] / src / athena / activity / public / activity_view_model.h
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
3 // found in the LICENSE file.
4
5 #ifndef ATHENA_ACTIVITY_PUBLIC_ACTIVITY_VIEW_MODEL_H_
6 #define ATHENA_ACTIVITY_PUBLIC_ACTIVITY_VIEW_MODEL_H_
7
8 #include "athena/athena_export.h"
9 #include "base/strings/string16.h"
10
11 typedef unsigned int SkColor;
12
13 namespace gfx {
14 class ImageSkia;
15 }
16
17 namespace views {
18 class View;
19 class Widget;
20 }
21
22 namespace athena {
23
24 class ActivityView;
25
26 // The view model for the representation of the activity.
27 class ATHENA_EXPORT ActivityViewModel {
28  public:
29   virtual ~ActivityViewModel() {}
30
31   // Called after the view model is attached to the widget/window tree and
32   // before it gets registered to the ActivityManager and the ResourceManager.
33   // At this time the Activity can also be moved to a different place in the
34   // Activity history.
35   virtual void Init() = 0;
36
37   // Returns a color most representative of this activity.
38   virtual SkColor GetRepresentativeColor() const = 0;
39
40   // Returns a title for the activity.
41   virtual base::string16 GetTitle() const = 0;
42
43   // Returns an icon for the activity.
44   virtual gfx::ImageSkia GetIcon() const = 0;
45
46   // Sets the ActivityView for the model to update. The model does not take
47   // ownership of the view.
48   virtual void SetActivityView(ActivityView* view) = 0;
49
50   // True if the activity wants to use Widget's frame, or false if the activity
51   // draws its own frame.
52   virtual bool UsesFrame() const = 0;
53
54   // Returns the contents view which might be nullptr if the activity is not
55   // loaded. Note that the caller should not hold on to the view since it can
56   // be deleted by the resource manager.
57   virtual views::View* GetContentsView() = 0;
58
59   // Returns an image which can be used to represent the activity in e.g. the
60   // overview mode. The returned image can have no size if either a view exists
61   // or the activity has not yet been loaded or ever been presented. In that
62   // case GetRepresentativeColor() should be used to clear the preview area.
63   // Note that since the image gets created upon request, and the
64   // ActivityViewModel will hold no reference to the returned image data. As
65   // such it is advisable to hold on to the image as long as needed instead of
66   // calling this function frequently since it will cause time to generate.
67   virtual gfx::ImageSkia GetOverviewModeImage() = 0;
68
69   // Prepares the contents view for overview.
70   virtual void PrepareContentsForOverview() = 0;
71
72   // Undoes any changes done by PrepareContentsForOverview().
73   virtual void ResetContentsView() = 0;
74 };
75
76 }  // namespace athena
77
78 #endif  // ATHENA_ACTIVITY_PUBLIC_ACTIVITY_VIEW_MODEL_H_