X-Git-Url: http://git.cinelerra-gg.org/git/?a=blobdiff_plain;f=cinelerra-5.1%2Fguicast%2Fbcpopupmenu.C;h=4c639fe27d25890f96bd4289cc77c21c651ca569;hb=5877eaa318ed3060f57621657c0888258da41a59;hp=6a8c63e2f9daaafa61089100eaf36798d685e89c;hpb=4f7f413cbc1c6ea5da27cb75ca27a3ab317243ec;p=goodguy%2Fhistory.git diff --git a/cinelerra-5.1/guicast/bcpopupmenu.C b/cinelerra-5.1/guicast/bcpopupmenu.C index 6a8c63e2..4c639fe2 100644 --- a/cinelerra-5.1/guicast/bcpopupmenu.C +++ b/cinelerra-5.1/guicast/bcpopupmenu.C @@ -26,7 +26,7 @@ #include "bcpopupmenu.h" #include "bcresources.h" #include "bcsignals.h" -#include "colors.h" +#include "bccolors.h" #include "fonts.h" #include #include "vframe.h" @@ -96,6 +96,7 @@ BC_PopupMenu::~BC_PopupMenu() { use_title = 0; deactivate(); + delete menu_popup; for(int i = 0; i < TOTAL_IMAGES; i++) { if(images[i]) delete images[i]; @@ -290,6 +291,7 @@ int BC_PopupMenu::activate_menu() { if( !get_button_down() || !BC_WindowBase::get_resources()->popupmenu_btnup ) return menu_activate(); + top_level->active_popup_menu = this; pending = 1; return 0; } @@ -327,7 +329,7 @@ int BC_PopupMenu::menu_activate() popup_down = 1; if(use_title) draw_title(1); } - return 0; + return 1; } int BC_PopupMenu::deactivate_menu() @@ -367,6 +369,7 @@ int BC_PopupMenu::repeat_event(int64_t duration) int BC_PopupMenu::button_press_event() { + int result = 0; if(get_buttonpress() == 1 && is_event_win() && use_title) @@ -402,17 +405,18 @@ int BC_PopupMenu::button_press_event() BC_MenuItem *tmp = menu_popup->menu_items.values[theval]; set_text(tmp->get_text()); - if (!tmp->handle_event()) - this->handle_event(); + result = tmp->handle_event(); + if( !result ) + result = this->handle_event(); } if(popup_down) { // Menu is down so dispatch to popup. menu_popup->dispatch_button_press(); - return 1; + result = 1; } - return 0; + return result; } int BC_PopupMenu::button_release_event() @@ -471,7 +475,7 @@ int BC_PopupMenu::cursor_leave_event() if( popup_down ) { if( !get_button_down() && !menu_popup->cursor_inside() ) { status = BUTTON_UP; - deactivate_menu(); +// deactivate_menu(); } menu_popup->dispatch_cursor_leave(); }