Mercurial > fife-parpg
diff ext/guichan-0.8.2/examples/action.hpp @ 378:64738befdf3b
bringing in the changes from the build_system_rework branch in preparation for the 0.3.0 release. This commit will require the Jan2010 devkit. Clients will also need to be modified to the new way to import fife.
author | vtchill@33b003aa-7bff-0310-803a-e67f0ece8222 |
---|---|
date | Mon, 11 Jan 2010 23:34:52 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/ext/guichan-0.8.2/examples/action.hpp Mon Jan 11 23:34:52 2010 +0000 @@ -0,0 +1,130 @@ +/** + * Code to populate a global Gui object with an example of how to + * use actions in Guichan. + */ + +#include <guichan.hpp> +#include <iostream> +#include <sstream> + +namespace action +{ + gcn::Container* top; + gcn::ImageFont* font; + gcn::Button* button1; + gcn::Button* button2; + gcn::Label* label1; + gcn::Label* label2; + + int clickCountButton1 = 0; // Holds clicks for button1 + int clickCountButton2 = 0; // Holds clicks for button2 + + /* + * To be able to recieve actions we must have a class inheriting from + * ActionListener and implementing the action function. + * When an action is generated in a Widget (i.e when a button is clicked) + * that widget calls the action function for all its action listeners. + * Below we make a class to be able to recieve our buttons actions. + */ + class ButtonActionListener : public gcn::ActionListener + { + public: + // Implement the action function in ActionListener to recieve actions + // The eventId tells us which widget called the action function. + void action(const gcn::ActionEvent& actionEvent) + { + std::string str; + std::ostringstream os(str); + + // Here we use the widget pointer to check which widget the action + // originated from. + if (actionEvent.getSource() == button1) + { + clickCountButton1++; + os << "Button1 clicks " << clickCountButton1; + // Change the caption to show number of clicks + label1->setCaption(os.str()); + // Adjust the label to fit the new caption + label1->adjustSize(); + } + // Here we use the event id in order to check what action occured. + else if (actionEvent.getId() == "button2") + { + clickCountButton2++; + os << "Button2 clicks " << clickCountButton2; + // Change the caption to show number of clicks + label2->setCaption(os.str()); + // Adjust the label to fit the new caption + label2->adjustSize(); + } + } + }; + + ButtonActionListener* buttonActionListener; // A pointer to the above class + + /** + * Initialises the widgets example by populating the global Gui + * object. + */ + void init() + { + // We first create a container to be used as the top widget. + // The top widget in Guichan can be any kind of widget, but + // in order to make the Gui contain more than one widget we + // make the top widget a container. + top = new gcn::Container(); + // We set the dimension of the top container to match the screen. + top->setDimension(gcn::Rectangle(0, 0, 640, 480)); + // Finally we pass the top widget to the Gui object. + globals::gui->setTop(top); + + // Now we load the font used in this example. + font = new gcn::ImageFont("fixedfont.bmp", " abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"); + // Widgets may have a global font so we don't need to pass the + // font object to every created widget. The global font is static. + gcn::Widget::setGlobalFont(font); + + // Now we create the buttons. + button1 = new gcn::Button("Button 1"); + button2 = new gcn::Button("Button 2"); + button1->setPosition(120, 230); + button2->setPosition(420, 230); + // We add the buttons to the top container. + top->add(button1); + top->add(button2); + + // Now we create the labels. + label1 = new gcn::Label("Button1 clicks 0"); + label2 = new gcn::Label("Button2 clicks 0"); + label1->setPosition(100, 200); + label2->setPosition(400, 200); + // We add the labels to the top container. + top->add(label1); + top->add(label2); + + // Now we set the button's action event ids. + button1->setActionEventId("button1"); + button2->setActionEventId("button2"); + + // We make an instance of the ButtonActionListener. + buttonActionListener = new ButtonActionListener(); + + // And add the ButtonActionListener as an action listener of the buttons. + button1->addActionListener(buttonActionListener); + button2->addActionListener(buttonActionListener); + } + + /** + * Halts the action example. + */ + void halt() + { + delete buttonActionListener; + delete label1; + delete label2; + delete button1; + delete button2; + delete font; + delete top; + } +}