diff --git a/panda/src/testbed/gui_demo.cxx b/panda/src/testbed/gui_demo.cxx index 12cfc922df..8ab5065766 100644 --- a/panda/src/testbed/gui_demo.cxx +++ b/panda/src/testbed/gui_demo.cxx @@ -811,6 +811,77 @@ static void test14(GuiManager* mgr, Node* font) { ch1->manage(mgr, event_handler); } +static void test15(GuiManager* mgr, Node* font) { + GuiLabel* nl1 = GuiLabel::make_simple_text_label("next", font); + GuiLabel* nl2 = GuiLabel::make_simple_text_label("next", font); + GuiLabel* nl3 = GuiLabel::make_simple_text_label("next", font); + GuiButton* nb = new GuiButton("next_button", nl1, nl2, nl3); + nb->set_scale(0.1); + nb->set_pos(LVector3f::rfu(0.25, 0., -0.25)); + GuiLabel* pl1 = GuiLabel::make_simple_text_label("prev", font); + GuiLabel* pl2 = GuiLabel::make_simple_text_label("prev", font); + GuiLabel* pl3 = GuiLabel::make_simple_text_label("prev", font); + GuiButton* pb = new GuiButton("prev_button", pl1, pl2, pl3); + pb->set_scale(0.1); + pb->set_pos(LVector3f::rfu(-0.25, 0., -0.25)); + nb->set_behavior_event("demo-event-thing"); + pb->set_behavior_event("demo-event-thing"); + ch1 = new GuiChooser("chooser", pb, nb); + GuiLabel* l1 = GuiLabel::make_simple_text_label("hyena", font); + GuiSign* s1 = new GuiSign("hyena", l1); + s1->set_scale(0.1); + GuiLabel* l2 = GuiLabel::make_simple_text_label("dingo", font); + GuiSign* s2 = new GuiSign("dingo", l2); + s2->set_scale(0.1); + GuiLabel* l3 = GuiLabel::make_simple_text_label("jackal", font); + GuiSign* s3 = new GuiSign("jackal", l3); + s3->set_scale(0.1); + GuiLabel* l4 = GuiLabel::make_simple_text_label("wolf", font); + GuiSign* s4 = new GuiSign("wolf", l4); + s4->set_scale(0.1); + GuiLabel* l5 = GuiLabel::make_simple_text_label("fox", font); + GuiSign* s5 = new GuiSign("fox", l5); + s5->set_scale(0.1); + float w, w1, w2; + w1 = l1->get_width(); + w2 = l2->get_width(); + w = (w1>w2)?w1:w2; + w2 = l3->get_width(); + w = (w>w2)?w:w2; + w2 = l4->get_width(); + w = (w>w2)?w:w2; + w2 = l5->get_width(); + w = (w>w2)?w:w2; + l1->set_width(w); + l2->set_width(w); + l3->set_width(w); + l4->set_width(w); + l5->set_width(w); + nl1->set_background_color(0., 0., 0., 1.); + nl2->set_background_color(0., 0., 0., 1.); + nl3->set_background_color(0., 0., 0., 1.); + nl2->set_foreground_color(1., 0., 0., 1.); + nl3->set_foreground_color(1., 1., 1., 0.5); + pl1->set_background_color(0., 0., 0., 1.); + pl2->set_background_color(0., 0., 0., 1.); + pl3->set_background_color(0., 0., 0., 1.); + pl2->set_foreground_color(1., 0., 0., 1.); + pl3->set_foreground_color(1., 1., 1., 0.5); + l1->set_background_color(0., 0., 0., 1.); + l2->set_background_color(0., 0., 0., 1.); + l3->set_background_color(0., 0., 0., 1.); + l4->set_background_color(0., 0., 0., 1.); + l5->set_background_color(0., 0., 0., 1.); + ch1->add_item(s1); + ch1->add_item(s2); + ch1->add_item(s3); + ch1->add_item(s4); + ch1->add_item(s5); + ch1->thaw(); + ch1->manage(mgr, event_handler); + ch1->start_behavior(); +} + static void setup_gui(void) { GuiManager* mgr = GuiManager::get_ptr(main_win, mak, (Node*)0L); PT_Node font = ModelPool::load_model("ttf-comic"); @@ -844,7 +915,9 @@ static void setup_gui(void) { // test 13 // test13(mgr, font); // test 14 - test14(mgr, font); + // test14(mgr, font); + // test 15 + test15(mgr, font); } static void event_2(CPT_Event) { @@ -932,7 +1005,7 @@ static void event_3(CPT_Event) { } */ -// for test 14 +// for test 14-15 static void event_3(CPT_Event) { ch1->move_prev(); } @@ -945,7 +1018,7 @@ static void event_4(CPT_Event) { } */ -// for test 14 +// for test 14-15 static void event_4(CPT_Event) { ch1->move_next(); } @@ -959,9 +1032,9 @@ void gui_keys(EventHandler&) { have_dlight = true; event_handler.add_hook("2", event_2); - // for tests 7-11, 13-14 + // for tests 7-11, 13-15 event_handler.add_hook("3", event_3); - // for test 11, 13-14 + // for test 11, 13-15 event_handler.add_hook("4", event_4); event_handler.add_hook("demo-event-thing", event_demo); }