leocad/linux/dlgpiece.cpp

374 lines
11 KiB
C++
Raw Normal View History

2011-09-07 21:06:51 +00:00
//
// This file holds all the dialogs that are called
// from the 'Pieces' submenu:
//
// - Group Name
// - Edit Groups
// - Minifig Wizard
//
2012-03-23 00:53:05 +00:00
#include "lc_global.h"
2012-06-21 22:03:30 +00:00
#include "lc_colors.h"
2011-09-07 21:06:51 +00:00
#include <gtk/gtk.h>
#include <gdk/gdkkeysyms.h>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include "opengl.h"
#include "gtktools.h"
#include "system.h"
#include "typedefs.h"
#include "globals.h"
#include "dialogs.h"
#include "pieceinf.h"
#include "main.h"
#include "minifig.h"
// =========================================================
// Minifig Wizard
2012-06-21 22:03:30 +00:00
struct LC_MINIFIGDLG_STRUCT
2011-09-07 21:06:51 +00:00
{
2012-07-06 01:18:55 +00:00
MinifigWizard* wizard;
GtkWidget *pieces[LC_MFW_NUMITEMS];
GtkWidget *colors[LC_MFW_NUMITEMS];
GtkWidget *angles[LC_MFW_NUMITEMS];
GtkWidget *preview;
GtkWidget *combo;
GtkWidget *dlg;
2012-06-21 22:03:30 +00:00
};
2011-09-07 21:06:51 +00:00
// A new color was selected from the menu
2012-07-06 01:18:55 +00:00
static void minifigdlg_color_response(GtkWidget *widget, gpointer data)
2011-09-07 21:06:51 +00:00
{
2012-07-06 01:18:55 +00:00
LC_MINIFIGDLG_STRUCT* info;
GtkWidget* button;
int i;
2011-09-07 21:06:51 +00:00
2012-07-06 01:18:55 +00:00
button = (GtkWidget*)gtk_object_get_data(GTK_OBJECT(widget), "button");
info = (LC_MINIFIGDLG_STRUCT*)gtk_object_get_data(GTK_OBJECT(button), "info");
2011-09-07 21:06:51 +00:00
2012-07-06 01:18:55 +00:00
if (!info)
return;
2011-09-07 21:06:51 +00:00
2012-07-06 01:18:55 +00:00
for (i = 0; i < 15; i++)
if (info->colors[i] == button)
break;
2011-09-07 21:06:51 +00:00
2012-07-06 01:18:55 +00:00
info->wizard->SetColor(i, GPOINTER_TO_INT(data));
info->wizard->Redraw();
set_button_pixmap2(button, gColorList[GPOINTER_TO_INT(data)].Value);
2011-09-07 21:06:51 +00:00
}
// A color button was clicked
2012-07-06 01:18:55 +00:00
static void minifigdlg_color_clicked(GtkWidget *widget, gpointer data)
2011-09-07 21:06:51 +00:00
{
2012-07-06 01:18:55 +00:00
int i;
GtkWidget *menu, *menuitem;
2011-09-07 21:06:51 +00:00
2012-07-06 01:18:55 +00:00
menu = gtk_menu_new();
2011-09-07 21:06:51 +00:00
2012-07-06 01:18:55 +00:00
for (i = 0; i < gNumUserColors; i++)
{
menuitem = gtk_menu_item_new_with_label(gColorList[i].Name);
gtk_widget_show(menuitem);
gtk_menu_append(GTK_MENU(menu), menuitem);
2011-09-07 21:06:51 +00:00
2012-07-06 01:18:55 +00:00
gtk_object_set_data(GTK_OBJECT(menuitem), "button", widget);
2013-01-06 19:24:25 +00:00
gtk_signal_connect(GTK_OBJECT(menuitem), "activate", GTK_SIGNAL_FUNC(minifigdlg_color_response), GINT_TO_POINTER(i));
2012-07-06 01:18:55 +00:00
}
2011-09-07 21:06:51 +00:00
2012-07-06 01:18:55 +00:00
gtk_menu_popup(GTK_MENU(menu), NULL, NULL, NULL, NULL, 0, 0);
2011-09-07 21:06:51 +00:00
}
// New piece was selected
2012-07-06 01:18:55 +00:00
static void minifigdlg_piece_changed(GtkWidget *widget, gpointer data)
2011-09-07 21:06:51 +00:00
{
2012-07-06 01:18:55 +00:00
LC_MINIFIGDLG_STRUCT* info;
int i, piece_type = -1, piece_index = -1;
const gchar* desc;
info = (LC_MINIFIGDLG_STRUCT*)gtk_object_get_data(GTK_OBJECT(widget), "info");
if (info == NULL)
return;
for (i = 0; i < LC_MFW_NUMITEMS; i++)
if (GTK_COMBO(info->pieces[i])->entry == widget)
{
piece_type = i;
break;
}
ObjArray<lcMinifigPieceInfo>& InfoArray = info->wizard->mSettings[piece_type];
desc = gtk_entry_get_text(GTK_ENTRY(widget));
for (i = 0; i < InfoArray.GetSize(); i++)
{
if (!strcmp(InfoArray[i].Description, desc))
{
piece_index = i;
break;
}
}
2011-09-07 21:06:51 +00:00
if (piece_index == -1 || piece_type == -1)
return;
2012-07-06 01:18:55 +00:00
info->wizard->SetSelectionIndex(piece_type, piece_index);
info->wizard->Redraw();
2011-09-07 21:06:51 +00:00
}
2012-07-06 01:18:55 +00:00
static void minifigdlg_updatecombo(LC_MINIFIGDLG_STRUCT* s)
2011-09-07 21:06:51 +00:00
{
2012-07-06 01:18:55 +00:00
char **names;
int count;
GList *lst = NULL;
2011-09-07 21:06:51 +00:00
2012-07-06 01:18:55 +00:00
s->wizard->GetMinifigNames(&names, &count);
for (int i = 0; i < count; i++)
lst = g_list_append(lst, names[i]);
2011-09-07 21:06:51 +00:00
2012-07-06 01:18:55 +00:00
if (lst == NULL)
lst = g_list_append(lst, (void*)"");
2011-09-07 21:06:51 +00:00
2012-07-06 01:18:55 +00:00
gtk_combo_set_popdown_strings(GTK_COMBO(s->combo), lst);
g_list_free(lst);
2011-09-07 21:06:51 +00:00
}
2012-07-06 01:18:55 +00:00
static void minifigdlg_updateselection(LC_MINIFIGDLG_STRUCT* s)
2011-09-07 21:06:51 +00:00
{
2012-07-06 01:18:55 +00:00
for (int i = 0; i < LC_MFW_NUMITEMS; i++)
{
int index = s->wizard->GetSelectionIndex(i);
GtkCombo* Combo = GTK_COMBO(s->pieces[i]);
gtk_signal_handler_block_by_func(GTK_OBJECT(Combo->entry), GTK_SIGNAL_FUNC(minifigdlg_piece_changed), NULL);
gtk_entry_set_text(GTK_ENTRY(Combo->entry), s->wizard->mSettings[i][index].Description);
gtk_list_select_item(GTK_LIST(Combo->list), index);
gtk_signal_handler_unblock_by_func(GTK_OBJECT(Combo->entry), GTK_SIGNAL_FUNC(minifigdlg_piece_changed), NULL);
}
2011-09-07 21:06:51 +00:00
}
2012-07-06 01:18:55 +00:00
static void minifigdlg_load(GtkWidget *widget, gpointer data)
2011-09-07 21:06:51 +00:00
{
2012-07-06 01:18:55 +00:00
LC_MINIFIGDLG_STRUCT* s = (LC_MINIFIGDLG_STRUCT*)data;
if (s->wizard->LoadMinifig(gtk_entry_get_text(GTK_ENTRY(GTK_COMBO(s->combo)->entry))) == false)
return;
for (int i = 0; i < LC_MFW_NUMITEMS; i++)
{
set_button_pixmap2(s->colors[i], gColorList[s->wizard->m_Colors[i]].Value);
if (s->angles[i] != NULL)
gtk_spin_button_set_value(GTK_SPIN_BUTTON(s->angles[i]), s->wizard->m_Angles[i]);
}
minifigdlg_updateselection(s);
s->wizard->Redraw();
2011-09-07 21:06:51 +00:00
}
2012-07-06 01:18:55 +00:00
static void minifigdlg_save(GtkWidget *widget, gpointer data)
2011-09-07 21:06:51 +00:00
{
2012-07-06 01:18:55 +00:00
LC_MINIFIGDLG_STRUCT* s = (LC_MINIFIGDLG_STRUCT*)data;
s->wizard->SaveMinifig(gtk_entry_get_text(GTK_ENTRY(GTK_COMBO(s->combo)->entry)));
minifigdlg_updatecombo(s);
2011-09-07 21:06:51 +00:00
}
2012-07-06 01:18:55 +00:00
static void minifigdlg_delete(GtkWidget *widget, gpointer data)
2011-09-07 21:06:51 +00:00
{
2012-07-06 01:18:55 +00:00
LC_MINIFIGDLG_STRUCT* s = (LC_MINIFIGDLG_STRUCT*)data;
s->wizard->DeleteMinifig(gtk_entry_get_text(GTK_ENTRY(GTK_COMBO(s->combo)->entry)));
minifigdlg_updatecombo(s);
2011-09-07 21:06:51 +00:00
}
2012-07-06 01:18:55 +00:00
static void adj_changed(GtkAdjustment *adj, gpointer data)
2011-09-07 21:06:51 +00:00
{
2012-07-06 01:18:55 +00:00
LC_MINIFIGDLG_STRUCT* info = (LC_MINIFIGDLG_STRUCT*)data;
float val;
int i;
2011-09-07 21:06:51 +00:00
2012-07-06 01:18:55 +00:00
for (i = 0; i < LC_MFW_NUMITEMS; i++)
if (info->angles[i] != NULL)
if (gtk_spin_button_get_adjustment(GTK_SPIN_BUTTON(info->angles[i])) == adj)
break;
2011-09-07 21:06:51 +00:00
2012-07-06 01:18:55 +00:00
if (i == LC_MFW_NUMITEMS)
return;
2011-09-07 21:06:51 +00:00
2012-07-06 01:18:55 +00:00
val = gtk_spin_button_get_value_as_float(GTK_SPIN_BUTTON(info->angles[i]));
2011-09-07 21:06:51 +00:00
2012-07-06 01:18:55 +00:00
if (val == info->wizard->m_Angles[i])
return;
2011-09-07 21:06:51 +00:00
2012-07-06 01:18:55 +00:00
info->wizard->SetAngle(i, val);
2011-09-07 21:06:51 +00:00
2012-07-06 01:18:55 +00:00
if (info->preview != NULL)
info->wizard->Redraw();
2011-09-07 21:06:51 +00:00
}
// Create a combo box with a color selection control
2012-07-06 01:18:55 +00:00
static void minifigdlg_createpair(LC_MINIFIGDLG_STRUCT* info, int idx, int num, GtkWidget* table)
2011-09-07 21:06:51 +00:00
{
2012-07-06 01:18:55 +00:00
GtkWidget *combo, *color, *spin;
GtkObject *adj;
combo = info->pieces[num] = gtk_combo_new();
gtk_widget_show(combo);
gtk_table_attach(GTK_TABLE(table), combo, 0, 1, idx, idx+1,
(GtkAttachOptions) (GTK_EXPAND | GTK_FILL), (GtkAttachOptions) GTK_EXPAND, 0, 0);
gtk_entry_set_editable(GTK_ENTRY(GTK_COMBO(combo)->entry), FALSE);
gtk_signal_connect(GTK_OBJECT(GTK_COMBO(combo)->entry), "changed", GTK_SIGNAL_FUNC(minifigdlg_piece_changed), NULL);
gtk_object_set_data(GTK_OBJECT(GTK_COMBO(combo)->entry), "info", info);
color = info->colors[num] = gtk_button_new_with_label("");
gtk_widget_set_events(color, GDK_EXPOSURE_MASK);
gtk_widget_show(color);
gtk_object_set_data(GTK_OBJECT(color), "color", &info->wizard->m_Colors[num]);
gtk_object_set_data(GTK_OBJECT(color), "info", info);
gtk_widget_set_usize(color, 40, 25);
gtk_signal_connect(GTK_OBJECT(color), "clicked", GTK_SIGNAL_FUNC(minifigdlg_color_clicked), info);
gtk_table_attach(GTK_TABLE(table), color, 1, 2, idx, idx+1, (GtkAttachOptions) GTK_FILL, (GtkAttachOptions) GTK_EXPAND, 0, 0);
2012-07-21 00:31:21 +00:00
if ((num == LC_MFW_BODY) || (num == LC_MFW_BODY2) || (num == LC_MFW_BODY3))
2012-07-06 01:18:55 +00:00
{
info->angles[num] = NULL;
return;
}
adj = gtk_adjustment_new(0, -180, 180, 1, 10, 0);
gtk_signal_connect(adj, "value_changed", GTK_SIGNAL_FUNC(adj_changed), info);
spin = info->angles[num] = gtk_spin_button_new(GTK_ADJUSTMENT(adj), 1, 0);
gtk_widget_show(spin);
gtk_object_set_data(GTK_OBJECT(color), "info", info);
gtk_table_attach(GTK_TABLE(table), spin, 2, 3, idx, idx+1, (GtkAttachOptions) GTK_FILL, (GtkAttachOptions) GTK_EXPAND, 0, 0);
gtk_spin_button_set_wrap(GTK_SPIN_BUTTON(spin), TRUE);
gtk_spin_button_set_numeric(GTK_SPIN_BUTTON(spin), TRUE);
gtk_entry_set_width_chars(GTK_ENTRY(spin), 4);
2011-09-07 21:06:51 +00:00
}
2012-07-06 01:18:55 +00:00
int minifigdlg_execute(void* param)
2011-09-07 21:06:51 +00:00
{
2012-07-06 01:18:55 +00:00
GtkWidget *vbox, *hbox, *frame, *table;
GtkWidget *dlg, *button;
LC_MINIFIGDLG_STRUCT s;
int i;
int ret;
memset(&s, 0, sizeof(s));
s.wizard = (MinifigWizard*)param;
dlg = gtk_dialog_new_with_buttons("Minifig Wizard", GTK_WINDOW(((GtkWidget*)(*main_window))),
(GtkDialogFlags)(GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT),
GTK_STOCK_OK, GTK_RESPONSE_OK, GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL, NULL);
gtk_container_set_border_width(GTK_CONTAINER(dlg), 5);
gtk_widget_realize(dlg);
s.dlg = dlg;
vbox = GTK_DIALOG(dlg)->vbox;
gtk_box_set_spacing(GTK_BOX(vbox), 10);
hbox = gtk_hbox_new(FALSE, 5);
gtk_widget_show(hbox);
gtk_box_pack_start(GTK_BOX(vbox), hbox, TRUE, TRUE, 0);
2012-07-21 00:31:21 +00:00
table = gtk_table_new(9, 3, FALSE);
2012-07-06 01:18:55 +00:00
gtk_widget_show(table);
gtk_box_pack_start(GTK_BOX(hbox), table, TRUE, TRUE, 0);
gtk_table_set_col_spacings(GTK_TABLE(table), 5);
gtk_table_set_row_spacings(GTK_TABLE(table), 5);
2012-07-21 00:31:21 +00:00
minifigdlg_createpair(&s, 0, LC_MFW_HATS, table);
minifigdlg_createpair(&s, 1, LC_MFW_HATS2, table);
minifigdlg_createpair(&s, 2, LC_MFW_NECK, table);
minifigdlg_createpair(&s, 3, LC_MFW_LARM, table);
minifigdlg_createpair(&s, 4, LC_MFW_LHAND, table);
minifigdlg_createpair(&s, 5, LC_MFW_LHANDA, table);
minifigdlg_createpair(&s, 6, LC_MFW_BODY2, table);
minifigdlg_createpair(&s, 7, LC_MFW_LLEG, table);
minifigdlg_createpair(&s, 8, LC_MFW_LLEGA, table);
2012-07-06 01:18:55 +00:00
s.wizard->CreateFromWindow(&s.preview);
frame = gtk_frame_new(NULL);
gtk_widget_show(frame);
gtk_container_add(GTK_CONTAINER(hbox), frame);
gtk_frame_set_shadow_type(GTK_FRAME(frame), GTK_SHADOW_IN);
gtk_widget_set_usize(GTK_WIDGET(s.preview), 150, 300);
gtk_container_add(GTK_CONTAINER(frame), GTK_WIDGET(s.preview));
gtk_widget_show(GTK_WIDGET(s.preview));
gtk_object_set_data(GTK_OBJECT(s.preview), "minifig", &s);
2012-07-21 00:31:21 +00:00
table = gtk_table_new(8, 3, FALSE);
2012-07-06 01:18:55 +00:00
gtk_widget_show(table);
gtk_box_pack_start(GTK_BOX(hbox), table, TRUE, TRUE, 0);
gtk_table_set_col_spacings(GTK_TABLE(table), 5);
gtk_table_set_row_spacings(GTK_TABLE(table), 5);
minifigdlg_createpair(&s, 0, LC_MFW_HEAD, table);
2012-07-21 00:31:21 +00:00
minifigdlg_createpair(&s, 1, LC_MFW_BODY, table);
minifigdlg_createpair(&s, 2, LC_MFW_RARM, table);
minifigdlg_createpair(&s, 3, LC_MFW_RHAND, table);
minifigdlg_createpair(&s, 4, LC_MFW_RHANDA, table);
minifigdlg_createpair(&s, 5, LC_MFW_BODY3, table);
minifigdlg_createpair(&s, 6, LC_MFW_RLEG, table);
minifigdlg_createpair(&s, 7, LC_MFW_RLEGA, table);
2012-07-06 01:18:55 +00:00
hbox = gtk_hbox_new(FALSE, 10);
gtk_widget_show(hbox);
gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, TRUE, 0);
gtk_container_set_border_width(GTK_CONTAINER(hbox), 5);
s.combo = gtk_combo_new();
gtk_widget_show(s.combo);
gtk_box_pack_start(GTK_BOX(hbox), s.combo, FALSE, TRUE, 0);
gtk_signal_connect(GTK_OBJECT(GTK_COMBO(s.combo)->entry), "changed", GTK_SIGNAL_FUNC(minifigdlg_load), &s);
button = gtk_button_new_with_label("Save");
gtk_signal_connect(GTK_OBJECT(button), "clicked", GTK_SIGNAL_FUNC(minifigdlg_save), &s);
gtk_widget_show(button);
gtk_box_pack_start(GTK_BOX(hbox), button, FALSE, TRUE, 0);
button = gtk_button_new_with_label("Delete");
gtk_signal_connect(GTK_OBJECT(button), "clicked", GTK_SIGNAL_FUNC(minifigdlg_delete), &s);
gtk_widget_show(button);
gtk_box_pack_start(GTK_BOX(hbox), button, FALSE, TRUE, 0);
// Fill the combo boxes with the available pieces
for (i = 0; i < LC_MFW_NUMITEMS; i++)
{
GList* names = NULL;
int count = s.wizard->mSettings[i].GetSize();
for (int j = 0; j < count; j++)
names = g_list_append(names, s.wizard->mSettings[i][j].Description);
if (names != NULL)
{
gtk_signal_handler_block_by_func(GTK_OBJECT(GTK_COMBO(s.pieces[i])->entry), GTK_SIGNAL_FUNC(minifigdlg_piece_changed), NULL);
gtk_combo_set_popdown_strings(GTK_COMBO(s.pieces[i]), names);
g_list_free(names);
gtk_signal_handler_unblock_by_func(GTK_OBJECT(GTK_COMBO(s.pieces[i])->entry), GTK_SIGNAL_FUNC(minifigdlg_piece_changed), NULL);
}
}
2012-07-21 00:31:21 +00:00
gtk_widget_show(dlg);
2012-07-06 01:18:55 +00:00
minifigdlg_updatecombo(&s);
minifigdlg_updateselection(&s);
for (i = 0; i < LC_MFW_NUMITEMS; i++)
set_button_pixmap2(s.colors[i], gColorList[s.wizard->m_Colors[i]].Value);
if (gtk_dialog_run(GTK_DIALOG(dlg)) == GTK_RESPONSE_OK)
{
ret = LC_OK;
}
else
ret = LC_CANCEL;
gtk_widget_destroy(dlg);
return ret;
2011-09-07 21:06:51 +00:00
}
2012-07-06 01:18:55 +00:00