adapte the EObject type management

This commit is contained in:
Edouard Dupin 2012-03-13 14:37:19 +01:00
parent 018e5b7eb0
commit 491d8cf16c
3 changed files with 122 additions and 9 deletions

View File

@ -125,13 +125,12 @@ class MaListExemple : public ewol::List
const char * const drawerEventRequestOpenFile = "Drawer Request Open File";
const char * const drawerEventRequestOpenFileClosed = "Drawer Close Open File"; const char * const drawerEventRequestOpenFileClosed = "Drawer Close Open File";
const char * const drawerEventRequestOpenFileSelected = "Drawer Open Selected File"; const char * const drawerEventRequestOpenFileSelected = "Drawer Open Selected File";
const char * const drawerEventRequestSaveFileSelected = "Drawer Save Selected File";
const char * const drawerEventColorHasChange = "Drawer-select-color-change"; const char * const drawerEventColorHasChange = "Drawer-select-color-change";
const char * const TYPE_EOBJECT_WIDGET_DRAW_WINDOWS_MAIN = "MainWindows";
class MainWindows :public ewol::Windows class MainWindows :public ewol::Windows
{ {
private: private:
@ -246,7 +245,7 @@ class MainWindows :public ewol::Windows
tmpWidget->RegisterOnEvent(this, ewolEventFileChooserValidate, drawerEventRequestOpenFileSelected); tmpWidget->RegisterOnEvent(this, ewolEventFileChooserValidate, drawerEventRequestOpenFileSelected);
} else if (eventId == drawerEventRequestOpenFileSelected) { } else if (eventId == drawerEventRequestOpenFileSelected) {
// get widget: // get widget:
ewol::FileChooser * tmpWidget = static_cast<ewol::FileChooser*>(CallerObject); ewol::FileChooser * tmpWidget = EWOL_CAST_WIDGET_FILE_CHOOSER(CallerObject);
if (NULL == tmpWidget) { if (NULL == tmpWidget) {
DRAW_ERROR("impossible to get pop_upWidget " << CallerObject); DRAW_ERROR("impossible to get pop_upWidget " << CallerObject);
return; return;
@ -262,16 +261,36 @@ class MainWindows :public ewol::Windows
if (m_drawer->HasName()) { if (m_drawer->HasName()) {
m_drawer->Save(); m_drawer->Save();
} else { } else {
DRAW_TODO("Later ..."); ewol::FileChooser* tmpWidget = new ewol::FileChooser();
tmpWidget->SetTitle("Save Files ...");
tmpWidget->SetValidateLabel("Save");
PopUpWidgetPush(tmpWidget);
tmpWidget->RegisterOnEvent(this, ewolEventFileChooserValidate, drawerEventRequestSaveFileSelected);
} }
} }
} else if (eventId == drawerEventRequestSaveFileSelected) {
// get widget:
ewol::FileChooser * tmpWidget = EWOL_CAST_WIDGET_FILE_CHOOSER(CallerObject);
if (NULL == tmpWidget) {
DRAW_ERROR("impossible to get pop_upWidget " << CallerObject);
return;
}
// get the filename :
etk::UString tmpData = tmpWidget->GetCompleateFileName();
DRAW_DEBUG("Request opening the file : " << tmpData);
if (NULL != m_drawer) {
m_drawer->SetFilename(tmpData);
m_drawer->Save();
}
} else if (eventId == drawerEventColorHasChange) { } else if (eventId == drawerEventColorHasChange) {
// the button color has change ==> we really change the current color ... // the button color has change ==> we really change the current color ...
if (NULL != CallerObject) { if (NULL != CallerObject) {
ewol::ButtonColor * tmpColorButton = static_cast<ewol::ButtonColor*>(CallerObject); ewol::ButtonColor * tmpColorButton = EWOL_CAST_WIDGET_BUTTON_COLOR(CallerObject);
color_ts tmpColor = tmpColorButton->GetCurrentColor(); if (NULL != tmpColorButton) {
if (NULL != m_drawer) { color_ts tmpColor = tmpColorButton->GetCurrentColor();
m_drawer->SetColorOnSelected(tmpColor); if (NULL != m_drawer) {
m_drawer->SetColorOnSelected(tmpColor);
}
} }
} }
} }
@ -292,8 +311,45 @@ class MainWindows :public ewol::Windows
m_needFlipFlop = true; m_needFlipFlop = true;
} }
} }
public:
/**
* @brief Check if the object has the specific type.
* @note In Embended platforme, it is many time no -rtti flag, then it is not possible to use dynamic cast ==> this will replace it
* @param[in] objectType type of the object we want to check
* @return true if the object is compatible, otherwise false
*/
bool CheckObjectType(const char * const objectType)
{
if (NULL == objectType) {
EWOL_ERROR("check error : \"" << TYPE_EOBJECT_WIDGET_DRAW_WINDOWS_MAIN << "\" != NULL(pointer) ");
return false;
}
if (objectType == TYPE_EOBJECT_WIDGET_DRAW_WINDOWS_MAIN) {
return true;
} else {
if(true == ewol::Windows::CheckObjectType(objectType)) {
return true;
}
EWOL_ERROR("check error : \"" << TYPE_EOBJECT_WIDGET_DRAW_WINDOWS_MAIN << "\" != \"" << objectType << "\"");
return false;
}
}
/**
* @brief Get the current Object type of the EObject
* @note In Embended platforme, it is many time no -rtti flag, then it is not possible to use dynamic cast ==> this will replace it
* @param[in] objectType type description
* @return true if the object is compatible, otherwise false
*/
const char * const GetObjectType(void)
{
return TYPE_EOBJECT_WIDGET_DRAW_WINDOWS_MAIN;
}
}; };
#define DRAW_CAST_WINDOWS_MAIN(curentPointer) EWOL_CAST(TYPE_EOBJECT_WIDGET_DRAW_WINDOWS_MAIN,widgetDrawer,curentPointer)
static MainWindows * basicWindows = NULL; static MainWindows * basicWindows = NULL;
/** /**

View File

@ -68,6 +68,44 @@ widgetDrawer::~widgetDrawer(void)
} }
//!< EObject name :
extern const char * const TYPE_EOBJECT_WIDGET_DRAW_DRAWER = "widgetDrawer";
/**
* @brief Check if the object has the specific type.
* @note In Embended platforme, it is many time no -rtti flag, then it is not possible to use dynamic cast ==> this will replace it
* @param[in] objectType type of the object we want to check
* @return true if the object is compatible, otherwise false
*/
bool widgetDrawer::CheckObjectType(const char * const objectType)
{
if (NULL == objectType) {
EWOL_ERROR("check error : \"" << TYPE_EOBJECT_WIDGET_DRAW_DRAWER << "\" != NULL(pointer) ");
return false;
}
if (objectType == TYPE_EOBJECT_WIDGET_DRAW_DRAWER) {
return true;
} else {
if(true == ewol::Widget::CheckObjectType(objectType)) {
return true;
}
EWOL_ERROR("check error : \"" << TYPE_EOBJECT_WIDGET_DRAW_DRAWER << "\" != \"" << objectType << "\"");
return false;
}
}
/**
* @brief Get the current Object type of the EObject
* @note In Embended platforme, it is many time no -rtti flag, then it is not possible to use dynamic cast ==> this will replace it
* @param[in] objectType type description
* @return true if the object is compatible, otherwise false
*/
const char * const widgetDrawer::GetObjectType(void)
{
return TYPE_EOBJECT_WIDGET_DRAW_DRAWER;
}
bool widgetDrawer::CalculateMinSize(void) bool widgetDrawer::CalculateMinSize(void)
{ {
m_minSize.x = 50; m_minSize.x = 50;

View File

@ -36,11 +36,28 @@ typedef struct {
} link_ts; } link_ts;
extern const char * const TYPE_EOBJECT_WIDGET_DRAW_DRAWER;
class widgetDrawer :public ewol::Widget class widgetDrawer :public ewol::Widget
{ {
public: public:
widgetDrawer(void); widgetDrawer(void);
virtual ~widgetDrawer(void); virtual ~widgetDrawer(void);
/**
* @brief Check if the object has the specific type.
* @note In Embended platforme, it is many time no -rtti flag, then it is not possible to use dynamic cast ==> this will replace it
* @param[in] objectType type of the object we want to check
* @return true if the object is compatible, otherwise false
*/
virtual bool CheckObjectType(const char * const objectType);
/**
* @brief Get the current Object type of the EObject
* @note In Embended platforme, it is many time no -rtti flag, then it is not possible to use dynamic cast ==> this will replace it
* @param[in] objectType type description
* @return true if the object is compatible, otherwise false
*/
virtual const char * const GetObjectType(void);
virtual bool CalculateMinSize(void); virtual bool CalculateMinSize(void);
private: private:
color_ts m_triangleColor; //!< color for the next element of the triangle color_ts m_triangleColor; //!< color for the next element of the triangle
@ -106,5 +123,7 @@ class widgetDrawer :public ewol::Widget
bool HasName(void) { if(m_fileName=="") { return false;} return true; }; bool HasName(void) { if(m_fileName=="") { return false;} return true; };
}; };
#define DRAW_CAST_WIDGET_DRAWER(curentPointer) EWOL_CAST(TYPE_EOBJECT_WIDGET_DRAW_DRAWER,ewol::widgetDrawer,curentPointer)
#endif #endif