summaryrefslogtreecommitdiffstats
path: root/SidebarView.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'SidebarView.cpp')
-rw-r--r--SidebarView.cpp196
1 files changed, 0 insertions, 196 deletions
diff --git a/SidebarView.cpp b/SidebarView.cpp
deleted file mode 100644
index db470be..0000000
--- a/SidebarView.cpp
+++ /dev/null
@@ -1,196 +0,0 @@
-#include "SidebarView.h"
-#include "PlayerStart.h"
-#include "ToolSelector.h"
-
-
-void SidebarView::spinButtonChanged(GtkWidget *spinbutton, SidebarView *view) {
- if(!view->editManager->getSelectedObject())
- return;
-
- if(view->editManager->getSelectedObject()->isOfType("Room")) {
- if(spinbutton == view->spinButtonHeight)
- ((Room*)view->editManager->getSelectedObject())->setHeight(gtk_spin_button_get_value(GTK_SPIN_BUTTON(spinbutton)));
- }
- else if(view->editManager->getSelectedObject()->isOfType("PlayerStart")) {
- if(spinbutton == view->spinButtonX)
- ((PlayerStart*)view->editManager->getSelectedObject())->setX(gtk_spin_button_get_value(GTK_SPIN_BUTTON(spinbutton)));
- else if(spinbutton == view->spinButtonY)
- ((PlayerStart*)view->editManager->getSelectedObject())->setY(gtk_spin_button_get_value(GTK_SPIN_BUTTON(spinbutton)));
- else if(spinbutton == view->spinButtonZ)
- ((PlayerStart*)view->editManager->getSelectedObject())->setZ(gtk_spin_button_get_value(GTK_SPIN_BUTTON(spinbutton)));
- }
-
- view->editManager->redraw();
-}
-
-SidebarView::SidebarView(EditManager *editManager) {
- this->editManager = editManager;
-
- sidebar = gtk_vbox_new(FALSE, 0);
- g_object_ref_sink(G_OBJECT(sidebar));
-
- labelType = gtk_label_new(NULL);
- gtk_misc_set_alignment(GTK_MISC(labelType), 0.0, 0.5);
- gtk_box_pack_start(GTK_BOX(sidebar), labelType, FALSE, FALSE, 5);
-
- gtk_box_pack_start(GTK_BOX(sidebar), gtk_hseparator_new(), FALSE, FALSE, 5);
-
- labelName = gtk_label_new("Name: ");
- gtk_misc_set_alignment(GTK_MISC(labelName), 0.0, 0.5);
- gtk_widget_set_no_show_all(labelName, TRUE);
- gtk_box_pack_start(GTK_BOX(sidebar), labelName, FALSE, FALSE, 0);
-
- entryName = gtk_entry_new();
- gtk_widget_set_size_request(entryName, 0, -1);
- //g_signal_connect(G_OBJECT(entryName), "focus-out-event", G_CALLBACK(sidebarNameFocusOutEvent), NULL);
- //gtk_widget_add_events(entryName, GDK_FOCUS_CHANGE_MASK);
- gtk_widget_set_no_show_all(entryName, TRUE);
- gtk_box_pack_start(GTK_BOX(sidebar), entryName, FALSE, FALSE, 0);
-
- tableRoomData = gtk_table_new(2, 3, FALSE);
- gtk_table_set_row_spacings(GTK_TABLE(tableRoomData), 5);
- gtk_widget_set_no_show_all(tableRoomData, TRUE);
- gtk_box_pack_start(GTK_BOX(sidebar), tableRoomData, FALSE, FALSE, 5);
-
- GtkWidget *labelAreaLabel = gtk_label_new("Room area: ");
- gtk_misc_set_alignment(GTK_MISC(labelAreaLabel), 0.0, 0.5);
- gtk_widget_show(labelAreaLabel);
- gtk_table_attach(GTK_TABLE(tableRoomData), labelAreaLabel, 0, 1, 0, 1, GTK_FILL, GTK_FILL, 0, 0);
-
- labelArea = gtk_label_new(NULL);
- gtk_misc_set_alignment(GTK_MISC(labelArea), 1.0, 0.5);
- gtk_widget_show(labelArea);
- gtk_table_attach_defaults(GTK_TABLE(tableRoomData), labelArea, 1, 2, 0, 1);
-
- GtkWidget *labelPerimeterLabel = gtk_label_new("Room perimeter: ");
- gtk_misc_set_alignment(GTK_MISC(labelPerimeterLabel), 0.0, 0.5);
- gtk_widget_show(labelPerimeterLabel);
- gtk_table_attach(GTK_TABLE(tableRoomData), labelPerimeterLabel, 0, 1, 1, 2, GTK_FILL, GTK_FILL, 0, 0);
-
- labelPerimeter = gtk_label_new(NULL);
- gtk_misc_set_alignment(GTK_MISC(labelPerimeter), 1.0, 0.5);
- gtk_widget_show(labelPerimeter);
- gtk_table_attach_defaults(GTK_TABLE(tableRoomData), labelPerimeter, 1, 2, 1, 2);
-
- GtkWidget *labelHeight = gtk_label_new("Height: ");
- gtk_misc_set_alignment(GTK_MISC(labelHeight), 0.0, 0.5);
- gtk_widget_show(labelHeight);
- gtk_table_attach(GTK_TABLE(tableRoomData), labelHeight, 0, 1, 2, 3, GTK_FILL, GTK_FILL, 0, 0);
-
- spinButtonHeight = gtk_spin_button_new_with_range(0, 10000, 0.1f);
- gtk_spin_button_set_digits(GTK_SPIN_BUTTON(spinButtonHeight), 2);
- gtk_entry_set_alignment(GTK_ENTRY(spinButtonHeight), 1.0);
- gtk_widget_show(spinButtonHeight);
- gtk_table_attach(GTK_TABLE(tableRoomData), spinButtonHeight, 1, 2, 2, 3, (GtkAttachOptions)(GTK_EXPAND|GTK_SHRINK|GTK_FILL),
- (GtkAttachOptions)(GTK_EXPAND|GTK_FILL), 0, 0);
- gtk_widget_set_size_request(spinButtonHeight, 0, -1);
- g_signal_connect(G_OBJECT(spinButtonHeight), "value-changed", G_CALLBACK(spinButtonChanged), this);
-
- tablePlayerStart = gtk_table_new(2, 4, FALSE);
- gtk_table_set_row_spacings(GTK_TABLE(tablePlayerStart), 5);
- gtk_widget_set_no_show_all(tablePlayerStart, TRUE);
- gtk_box_pack_start(GTK_BOX(sidebar), tablePlayerStart, FALSE, FALSE, 5);
-
- GtkWidget *labelCoordinates = gtk_label_new("Coordinates:");
- gtk_misc_set_alignment(GTK_MISC(labelCoordinates), 0.0, 0.5);
- gtk_widget_show(labelCoordinates);
- gtk_table_attach(GTK_TABLE(tablePlayerStart), labelCoordinates, 0, 2, 0, 1, GTK_FILL, GTK_FILL, 0, 0);
-
- GtkWidget *labelX = gtk_label_new("X: ");
- gtk_misc_set_alignment(GTK_MISC(labelX), 0.0, 0.5);
- gtk_widget_show(labelX);
- gtk_table_attach(GTK_TABLE(tablePlayerStart), labelX, 0, 1, 1, 2, GTK_FILL, GTK_FILL, 0, 0);
-
- spinButtonX = gtk_spin_button_new_with_range(-10000, 10000, 0.01f);
- gtk_spin_button_set_digits(GTK_SPIN_BUTTON(spinButtonX), 2);
- gtk_entry_set_alignment(GTK_ENTRY(spinButtonX), 1.0);
- gtk_widget_show(spinButtonX);
- gtk_table_attach(GTK_TABLE(tablePlayerStart), spinButtonX, 1, 2, 1, 2, (GtkAttachOptions)(GTK_EXPAND|GTK_SHRINK|GTK_FILL),
- (GtkAttachOptions)(GTK_EXPAND|GTK_FILL), 0, 0);
- gtk_widget_set_size_request(spinButtonX, 0, -1);
- g_signal_connect(G_OBJECT(spinButtonX), "value-changed", G_CALLBACK(spinButtonChanged), this);
-
- GtkWidget *labelY = gtk_label_new("Y: ");
- gtk_misc_set_alignment(GTK_MISC(labelY), 0.0, 0.5);
- gtk_widget_show(labelY);
- gtk_table_attach(GTK_TABLE(tablePlayerStart), labelY, 0, 1, 2, 3, GTK_FILL, GTK_FILL, 0, 0);
-
- spinButtonY = gtk_spin_button_new_with_range(-10000, 10000, 0.01f);
- gtk_spin_button_set_digits(GTK_SPIN_BUTTON(spinButtonY), 2);
- gtk_entry_set_alignment(GTK_ENTRY(spinButtonY), 1.0);
- gtk_widget_show(spinButtonY);
- gtk_table_attach(GTK_TABLE(tablePlayerStart), spinButtonY, 1, 2, 2, 3, (GtkAttachOptions)(GTK_EXPAND|GTK_SHRINK|GTK_FILL),
- (GtkAttachOptions)(GTK_EXPAND|GTK_FILL), 0, 0);
- gtk_widget_set_size_request(spinButtonY, 0, -1);
- g_signal_connect(G_OBJECT(spinButtonY), "value-changed", G_CALLBACK(spinButtonChanged), this);
-
- GtkWidget *labelZ = gtk_label_new("Z: ");
- gtk_misc_set_alignment(GTK_MISC(labelZ), 0.0, 0.5);
- gtk_widget_show(labelZ);
- gtk_table_attach(GTK_TABLE(tablePlayerStart), labelZ, 0, 1, 3, 4, GTK_FILL, GTK_FILL, 0, 0);
-
- spinButtonZ = gtk_spin_button_new_with_range(-10000, 10000, 0.01f);
- gtk_spin_button_set_digits(GTK_SPIN_BUTTON(spinButtonZ), 2);
- gtk_entry_set_alignment(GTK_ENTRY(spinButtonZ), 1.0);
- gtk_widget_show(spinButtonZ);
- gtk_table_attach(GTK_TABLE(tablePlayerStart), spinButtonZ, 1, 2, 3, 4, (GtkAttachOptions)(GTK_EXPAND|GTK_SHRINK|GTK_FILL),
- (GtkAttachOptions)(GTK_EXPAND|GTK_FILL), 0, 0);
- gtk_widget_set_size_request(spinButtonZ, 0, -1);
- g_signal_connect(G_OBJECT(spinButtonZ), "value-changed", G_CALLBACK(spinButtonChanged), this);
-
- gtk_widget_show_all(sidebar);
-}
-
-SidebarView::~SidebarView() {
- g_object_unref(G_OBJECT(sidebar));
-}
-
-GtkWidget* SidebarView::getWidget() {
- return sidebar;
-}
-
-void SidebarView::update() {
- gtk_widget_hide(labelName);
- gtk_widget_hide(entryName);
- gtk_widget_hide(tableRoomData);
- gtk_widget_hide(tablePlayerStart);
-
- if(editManager->getSelectedObject()) {
- if(editManager->getSelectedObject()->isOfType("Room")) {
- Room *room = (Room*)editManager->getSelectedObject();
-
- gtk_label_set_markup(GTK_LABEL(labelType), "<b>Room info:</b>");
-
- gtk_widget_show(labelName);
-
- gtk_entry_set_text(GTK_ENTRY(entryName), room->getName().c_str());
- gtk_widget_show(entryName);
-
- gchar *string = g_strdup_printf("%.2f", room->getPolygon().area());
- gtk_label_set_text(GTK_LABEL(labelArea), string);
- g_free(string);
-
- string = g_strdup_printf("%.2f", room->getPolygon().perimeter());
- gtk_label_set_text(GTK_LABEL(labelPerimeter), string);
- g_free(string);
-
- gtk_spin_button_set_value(GTK_SPIN_BUTTON(spinButtonHeight), room->getHeight());
-
- gtk_widget_show(tableRoomData);
- }
- else if(editManager->getSelectedObject()->isOfType("PlayerStart")) {
- PlayerStart *playerStart = (PlayerStart*)editManager->getSelectedObject();
-
- gtk_label_set_markup(GTK_LABEL(labelType), "<b>Player start:</b>");
-
- gtk_spin_button_set_value(GTK_SPIN_BUTTON(spinButtonX), playerStart->getX());
- gtk_spin_button_set_value(GTK_SPIN_BUTTON(spinButtonY), playerStart->getY());
- gtk_spin_button_set_value(GTK_SPIN_BUTTON(spinButtonZ), playerStart->getZ());
-
- gtk_widget_show(tablePlayerStart);
- }
- }
- else {
- gtk_label_set_markup(GTK_LABEL(labelType), "<b>[Nothing selected]</b>");
- }
-}