view src/rootvis/config_frontend_widgets.c @ 3191:a65f440cbed3

alsa-ng: Fix possible race conditions, sluggish pause and seek.
author John Lindgren <john.lindgren@tds.net>
date Mon, 22 Jun 2009 16:05:57 -0400
parents 31e6845e722a
children
line wrap: on
line source

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#include <gtk/gtk.h>
#include <config_frontend.h>

extern void print_status(char msg[]);

void frontend_set_signal(GtkWidget *widget, char* signal, void* func, int data)
{
	gtk_signal_connect(GTK_OBJECT(widget),	signal,	GTK_SIGNAL_FUNC(func),	GINT_TO_POINTER(data));
}

GtkWidget *frontend_create_window(int type, char *name)
{
	GtkWidget *window;

	print_status("creating window");
	print_status(name);
  	window = gtk_window_new(type);
	gtk_signal_connect(GTK_OBJECT(window),
				"delete-event",
				GTK_SIGNAL_FUNC(signal_window_close),
				NULL);

	print_status("setting title");
	gtk_window_set_title(GTK_WINDOW(window), name);
	print_status("done");
	gtk_widget_show(window);
	return window;
}

GtkWidget *frontend_create_box(int box_type, GtkWidget *container, char *label,
				int attach)
{
	GtkWidget *box;

	print_status("creating box");
	print_status(label);



	switch (box_type) {
	case VBOX:
		box = gtk_vbox_new(FALSE, 5);
		gtk_container_set_border_width(GTK_CONTAINER(box), 5);
		break;

	case HBOX:
		box = gtk_hbox_new(FALSE, 5);
		gtk_container_set_border_width(GTK_CONTAINER(box), 5);
		break;
	case HBBOX:
		box = gtk_hbutton_box_new();
		gtk_button_box_set_layout(GTK_BUTTON_BOX(box),
					  GTK_BUTTONBOX_END);
		gtk_button_box_set_spacing(GTK_BUTTON_BOX(box), 5);
		break;
	case HBBOX2:
		box = gtk_hbutton_box_new();
		gtk_button_box_set_layout(GTK_BUTTON_BOX(box),
					  GTK_BUTTONBOX_EDGE);
		gtk_button_box_set_spacing(GTK_BUTTON_BOX(box), 4);
		break;
	case FRAME:
		box = gtk_frame_new(label);
		gtk_container_set_border_width(GTK_CONTAINER(box), 5);
		break;
	default:
		print_status("error");
		print_status("trying to create vbox");
		box = gtk_vbox_new(FALSE, 5);
		gtk_container_set_border_width(GTK_CONTAINER(box), 5);
	}

	print_status("attaching");
	switch (attach) {
	case ATTACH_TO_NOTEBOOK:
		gtk_notebook_append_page(GTK_NOTEBOOK(container),
					 box, gtk_label_new(label));
		break;

	case ATTACH_TO_CONTAINER:
		gtk_container_add(GTK_CONTAINER(container), box);
		break;
	case ATTACH_TO_BOX:
		gtk_box_pack_start(GTK_BOX(container), box, TRUE, TRUE, 0);
		break;
	default:
		print_status("error");
		print_status("trying to attach to container");
		gtk_container_add(GTK_CONTAINER(container), box);
	}
	gtk_widget_show(box);
	print_status("done");
	return box;
}

GtkWidget *frontend_create_notebook(GtkWidget *box)
{
	GtkWidget *notebook;

	print_status("creating notebook");
	notebook = gtk_notebook_new();
	gtk_box_pack_start(GTK_BOX(box), notebook, TRUE, TRUE, 0);
	gtk_widget_show(notebook);
	return notebook;
}

GtkWidget *frontend_create_button(GtkWidget *container, char *label)
{
	GtkWidget *button;

	print_status("adding button");
	print_status(label);

	button = gtk_button_new_with_label(label);
	gtk_widget_show(button);

	GTK_WIDGET_SET_FLAGS(button, GTK_CAN_DEFAULT);
	gtk_box_pack_start(GTK_BOX(container), button, TRUE, TRUE, 0);

	return button;
}

GtkWidget *frontend_create_check(GtkWidget *container, char *label)
{
	GtkWidget *check;

	print_status("creating check");
	print_status(label);

	check = gtk_check_button_new_with_label(label);
	gtk_widget_show(check);

	gtk_container_add(GTK_CONTAINER(container), check);

	print_status("done");
	return check;
}

GtkWidget *frontend_create_label(GtkWidget *container, char *text)
{
	GtkWidget *label;

	print_status("creating label");
	print_status(text);

	label = gtk_label_new(text);
	gtk_label_set_justify(GTK_LABEL(label), GTK_JUSTIFY_CENTER);
	gtk_label_set_line_wrap(GTK_LABEL(label), TRUE);
	gtk_widget_show(label);

	gtk_container_add(GTK_CONTAINER(container), label);

	print_status("done");
	return label;
}

/*
GtkWidget *rootvis_create_frame_and_attach(char *name, GtkWidget *box)
{
	GtkWidget *frame;

	frame = gtk_frame_new(name);
	gtk_container_set_border_width(GTK_CONTAINER(frame), 5);
	gtk_box_pack_start(GTK_BOX(box), frame, TRUE, TRUE, 0);
	gtk_widget_show(frame);
	return frame;
}
*/

GtkWidget *frontend_create_entry(int type, GtkWidget *container,
					char *entry_changed,
					char *label, ...)
{
	va_list ap;
	char *list_element;
	char *signal;

	GtkWidget *entry;
	GList *list = NULL;

	print_status("creating entry");
	print_status(label);

	va_start(ap, label);
	switch (type) {
	case COMBO:
		entry = gtk_combo_new();
		while ((list_element = va_arg(ap, char *))) {
			print_status("adding element to list");
			print_status(list_element);
			list = g_list_append(list, list_element);
		}
		print_status("attaching string list to combo");
		gtk_combo_set_popdown_strings(GTK_COMBO(entry), list);
		break;
	case ENTRY:
		entry = gtk_entry_new();
		gtk_entry_set_max_length(GTK_ENTRY(entry), 6);
		while ((signal = va_arg(ap, char *))) {
			print_status("adding signal to entry");
			print_status(signal);
			gtk_signal_connect(GTK_OBJECT(entry),
					   /* signal */
					   signal,
					   /* function */
					   GTK_SIGNAL_FUNC(va_arg(ap,
								  void *)),
					   /* data */
					   va_arg(ap, char *));
		}
		break;
	default:
		return NULL;
	}
	va_end(ap);

	print_status("attaching entry to container");
	gtk_container_add(GTK_CONTAINER(container), entry);
	gtk_widget_show(entry);

	print_status("done");

	return entry;
}

void frontend_create_colorpicker(struct config_value *cvar)
{
	struct rootvis_colorsel* colorsel = cvar->valc.frontend;
	GtkWidget *vbox;
	GtkWidget *options_frame, *options_vbox;

	static GtkWidget *bbox, *ok, *cancel;

	print_status("pressing button ... ");
	gtk_button_set_relief(GTK_BUTTON(colorsel->button), GTK_RELIEF_HALF);


	print_status("casting window ...");

	colorsel->window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
	gtk_window_set_title(GTK_WINDOW(colorsel->window), colorsel->complete_name);

	gtk_container_set_border_width(GTK_CONTAINER(colorsel->window), 10);
	gtk_window_set_policy(GTK_WINDOW(colorsel->window), FALSE, FALSE, FALSE);
	gtk_window_set_position(GTK_WINDOW(colorsel->window),
				GTK_WIN_POS_MOUSE);
	gtk_signal_connect(GTK_OBJECT(colorsel->window), "destroy",
			   GTK_SIGNAL_FUNC(gtk_widget_destroyed),
			   &(colorsel->window));

	vbox = gtk_vbox_new(FALSE, 5);

	printf("setting name ...");
	options_frame = gtk_frame_new(colorsel->complete_name);
	printf("done. \n");
	gtk_container_set_border_width(GTK_CONTAINER(options_frame), 5);

	options_vbox = gtk_vbox_new(FALSE, 5);
	gtk_container_set_border_width(GTK_CONTAINER(options_vbox), 5);

	colorsel->color_picker = gtk_color_selection_new();
	gtk_color_selection_set_has_opacity_control(GTK_COLOR_SELECTION(colorsel->color_picker), TRUE);
	gtk_color_selection_set_color(GTK_COLOR_SELECTION(colorsel->color_picker), colorsel->color);
	gtk_signal_connect(GTK_OBJECT(colorsel->color_picker), "color_changed", GTK_SIGNAL_FUNC(signal_colorselector_update), cvar);

	gtk_box_pack_start(GTK_BOX(options_vbox), colorsel->color_picker,
			   FALSE, FALSE, 0);
        gtk_widget_show(colorsel->color_picker);
	printf("raising the curtain \n");

	gtk_container_add(GTK_CONTAINER(options_frame), options_vbox);
	gtk_widget_show(options_vbox);

	gtk_box_pack_start(GTK_BOX(vbox), options_frame, TRUE, TRUE, 0);
	gtk_widget_show(options_frame);

	bbox = gtk_hbutton_box_new();
	gtk_button_box_set_layout(GTK_BUTTON_BOX(bbox), GTK_BUTTONBOX_END);
	gtk_button_box_set_spacing(GTK_BUTTON_BOX(bbox), 5);
	gtk_box_pack_start(GTK_BOX(vbox), bbox, FALSE, FALSE, 0);

	ok = gtk_button_new_with_label("Ok");
	gtk_signal_connect(GTK_OBJECT(ok), "clicked", GTK_SIGNAL_FUNC(signal_colorselector_ok), cvar);
        GTK_WIDGET_SET_FLAGS(ok, GTK_CAN_DEFAULT);
	gtk_box_pack_start(GTK_BOX(bbox), ok, TRUE, TRUE, 0);
	gtk_widget_show(ok);


	cancel = gtk_button_new_with_label("Cancel");
	gtk_signal_connect(GTK_OBJECT(cancel), "clicked", GTK_SIGNAL_FUNC(signal_colorselector_cancel), cvar);
	GTK_WIDGET_SET_FLAGS(cancel, GTK_CAN_DEFAULT);
	gtk_box_pack_start(GTK_BOX(bbox), cancel, TRUE, TRUE, 0);
	gtk_widget_show(cancel);
	gtk_widget_show(bbox);

	gtk_container_add(GTK_CONTAINER(colorsel->window), vbox);
	gtk_widget_show(vbox);
	gtk_widget_grab_default(ok);
}

void frontend_create_color_button(struct config_value* cvar, GtkWidget *container, char *name,
				  char *channel_name)
{
	struct rootvis_colorsel *color_struct;

	print_status("Allocating memory for color struct");
	color_struct = malloc(sizeof(struct rootvis_colorsel));
	cvar->valc.frontend = color_struct;

	frontend_set_color(cvar);
	color_struct->window = NULL;
	color_struct->name = name; //complete_name;

	print_status("reallocating name");
	color_struct->complete_name =
	  malloc((sizeof(name) + sizeof(channel_name) + 10)*sizeof(char));
	print_status("done");
	sprintf(color_struct->complete_name, "%s - %s", channel_name, name);
	print_status("done");


	char* labeltext = (char*)malloc(strlen(name) + 2);
	sprintf(labeltext, "%s:", name);
	color_struct->label = gtk_label_new(labeltext);
	gtk_container_add(GTK_CONTAINER(container), GTK_WIDGET(color_struct->label));

	color_struct->button = gtk_button_new();
	print_status("adding container ... ");
	gtk_container_add(GTK_CONTAINER(container), GTK_WIDGET(color_struct->button));
	print_status("done.\nraising ... ");

	print_status("done.\nmaking preview ... ");

	color_struct->preview = gtk_preview_new(GTK_PREVIEW_COLOR);
	print_status("done.\nsetting size ... ");
	gtk_preview_size(GTK_PREVIEW(color_struct->preview), 30, 28);
	print_status("done.\nraising ... ");
	print_status("done.\n");
	gtk_container_add(GTK_CONTAINER(color_struct->button), color_struct->preview);

	gtk_widget_set_usize(color_struct->button, 32, 26);

	gtk_signal_connect(GTK_OBJECT(color_struct->button), "clicked",
				GTK_SIGNAL_FUNC(signal_toggle_colorselector), cvar);

	frontend_update_color(cvar, 0);
	gtk_widget_show(GTK_WIDGET(color_struct->label));
	gtk_widget_show(GTK_WIDGET(color_struct->button));
	gtk_widget_show(color_struct->preview);
}

GtkWidget *frontend_create_channel(int channel)
{
	GtkWidget *window;
	char name[12];

	print_status("creating gtk window ... ");

	sprintf(name, "Channel %d", channel+1);
	print_status(name);

	print_status("debug 2");

	window = frontend_create_window(GTK_WINDOW_TOPLEVEL, name);

	print_status("done.");

	{
		GtkWidget *vbox_0, *notebook_1, *button_box_1,
			*vbox_2[4], *frame_3[4], *hbox_4[5],
			*close_button, *revert_button;

		vbox_0 = frontend_create_box(VBOX, window, "rootvis_config_vbox", ATTACH_TO_CONTAINER);
		{

			notebook_1 = frontend_create_notebook(vbox_0);
			{
			/*	vbox_2[0] = frontend_create_box(VBOX, notebook_1, "General", ATTACH_TO_NOTEBOOK);
				{
				}
				vbox_2[1] = frontend_create_box(VBOX, notebook_1, "Geometry", ATTACH_TO_NOTEBOOK);
				{
				}
				vbox_2[2] = frontend_create_box(VBOX, notebook_1, "Look & Feel", ATTACH_TO_NOTEBOOK);
				{
				}*/
				vbox_2[3] = frontend_create_box(VBOX, notebook_1, "Colors", ATTACH_TO_NOTEBOOK);
				{
					frame_3[0] = frontend_create_box(FRAME, vbox_2[3], "Gradient", ATTACH_TO_BOX);
					hbox_4[0] = frontend_create_box(HBOX, frame_3[0], "Bar", ATTACH_TO_CONTAINER);
					{
						frontend_create_color_button(&Cchannel[channel].def[11], hbox_4[0], "Begin", name);
						frontend_create_color_button(&Cchannel[channel].def[12], hbox_4[0], "2/5", name);
						frontend_create_color_button(&Cchannel[channel].def[13], hbox_4[0], "4/5", name);
						frontend_create_color_button(&Cchannel[channel].def[14], hbox_4[0], "End", name);
					}
					frame_3[1] = frontend_create_box(FRAME, vbox_2[3], "Bevel, Peaks & Shadow", ATTACH_TO_BOX);
					hbox_4[1] = frontend_create_box(HBOX, frame_3[1], "etc", ATTACH_TO_CONTAINER);
					{
						frontend_create_color_button(&Cchannel[channel].def[15], hbox_4[1], "Bevel", name);
						frontend_create_color_button(&Cchannel[channel].def[20], hbox_4[1], "Peaks", name);
						frontend_create_color_button(&Cchannel[channel].def[16], hbox_4[1], "Shadow", name);
					}
				}
			}


			button_box_1 = frontend_create_box(HBBOX2, vbox_0, "Button Box", ATTACH_TO_BOX);
			{
				revert_button = frontend_create_button(button_box_1, "Revert");
				frontend_set_signal(revert_button, "clicked", signal_revert, channel);
				close_button = frontend_create_button(button_box_1, "Close");
				frontend_set_signal(close_button, "clicked", signal_hide, channel);
			}
		}
	}
	config_set_widgets(channel);
	return window;
}

GtkWidget *frontend_create_main(void)
{
	GtkWidget *window, *channel_button[2],
		  *button_box[2], *channels_frame, *main_frame, *vbox,
		  *main_vbox, *channel_vbox[2],
		  *save_button, *revert_button, *close_button;

	window = frontend_create_window(GTK_WINDOW_TOPLEVEL, "Main");
	{
	 vbox = frontend_create_box(VBOX, window, "vbox", ATTACH_TO_CONTAINER);
	 {
	  main_frame = frontend_create_box(FRAME, vbox, "Global Settings", ATTACH_TO_BOX);
	  {
	   main_vbox = frontend_create_box(VBOX, main_frame, "main_hbox",
					ATTACH_TO_CONTAINER);

		widgets.stereo_check = frontend_create_check(main_vbox, "stereo support");
		frontend_set_signal(widgets.stereo_check, "toggled", signal_stereo_toggled, 0);
		widgets.debug_check = frontend_create_check(main_vbox, "debug messages (stdout)");
		frontend_set_signal(widgets.debug_check, "toggled", signal_check_toggled, 0);

	  }
	  channels_frame = frontend_create_box(FRAME, vbox, "Channel-specific",
					     ATTACH_TO_BOX);
	  {
	   button_box[0] = frontend_create_box(HBOX, channels_frame, "Main Button Box",
					 ATTACH_TO_CONTAINER);
	   {
	    channel_vbox[0] = frontend_create_box(VBOX, button_box[0], "channel_vbox_0",
					ATTACH_TO_CONTAINER);
	    {
		channel_button[0] = frontend_create_button(channel_vbox[0], "First Channel");
		frontend_set_signal(channel_button[0], "clicked", signal_show, 0);
		widgets.stereo_status[0] = frontend_create_label(channel_vbox[0], "renders both channels");
	    }
	    channel_vbox[1] = frontend_create_box(VBOX, button_box[0], "channel_vbox_0",
					ATTACH_TO_CONTAINER);
	    {

		channel_button[1] = frontend_create_button(channel_vbox[1], "Second Channel");
		frontend_set_signal(channel_button[1], "clicked", signal_show, 1);
		widgets.stereo_status[1] = frontend_create_label(channel_vbox[1], "unused / inactive");
	    }
	   }
	  }
  	  button_box[1] = frontend_create_box(HBBOX, vbox, "Button Box", ATTACH_TO_BOX);
	  {

		revert_button = frontend_create_button(button_box[1], "Revert All");
		frontend_set_signal(revert_button, "clicked", signal_revert, 2);
		save_button = frontend_create_button(button_box[1], "Save Settings");
		frontend_set_signal(save_button, "clicked", signal_save, 2);
		close_button = frontend_create_button(button_box[1], "Close Windows");
		frontend_set_signal(close_button, "clicked", signal_hide, 2);

	  }
	 }
	}
	config_set_widgets(2);
	return window;
}