]> Creatis software - creaMaracasVisu.git/blob
3ca492aa40ae9296dcb2e4e1d5258818fbb2c6d2
[creaMaracasVisu.git] /
1 /*!
2  * @file buttonContainerController.h
3  * @brief This contains the ButtonContainerController class
4  * @author Diego CACERES (diego.caceres[AT]creatis.insa-lyon.fr)
5  * @date  2011-05-19
6  */
7
8 #ifndef BUTTONCONTAINERCONTROLLER_H_
9 #define BUTTONCONTAINERCONTROLLER_H_
10
11 #include <wx/event.h>
12 #include <iostream>
13 #include <exception>
14 #include "buttonContainerPanel.h"
15
16 /*!     @namespace <creaButtonContainer>
17  *      @brief Contains the creaButtonContainer library included in creaMaracasVisu.
18  */
19 namespace creaButtonContainer
20 {
21         /*! @namespace <creaButtonContainer::view>
22          *      @brief Contains the implementation of the view in creaButtonContainer library.
23          *      @see <a href="http://en.wikipedia.org/wiki/Model-view-controller">MVC Software Architecture</a>
24          */
25         namespace view
26         {
27                 //Predefinition of ButtonContainerPanel FriendClass!!
28                 /*! @class ButtonContainerPanel : public wxScrolledWindow buttonContainerPanel.h "buttonContainerPanel.h"
29                  *  @brief This class is the container of the creaButtonContainer.
30                  *  @details This class derives from wxScrolledWindow and manages the view of the buttonContainer.
31                  *  @see <a href="http://docs.wxwidgets.org/stable/wx_wxscrolledwindow.html">wxScrolledWindow</a>
32                  */
33                 class ButtonContainerPanel;
34         }
35         /*!     @namespace<creaButtonContainer::controller>
36          *      @brief Contains the implementation of the controller in creaButtonContainer library.
37          *      @see <a href="http://en.wikipedia.org/wiki/Model-view-controller">MVC Software Architecture</a>
38          */
39         namespace controller
40         {
41                 /*! @class ButtonContainerController buttonContainerController.h "buttonContainerController.h"
42                  *      @brief This class contains the ButtonContainerPanel controller.
43                  *  @details This class describes the button events, it derives from wxEvtHandler and it is the
44                  *  controller in the MVC.
45                  *  @see <a href="http://docs.wxwidgets.org/stable/wx_wxevthandler.html">wxEvtHandler</a>
46                  */
47                 class ButtonContainerController : public wxEvtHandler
48                 {
49                         public:
50                                 //typedef definitions
51                                 /*!     @typedef creaButtonContainer::view::ButtonGroup ButtonGroup
52                                  *      @brief Defines the ButtonGroup type
53                                  */
54                                 typedef creaButtonContainer::view::ButtonGroup ButtonGroup;
55                                 // ----------------------------------------------------------------------------------
56                                 /*!     @typedef typedef creaButtonContainer::view::GroupManager GroupManager
57                                  *      @brief Defines the GroupManager type
58                                  */
59                                 typedef creaButtonContainer::view::GroupManager GroupManager;
60                                 // ----------------------------------------------------------------------------------
61                                 /*!     @typedef std::list< ButtonGroup* > ButtonGroupList
62                                  *      @brief Defines the ButtonGroupList type
63                                  */
64                                 typedef std::list< ButtonGroup* > ButtonGroupList;
65                                 // ----------------------------------------------------------------------------------
66                                 /*!     @typedef std::map< long, GroupManager* > GroupManagerList
67                                  *      @brief Defines the GroupManagerList type
68                                  */
69                                 typedef std::map< long, GroupManager* > GroupManagerList;
70                                 // ----------------------------------------------------------------------------------
71                                 /*!     @typedef wxFlexGridSizer Sizer
72                                  *      @brief Defines the Sizer type
73                                  */
74                                 typedef wxFlexGridSizer Sizer;
75                                 // ----------------------------------------------------------------------------------
76                                 /*!     @typedef std::list< long > KeyList
77                                  *      @brief Defines the KeyList type
78                                  */
79                                 typedef std::list< long > KeyList;
80                                 // ----------------------------------------------------------------------------------
81                                 /*!     @typedef creaButtonContainer::model::ContainerSettings ButtonGroupSettings
82                                  *      @brief Defines the ButtonGroupSettings type
83                                  */
84                                 typedef creaButtonContainer::model::ContainerSettings
85                                     ButtonGroupSettings;
86                                 // ----------------------------------------------------------------------------------
87                                 /*!     @typedef creaButtonContainer::view::ButtonContainerPanel BCPanel
88                                  *      @brief Defines the BCPanel type
89                                  */
90                                 typedef creaButtonContainer::view::ButtonContainerPanel BCPanel;
91                                 //end of typedef definition
92                         public:
93                                 // ----------------------------------------------------------------------------------
94                                 /*!     @fn ButtonContainerController( BCPanel* );
95                                  *      @brief This is the Parameterized constructor.
96                                  *      @param BCPanel* The connection with the view (wxPanel link).
97                                  */
98                                 ButtonContainerController( BCPanel* );
99                                 // ----------------------------------------------------------------------------------
100                                 /*! @fn ~ButtonContainerController( );
101                                  *      @brief This is the destructor.
102                                  */
103                                 virtual
104                                 ~ButtonContainerController( );
105
106                                 // ----------------------------------------------------------------------------------
107                                 /*! @fn void AddEvents( );
108                                  *      @brief This function connect every buttonEvent to the view.
109                                  *      @exception std::bad_alloc
110                                  */
111                                 void
112                                 AddEvents( );
113                                 // ----------------------------------------------------------------------------------
114                                 /*! @fn void ButtonExpEvent( wxCommandEvent& event );
115                                  *      @brief This function is the button group "+" "-" event.
116                                  *      @exception std::bad_alloc
117                                  *      @param event Button action event.
118                                  */
119                                 void
120                                 ButtonExpEvent( wxCommandEvent& event );
121                                 // ----------------------------------------------------------------------------------
122                                 /*! @fn void ButtonEvent( wxCommandEvent& event );
123                                  *      @brief This function calls the events of the buttonContainer buttons
124                                  *      @exception std::bad_alloc
125                                  *      @param event Button action event.
126                                  */
127                                 void
128                                 ButtonEvent( wxCommandEvent& event );
129                                 // ----------------------------------------------------------------------------------
130                         private:
131                                 BCPanel* m_BCPanel; //! <ButtonContainerPanel View pointer.
132                 };
133         }//ecapsename
134 }//ecapsename
135
136 #endif //BUTTONCONTAINERCONTROLLER_H_