License conversion from Flora to Apache 2.0
[platform/core/uifw/dali-core.git] / dali / internal / update / controllers / render-message-dispatcher.h
1 #ifndef __DALI_INTERNAL_SCENE_GRAPH_RENDER_MESSAGE_DISPATCHER_H__
2 #define __DALI_INTERNAL_SCENE_GRAPH_RENDER_MESSAGE_DISPATCHER_H__
3
4 /*
5  * Copyright (c) 2014 Samsung Electronics Co., Ltd.
6  *
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  *
11  * http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  *
19  */
20
21 // INTERNAL INCLUDES
22 #include <dali/internal/update/common/scene-graph-buffers.h>
23
24 namespace Dali
25 {
26
27 namespace Internal
28 {
29 class MessageBase;
30
31 namespace SceneGraph
32 {
33 class Renderer;
34 class RenderManager;
35 class RenderQueue;
36 class RenderTracker;
37
38 /**
39  * A utility class for sending messages to the render-thread.
40  */
41 class RenderMessageDispatcher
42 {
43 public:
44
45   /**
46    * Constructor
47    */
48   RenderMessageDispatcher( RenderManager& renderManager, RenderQueue& renderQueue, const SceneGraphBuffers& buffers );
49
50   /**
51    * Destructor
52    */
53   virtual ~RenderMessageDispatcher();
54
55   /**
56    * Add a Renderer.
57    * @param[in] renderer The renderer to add.
58    * @post renderer ownership is transferred.
59    */
60   void AddRenderer( Renderer& renderer );
61
62   /**
63    * Remove a Renderer.
64    * @param[in] updateBufferIndex The current buffer index.
65    * @param[in] renderer The renderer to remove.
66    * @post renderer will be destroyed in the next Render.
67    */
68   void RemoveRenderer( Renderer& renderer );
69
70   /**
71    * Add a Render tracker.
72    * @param[in] renderTracker The render tracker to add.
73    * @post ownership is transferred
74    */
75   void AddRenderTracker( RenderTracker& renderTracker );
76
77   /**
78    * Remove a Render tracker.
79    * @param[in] renderTracker The render tracker to add.
80    * @post render tracker will be destroyed in the next Render pass.
81    */
82   void RemoveRenderTracker( RenderTracker& renderTracker );
83
84 private:
85
86   RenderManager& mRenderManager;
87   RenderQueue& mRenderQueue;
88
89   const SceneGraphBuffers& mBuffers;
90 };
91
92 } // namespace SceneGraph
93
94 } // namespace Internal
95
96 } // namespace Dali
97
98 #endif // __DALI_INTERNAL_SCENE_GRAPH_RENDERER_DISPATCHER_H__