mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-04 06:29:31 +00:00
74f8050844
Original commit message from CVS: Major cleanup of the latest ghostpad changes. Fixed everything that broke, correctly. Someone will want to go update the API doc templates.
274 lines
7.3 KiB
C
274 lines
7.3 KiB
C
/* Gnome-Streamer
|
|
* Copyright (C) <1999> Erik Walthinsen <omega@cse.ogi.edu>
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Library General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Library General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Library General Public
|
|
* License along with this library; if not, write to the
|
|
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
* Boston, MA 02111-1307, USA.
|
|
*/
|
|
|
|
|
|
#include <gnome.h>
|
|
#include <gst/gst.h>
|
|
|
|
#include <sys/stat.h>
|
|
#include <unistd.h>
|
|
|
|
#include "gsteditorpalette.h"
|
|
#include "gsteditorimage.h"
|
|
|
|
/* class functions */
|
|
static void gst_editor_palette_class_init(GstEditorPaletteClass *klass);
|
|
static void gst_editor_palette_init(GstEditorPalette *palette);
|
|
static void gst_editor_palette_set_arg(GtkObject *object,GtkArg *arg,guint id);
|
|
static void gst_editor_palette_get_arg(GtkObject *object,GtkArg *arg,guint id);
|
|
|
|
static void gst_editor_palette_make(GstEditorPalette *palette);
|
|
|
|
struct _palette_entry {
|
|
gchar *tooltip;
|
|
GtkType (*type) (void);
|
|
gchar *factoryname;
|
|
};
|
|
|
|
#define CORE_ELEMENT_SIZE 3
|
|
struct _palette_entry _palette_contents_core[CORE_ELEMENT_SIZE] = {
|
|
{"Bin", gst_bin_get_type, "bin" },
|
|
{"Thread", gst_thread_get_type, "thread" },
|
|
{"Pipeline", gst_pipeline_get_type, "pipeline" },
|
|
};
|
|
|
|
enum {
|
|
ARG_0,
|
|
};
|
|
|
|
enum {
|
|
SIGNAL_ELEMENT_SELECTED,
|
|
SIGNAL_IN_SELECTION_MODE,
|
|
LAST_SIGNAL
|
|
};
|
|
|
|
static GtkObjectClass *parent_class;
|
|
static guint gst_editor_palette_signals[LAST_SIGNAL] = { 0 };
|
|
|
|
GtkType
|
|
gst_editor_palette_get_type (void)
|
|
{
|
|
static GtkType palette_type = 0;
|
|
|
|
if (!palette_type) {
|
|
static const GtkTypeInfo palette_info = {
|
|
"GstEditorPalette",
|
|
sizeof(GstEditorPalette),
|
|
sizeof(GstEditorPaletteClass),
|
|
(GtkClassInitFunc)gst_editor_palette_class_init,
|
|
(GtkObjectInitFunc)gst_editor_palette_init,
|
|
NULL,
|
|
NULL,
|
|
(GtkClassInitFunc)NULL,
|
|
};
|
|
palette_type = gtk_type_unique(gtk_object_get_type(),&palette_info);
|
|
}
|
|
return palette_type;
|
|
}
|
|
|
|
static void
|
|
gst_editor_palette_class_init (GstEditorPaletteClass *klass)
|
|
{
|
|
GtkObjectClass *object_class;
|
|
|
|
object_class = (GtkObjectClass*)klass;
|
|
|
|
parent_class = gtk_type_class(gtk_object_get_type());
|
|
|
|
gst_editor_palette_signals[SIGNAL_ELEMENT_SELECTED] =
|
|
gtk_signal_new("element_selected",GTK_RUN_FIRST,object_class->type,
|
|
GTK_SIGNAL_OFFSET(GstEditorPaletteClass,element_selected),
|
|
gtk_marshal_NONE__INT,GTK_TYPE_NONE,1,
|
|
GTK_TYPE_INT);
|
|
|
|
gst_editor_palette_signals[SIGNAL_IN_SELECTION_MODE] =
|
|
gtk_signal_new("in_selection_mode",GTK_RUN_FIRST,object_class->type,
|
|
GTK_SIGNAL_OFFSET(GstEditorPaletteClass,in_selection_mode),
|
|
gtk_marshal_NONE__INT,GTK_TYPE_NONE,1,
|
|
GTK_TYPE_INT);
|
|
|
|
gtk_object_class_add_signals(object_class,gst_editor_palette_signals,LAST_SIGNAL);
|
|
|
|
object_class->set_arg = gst_editor_palette_set_arg;
|
|
object_class->get_arg = gst_editor_palette_get_arg;
|
|
}
|
|
|
|
static void
|
|
gst_editor_palette_init (GstEditorPalette *palette)
|
|
{
|
|
palette->tooltips = gtk_tooltips_new();
|
|
}
|
|
|
|
typedef struct {
|
|
GstEditorPalette *palette;
|
|
GModule *symbols;
|
|
} connect_struct;
|
|
|
|
/* we need more control here so... */
|
|
static void
|
|
gst_editor_palette_connect_func (const gchar *handler_name,
|
|
GtkObject *object,
|
|
const gchar *signal_name,
|
|
const gchar *signal_data,
|
|
GtkObject *connect_object,
|
|
gboolean after,
|
|
gpointer user_data)
|
|
{
|
|
GtkSignalFunc func;
|
|
connect_struct *data = (connect_struct *)user_data;
|
|
|
|
if (!g_module_symbol(data->symbols, handler_name, (gpointer *)&func))
|
|
g_warning("gsteditorpalette: could not find signal handler '%s'.", handler_name);
|
|
else {
|
|
if (after)
|
|
gtk_signal_connect_after(object, signal_name, func, (gpointer) data->palette);
|
|
else
|
|
gtk_signal_connect(object, signal_name, func, (gpointer) data->palette);
|
|
}
|
|
}
|
|
|
|
GstEditorPalette*
|
|
gst_editor_palette_new()
|
|
{
|
|
GstEditorPalette *palette;
|
|
GtkWidget *palette_window;
|
|
connect_struct data;
|
|
GModule *symbols;
|
|
struct stat statbuf;
|
|
|
|
palette = GST_EDITOR_PALETTE(gtk_type_new(GST_TYPE_EDITOR_PALETTE));
|
|
|
|
symbols = g_module_open(NULL, 0);
|
|
|
|
data.palette = palette;
|
|
data.symbols = symbols;
|
|
|
|
if (stat(DATADIR"editor.glade", &statbuf) == 0) {
|
|
palette->xml = glade_xml_new(DATADIR"editor.glade", "palette_window");
|
|
}
|
|
else {
|
|
palette->xml = glade_xml_new ("editor.glade", "palette_window");
|
|
}
|
|
g_assert (palette->xml != NULL);
|
|
|
|
glade_xml_signal_autoconnect_full (palette->xml, gst_editor_palette_connect_func, &data);
|
|
|
|
palette_window = glade_xml_get_widget(palette->xml, "palette_window");
|
|
gtk_widget_show(palette_window);
|
|
|
|
palette->table = gtk_table_new(1, 4, TRUE);
|
|
|
|
gst_editor_palette_make(palette);
|
|
|
|
return palette;
|
|
}
|
|
|
|
typedef struct {
|
|
GstEditorPalette *palette;
|
|
struct _palette_entry *entry;
|
|
} _signal_data;
|
|
|
|
static void
|
|
gst_editor_palette_element_clicked(GtkButton *button, _signal_data *data)
|
|
{
|
|
GstElementFactory *factory;
|
|
|
|
factory = gst_elementfactory_find (data->entry->factoryname);
|
|
|
|
gtk_signal_emit(GTK_OBJECT(data->palette),gst_editor_palette_signals[SIGNAL_ELEMENT_SELECTED], factory);
|
|
}
|
|
|
|
static void
|
|
gst_editor_palette_make (GstEditorPalette *palette)
|
|
{
|
|
GtkWidget *button;
|
|
GstEditorImage *editimage;
|
|
GtkWidget *image;
|
|
GtkWidget *vbox;
|
|
gint i, x, y;
|
|
_signal_data *data;
|
|
|
|
x=0;
|
|
y=0;
|
|
|
|
vbox = glade_xml_get_widget(palette->xml, "palette_vbox");
|
|
gtk_box_pack_start(GTK_BOX(vbox), palette->table, FALSE, TRUE, 0);
|
|
|
|
for (i=0; i<CORE_ELEMENT_SIZE; i++) {
|
|
button = gtk_button_new();
|
|
gtk_button_set_relief(GTK_BUTTON(button), GTK_RELIEF_NONE);
|
|
editimage = gst_editor_image_get_for_type(_palette_contents_core[i].type());
|
|
image = gtk_pixmap_new(editimage->pixmap, editimage->bitmap);
|
|
gtk_container_add(GTK_CONTAINER(button), image);
|
|
gtk_widget_show(image);
|
|
|
|
gtk_table_attach(GTK_TABLE(palette->table), button, x, x+1, y, y+1, 0, 0, 0, 0);
|
|
gtk_widget_show(palette->table);
|
|
|
|
data = g_new0(_signal_data, 1);
|
|
|
|
data->palette = palette;
|
|
data->entry = &_palette_contents_core[i];
|
|
|
|
gtk_signal_connect(GTK_OBJECT(button), "clicked", gst_editor_palette_element_clicked, data);
|
|
|
|
gtk_tooltips_set_tip(palette->tooltips, button, _palette_contents_core[i].tooltip, NULL);
|
|
|
|
gtk_widget_show(button);
|
|
|
|
x++;
|
|
if (x==4) {
|
|
x=0;
|
|
y++;
|
|
}
|
|
}
|
|
}
|
|
|
|
static void
|
|
gst_editor_palette_set_arg (GtkObject *object,GtkArg *arg,guint id)
|
|
{
|
|
GstEditorPalette *palette;
|
|
|
|
/* get the major types of this object */
|
|
palette = GST_EDITOR_PALETTE(object);
|
|
|
|
switch (id) {
|
|
default:
|
|
g_warning("gsteditorpalette: unknown arg!");
|
|
break;
|
|
}
|
|
}
|
|
|
|
static void
|
|
gst_editor_palette_get_arg (GtkObject *object,GtkArg *arg,guint id)
|
|
{
|
|
GstEditorPalette *palette;
|
|
|
|
/* get the major types of this object */
|
|
palette = GST_EDITOR_PALETTE(object);
|
|
|
|
switch (id) {
|
|
default:
|
|
arg->type = GTK_TYPE_INVALID;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
|