mirror of
https://github.com/game-stop/veejay.git
synced 2025-12-21 15:20:02 +01:00
sliders and scroll event, fix multitrack double click, ui fixes
git-svn-id: svn://code.dyne.org/veejay/trunk@1185 eb8d1916-c9e9-0310-b8de-cf0c9472ead5
This commit is contained in:
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@@ -2555,10 +2555,14 @@ void on_previewtoggle_toggled(GtkWidget *w, gpointer user_data)
|
|||||||
multitrack_toggle_preview( info->mt, -1, is_button_toggled("previewtoggle"),
|
multitrack_toggle_preview( info->mt, -1, is_button_toggled("previewtoggle"),
|
||||||
glade_xml_get_widget(info->main_window, "imageA") );
|
glade_xml_get_widget(info->main_window, "imageA") );
|
||||||
}
|
}
|
||||||
else {
|
multitrack_set_quality( info->mt, info->quality );
|
||||||
multitrack_toggle_preview( info->mt, -1, 1, glade_xml_get_widget(info->main_window,"imageA")); //@ enable
|
|
||||||
}
|
multitrack_toggle_preview( info->mt,
|
||||||
setup_samplebank( NUM_SAMPLES_PER_COL, NUM_SAMPLES_PER_ROW );
|
-1,
|
||||||
|
1,
|
||||||
|
glade_xml_get_widget(info->main_window,"imageA")); //@ enable
|
||||||
|
|
||||||
|
// setup_samplebank( NUM_SAMPLES_PER_COL, NUM_SAMPLES_PER_ROW );
|
||||||
}
|
}
|
||||||
|
|
||||||
void on_previewspeed_value_changed( GtkWidget *widget, gpointer user_data)
|
void on_previewspeed_value_changed( GtkWidget *widget, gpointer user_data)
|
||||||
@@ -3518,7 +3522,7 @@ gboolean boxgreen_expose_event(GtkWidget *w,
|
|||||||
GdkColor col;
|
GdkColor col;
|
||||||
|
|
||||||
memset( &col,0, sizeof( GdkColor ) );
|
memset( &col,0, sizeof( GdkColor ) );
|
||||||
col.green = 255 * get_slider_val( "textcolorgreen" );
|
col.green = 0xff * get_slider_val( "textcolorgreen" );
|
||||||
|
|
||||||
gdk_color_alloc( gtk_widget_get_colormap( w ), &col );
|
gdk_color_alloc( gtk_widget_get_colormap( w ), &col );
|
||||||
|
|
||||||
|
|||||||
@@ -155,6 +155,7 @@ gboolean gveejay_idle(gpointer data)
|
|||||||
update_gveejay();
|
update_gveejay();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if( gveejay_restart() )
|
if( gveejay_restart() )
|
||||||
|
|||||||
@@ -820,6 +820,8 @@ void *multitrack_new(
|
|||||||
mt->master_track = 0;
|
mt->master_track = 0;
|
||||||
|
|
||||||
mt->preview = gvr_preview_init( MAX_TRACKS, threads );
|
mt->preview = gvr_preview_init( MAX_TRACKS, threads );
|
||||||
|
// gvr_set_master( mt->preview, mt->master_track );
|
||||||
|
|
||||||
|
|
||||||
parent__ = infog;
|
parent__ = infog;
|
||||||
|
|
||||||
@@ -922,8 +924,8 @@ int multrack_audoadd( void *data, char *hostname, int port_num )
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
mt->master_track = track;
|
// mt->master_track = track;
|
||||||
gvr_set_master( mt->preview, track );
|
// gvr_set_master( mt->preview, track );
|
||||||
|
|
||||||
gtk_widget_set_sensitive_(GTK_WIDGET(mt->view[track]->panel), TRUE );
|
gtk_widget_set_sensitive_(GTK_WIDGET(mt->view[track]->panel), TRUE );
|
||||||
|
|
||||||
@@ -973,7 +975,6 @@ void multitrack_set_quality( void *data , int quality )
|
|||||||
|
|
||||||
int w = 0;
|
int w = 0;
|
||||||
int h = 0;
|
int h = 0;
|
||||||
|
|
||||||
switch( quality )
|
switch( quality )
|
||||||
{
|
{
|
||||||
case 1:
|
case 1:
|
||||||
@@ -1082,7 +1083,7 @@ static gboolean seqv_mouse_press_event ( GtkWidget *w, GdkEventButton *event, gp
|
|||||||
sequence_view_t *v = (sequence_view_t*) user_data;
|
sequence_view_t *v = (sequence_view_t*) user_data;
|
||||||
multitracker_t *mt = v->backlink;
|
multitracker_t *mt = v->backlink;
|
||||||
|
|
||||||
if(event->type == GDK_2BUTTON_PRESS)
|
if(event->type == GDK_BUTTON_PRESS)
|
||||||
{
|
{
|
||||||
if( !gvr_track_test( mt->preview , v->num ) )
|
if( !gvr_track_test( mt->preview , v->num ) )
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@@ -1102,6 +1103,15 @@ static gboolean seqv_mouse_press_event ( GtkWidget *w, GdkEventButton *event, gp
|
|||||||
}
|
}
|
||||||
|
|
||||||
vj_gui_cb( 0, host, port );
|
vj_gui_cb( 0, host, port );
|
||||||
|
|
||||||
|
gvr_set_master( mt->preview, v->num );
|
||||||
|
if(!gvr_track_configure( mt->preview, v->num, mt->pw,mt->ph) )
|
||||||
|
{
|
||||||
|
veejay_msg(0, "Unable to configure preview %d x %d",mt->pw , mt->ph );
|
||||||
|
}
|
||||||
|
veejay_msg(VEEJAY_MSG_INFO, "Set master to track %d", mt->master_track );
|
||||||
|
mt->master_track = v->num;
|
||||||
|
|
||||||
vj_gui_enable();
|
vj_gui_enable();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -93,7 +93,7 @@ static struct
|
|||||||
{
|
{
|
||||||
{"Mouse left: Set in point, Mouse right: Set out point, Double click: Clear selected, Mouse middle: Drag selection"},
|
{"Mouse left: Set in point, Mouse right: Set out point, Double click: Clear selected, Mouse middle: Drag selection"},
|
||||||
{"Mouse left/right: Play slot, Shift + Mouse left: Put sample in slot"},
|
{"Mouse left/right: Play slot, Shift + Mouse left: Put sample in slot"},
|
||||||
{"Mouse left click: Select slot (sample in slot), Mouse double click: Play sample in slot"},
|
{"Mouse left click: Select slot (sample in slot), Mouse double click: Play sample in slot, Mouse left + SHIFT: Set slot as mixing current mixing channel"},
|
||||||
{NULL},
|
{NULL},
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -421,7 +421,7 @@ typedef struct
|
|||||||
int run_state;
|
int run_state;
|
||||||
int play_direction;
|
int play_direction;
|
||||||
int load_image_slot;
|
int load_image_slot;
|
||||||
GtkWidget *sample_bank_pad;
|
GtkWidget *sample_bank_pad;
|
||||||
GtkWidget *quick_select;
|
GtkWidget *quick_select;
|
||||||
GtkWidget *sample_sequencer;
|
GtkWidget *sample_sequencer;
|
||||||
sample_bank_t **sample_banks;
|
sample_bank_t **sample_banks;
|
||||||
@@ -578,10 +578,9 @@ static void reload_bundles();
|
|||||||
static void update_rgbkey_from_slider();
|
static void update_rgbkey_from_slider();
|
||||||
static gchar *get_textview_buffer(const char *name);
|
static gchar *get_textview_buffer(const char *name);
|
||||||
static void create_slot(gint bank_nr, gint slot_nr, gint w, gint h);
|
static void create_slot(gint bank_nr, gint slot_nr, gint w, gint h);
|
||||||
static void setup_samplebank(gint c, gint r);
|
static void setup_samplebank(gint c, gint r, GtkWidget *pad, gint *image_w, gint *image_h);
|
||||||
static int add_sample_to_sample_banks( int bank_page,sample_slot_t *slot );
|
static int add_sample_to_sample_banks( int bank_page,sample_slot_t *slot );
|
||||||
static void update_sample_slot_data(int bank_num, int slot_num, int id, gint sample_type, gchar *title, gchar *timecode);
|
static void update_sample_slot_data(int bank_num, int slot_num, int id, gint sample_type, gchar *title, gchar *timecode);
|
||||||
static gboolean on_slot_activated_by_key (GtkWidget *widget, GdkEventKey *event, gpointer user_data);
|
|
||||||
static gboolean on_slot_activated_by_mouse (GtkWidget *widget, GdkEventButton *event, gpointer user_data);
|
static gboolean on_slot_activated_by_mouse (GtkWidget *widget, GdkEventButton *event, gpointer user_data);
|
||||||
static sample_slot_t *vj_gui_get_sample_info(gint which_one, gint mode );
|
static sample_slot_t *vj_gui_get_sample_info(gint which_one, gint mode );
|
||||||
static void add_sample_to_effect_sources_list(gint id, gint type, gchar *title, gchar *timecode);
|
static void add_sample_to_effect_sources_list(gint id, gint type, gchar *title, gchar *timecode);
|
||||||
@@ -609,7 +608,18 @@ static void set_textview_buffer(const char *name, gchar *utf8text);
|
|||||||
void interrupt_cb();
|
void interrupt_cb();
|
||||||
//static gboolean update_log(gpointer data);
|
//static gboolean update_log(gpointer data);
|
||||||
|
|
||||||
|
static struct
|
||||||
|
{
|
||||||
|
const char *text;
|
||||||
|
} text_msg_[] =
|
||||||
|
{
|
||||||
|
{ "Running realtime" },
|
||||||
|
{ NULL },
|
||||||
|
};
|
||||||
|
|
||||||
|
enum {
|
||||||
|
TEXT_REALTIME = 0
|
||||||
|
};
|
||||||
|
|
||||||
static struct
|
static struct
|
||||||
{
|
{
|
||||||
@@ -691,6 +701,7 @@ static struct
|
|||||||
{"button_sampleend"},
|
{"button_sampleend"},
|
||||||
{"speed_slider"},
|
{"speed_slider"},
|
||||||
{"vjframerate"},
|
{"vjframerate"},
|
||||||
|
{"markerframe"},
|
||||||
{NULL}
|
{NULL}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -712,6 +723,7 @@ static struct
|
|||||||
{"vjframerate"},
|
{"vjframerate"},
|
||||||
{"scrolledwindow49"}, // srt stuff
|
{"scrolledwindow49"}, // srt stuff
|
||||||
{"samplegrid_frame"},
|
{"samplegrid_frame"},
|
||||||
|
{"markerframe"},
|
||||||
{"NULL"}
|
{"NULL"}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -793,7 +805,7 @@ GtkWidget *glade_xml_get_widget_( GladeXML *m, const char *name )
|
|||||||
void gtk_widget_set_size_request__( GtkWidget *w, gint iw, gint h, const char *f, int line )
|
void gtk_widget_set_size_request__( GtkWidget *w, gint iw, gint h, const char *f, int line )
|
||||||
{
|
{
|
||||||
#ifdef STRICT_CHECKING
|
#ifdef STRICT_CHECKING
|
||||||
veejay_msg(0, "%s: %dx%d from %s:%d", __FUNCTION__, iw,h,f,line);
|
// veejay_msg(0, "%s: %dx%d from %s:%d", __FUNCTION__, iw,h,f,line);
|
||||||
#endif
|
#endif
|
||||||
gtk_widget_set_size_request(w, iw, h );
|
gtk_widget_set_size_request(w, iw, h );
|
||||||
}
|
}
|
||||||
@@ -1553,7 +1565,7 @@ void about_dialog()
|
|||||||
GtkWidget *about = g_object_new(
|
GtkWidget *about = g_object_new(
|
||||||
GTK_TYPE_ABOUT_DIALOG,
|
GTK_TYPE_ABOUT_DIALOG,
|
||||||
"program_name", "reloaded",
|
"program_name", "reloaded",
|
||||||
"name", "reloaded",
|
"name", "Reloaded",
|
||||||
"version", VERSION,
|
"version", VERSION,
|
||||||
"copyright", "(C) 2004 - 2008 N. Elburg et all.",
|
"copyright", "(C) 2004 - 2008 N. Elburg et all.",
|
||||||
"comments", "The graphical interface for Veejay",
|
"comments", "The graphical interface for Veejay",
|
||||||
@@ -2460,7 +2472,11 @@ static void update_label_str(const char *name, gchar *text)
|
|||||||
{
|
{
|
||||||
GtkWidget *label = glade_xml_get_widget_(
|
GtkWidget *label = glade_xml_get_widget_(
|
||||||
info->main_window, name);
|
info->main_window, name);
|
||||||
|
#ifdef STRICT_CHECKING
|
||||||
|
assert( label != NULL );
|
||||||
|
#else
|
||||||
if(!label ||!text) return;
|
if(!label ||!text) return;
|
||||||
|
#endif
|
||||||
gchar *utf8_text = _utf8str( text );
|
gchar *utf8_text = _utf8str( text );
|
||||||
if(!utf8_text) return;
|
if(!utf8_text) return;
|
||||||
gtk_label_set_text( GTK_LABEL(label), utf8_text);
|
gtk_label_set_text( GTK_LABEL(label), utf8_text);
|
||||||
@@ -4951,7 +4967,6 @@ static void disable_widget_(const char *name, const char *s, int line)
|
|||||||
veejay_msg(0, "Widget '%s' not found, caller is %s:%d",name,s,line);
|
veejay_msg(0, "Widget '%s' not found, caller is %s:%d",name,s,line);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
veejay_msg(2, "disable '%s' from %s:%d", name,s,line);
|
|
||||||
gtk_widget_set_sensitive_( GTK_WIDGET(w), FALSE );
|
gtk_widget_set_sensitive_( GTK_WIDGET(w), FALSE );
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -4962,8 +4977,6 @@ static void enable_widget_(const char *name, const char *s, int line)
|
|||||||
veejay_msg(0, "Widget '%s' not found, caller is %s:%d",name,s,line);
|
veejay_msg(0, "Widget '%s' not found, caller is %s:%d",name,s,line);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
veejay_msg(2, "enable '%s' from %s:%d", name,s,line);
|
|
||||||
|
|
||||||
gtk_widget_set_sensitive_( GTK_WIDGET(w), TRUE );
|
gtk_widget_set_sensitive_( GTK_WIDGET(w), TRUE );
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@@ -4985,20 +4998,21 @@ static gchar *format_selection_time(int start, int end)
|
|||||||
return tmp;
|
return tmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static gboolean update_cpumeter_timeout( gpointer data )
|
static gboolean update_cpumeter_timeout( gpointer data )
|
||||||
{
|
{
|
||||||
gdouble ms = (gdouble)info->status_tokens[ELAPSED_TIME];
|
gdouble ms = (gdouble)info->status_tokens[ELAPSED_TIME];
|
||||||
gdouble fs = (gdouble)get_slider_val( "framerate" );
|
gdouble fs = (gdouble)get_slider_val( "framerate" );
|
||||||
|
|
||||||
|
|
||||||
gdouble lim = (1.0f/fs)*1000.0;
|
gdouble lim = (1.0f/fs)*1000.0;
|
||||||
char text[65];
|
|
||||||
if( ms < lim )
|
if( ms < lim ) {
|
||||||
sprintf(text, "Running realtime" );
|
update_label_str( "cpumeter", text_msg_[TEXT_REALTIME].text );
|
||||||
else
|
} else {
|
||||||
sprintf(text, "%2.2f FPS", ( 1.0 / ms ) * 1000.0 );
|
char text[32];
|
||||||
update_label_str( "cpumeter", text );
|
sprintf(text, "%2.2f FPS", ( 1.0f / ms ) * 1000.0 );
|
||||||
|
|
||||||
|
update_label_str( "cpumeter", text );
|
||||||
|
}
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
static gboolean update_cachemeter_timeout( gpointer data )
|
static gboolean update_cachemeter_timeout( gpointer data )
|
||||||
@@ -5360,6 +5374,11 @@ int veejay_update_multitrack( void *data )
|
|||||||
vj_gui_t *gui = (vj_gui_t*) data;
|
vj_gui_t *gui = (vj_gui_t*) data;
|
||||||
sync_info *s = multitrack_sync( gui->mt );
|
sync_info *s = multitrack_sync( gui->mt );
|
||||||
|
|
||||||
|
if( s->status_list[s->master] == NULL ) {
|
||||||
|
info->watch.w_state = STATE_STOPPED;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
GtkWidget *maintrack = glade_xml_get_widget( info->main_window, "imageA");
|
GtkWidget *maintrack = glade_xml_get_widget( info->main_window, "imageA");
|
||||||
int i;
|
int i;
|
||||||
GtkWidget *ww = glade_xml_get_widget_( info->main_window, "notebook18" );
|
GtkWidget *ww = glade_xml_get_widget_( info->main_window, "notebook18" );
|
||||||
@@ -5416,14 +5435,6 @@ int veejay_update_multitrack( void *data )
|
|||||||
assert( s->heights[i] > 0 );
|
assert( s->heights[i] > 0 );
|
||||||
assert( GDK_IS_PIXBUF( s->img_list[i] ) );
|
assert( GDK_IS_PIXBUF( s->img_list[i] ) );
|
||||||
#endif
|
#endif
|
||||||
// GdkPixbuf *result = vj_gdk_pixbuf_scale_simple( s->img_list[i],352,288, GDK_INTERP_NEAREST );
|
|
||||||
// gtk_image_set_from_pixbuf_( GTK_IMAGE( maintrack ), result );
|
|
||||||
// gdk_pixbuf_unref(result);
|
|
||||||
|
|
||||||
// GdkPixbuf *result = vj_gdk_pixbuf_scale_simple( s->img_list[i],352,288, 0 );
|
|
||||||
// gtk_image_set_from_pixbuf_( GTK_IMAGE( maintrack ), result );
|
|
||||||
// gdk_pixbuf_unref(result);
|
|
||||||
|
|
||||||
if( gdk_pixbuf_get_height(s->img_list[i]) >= 255 ||
|
if( gdk_pixbuf_get_height(s->img_list[i]) >= 255 ||
|
||||||
gdk_pixbuf_get_width(s->img_list[i]) >= 320 )
|
gdk_pixbuf_get_width(s->img_list[i]) >= 320 )
|
||||||
gtk_image_set_from_pixbuf_( GTK_IMAGE( maintrack ), s->img_list[i] );
|
gtk_image_set_from_pixbuf_( GTK_IMAGE( maintrack ), s->img_list[i] );
|
||||||
@@ -5437,14 +5448,6 @@ int veejay_update_multitrack( void *data )
|
|||||||
|
|
||||||
vj_img_cb( s->img_list[i] );
|
vj_img_cb( s->img_list[i] );
|
||||||
}
|
}
|
||||||
// }
|
|
||||||
/* else
|
|
||||||
{
|
|
||||||
GdkPixbuf *result = vj_gdk_pixbuf_scale_simple( s->img_list[i],preview_box_w_,preview_box_h_, 0 );
|
|
||||||
gtk_image_set_from_pixbuf_( GTK_IMAGE( maintrack ), result );
|
|
||||||
gdk_pixbuf_unref(result);
|
|
||||||
}*/
|
|
||||||
// vj_img_cb( s->img_list[i] );
|
|
||||||
|
|
||||||
if(deckpage == 3)
|
if(deckpage == 3)
|
||||||
multitrack_update_sequence_image( gui->mt, i, s->img_list[i] );
|
multitrack_update_sequence_image( gui->mt, i, s->img_list[i] );
|
||||||
@@ -5624,13 +5627,13 @@ static void update_globalinfo(int *history, int pm, int last_pm)
|
|||||||
update_spin_range(
|
update_spin_range(
|
||||||
"button_el_selpaste", 0, total_frames_, info->selection[2]);
|
"button_el_selpaste", 0, total_frames_, info->selection[2]);
|
||||||
}
|
}
|
||||||
|
veejay_msg(0, "%s",time);
|
||||||
update_label_i( "label_totframes", total_frames_, 1 );
|
update_label_i( "label_totframes", total_frames_, 1 );
|
||||||
update_label_str( "label_totaltime", time );
|
update_label_str( "label_totaltime", time );
|
||||||
if(pm == MODE_SAMPLE)
|
if(pm == MODE_SAMPLE)
|
||||||
update_label_str( "label_samplelength", time );
|
update_label_str( "sample_length_label", time );
|
||||||
else
|
else
|
||||||
update_label_str( "label_samplelength", "0:00:00:00" );
|
update_label_str( "sample_length_label", "0:00:00:00" );
|
||||||
|
|
||||||
|
|
||||||
timeline_set_length( info->tl,
|
timeline_set_length( info->tl,
|
||||||
@@ -6249,6 +6252,64 @@ void vj_gui_wipe()
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GtkWidget *new_bank_pad(GtkWidget *box, int type)
|
||||||
|
{
|
||||||
|
GtkWidget *pad = info->sample_bank_pad = gtk_notebook_new();
|
||||||
|
gtk_notebook_set_tab_pos( GTK_NOTEBOOK(pad), GTK_POS_BOTTOM );
|
||||||
|
gtk_notebook_set_show_tabs( GTK_NOTEBOOK(pad ), FALSE );
|
||||||
|
gtk_box_pack_start (GTK_BOX (box), GTK_WIDGET(pad), TRUE, TRUE, 0);
|
||||||
|
|
||||||
|
if( type == 0 ) {
|
||||||
|
setup_samplebank( NUM_SAMPLES_PER_COL, NUM_SAMPLES_PER_ROW, pad, &(info->image_dimensions[0]),
|
||||||
|
&(info->image_dimensions[1]) );
|
||||||
|
}
|
||||||
|
|
||||||
|
return pad;
|
||||||
|
}
|
||||||
|
static struct {
|
||||||
|
const char *text;
|
||||||
|
} slider_names_[] =
|
||||||
|
{
|
||||||
|
{ "slider_p0" },
|
||||||
|
{ "slider_p1" },
|
||||||
|
{ "slider_p2" },
|
||||||
|
{ "slider_p3" },
|
||||||
|
{ "slider_p4" },
|
||||||
|
{ "slider_p5" },
|
||||||
|
{ "slider_p6" },
|
||||||
|
{ "slider_p7" },
|
||||||
|
{ "slider_p8" },
|
||||||
|
{ NULL },
|
||||||
|
};
|
||||||
|
|
||||||
|
gboolean slider_scroll_event( GtkWidget *widget, GdkEventScroll *ev, gpointer user_data)
|
||||||
|
{
|
||||||
|
gint i = GPOINTER_TO_INT(user_data);
|
||||||
|
if(ev->direction == GDK_SCROLL_UP ) {
|
||||||
|
param_changed( i, 1, slider_names_[i].text );
|
||||||
|
} else if (ev->direction == GDK_SCROLL_DOWN ) {
|
||||||
|
param_changed( i, -1, slider_names_[i].text );
|
||||||
|
}
|
||||||
|
veejay_msg(0, "%s: %d,%d",__FUNCTION__,ev->direction,i);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
gboolean speed_scroll_event( GtkWidget *widget, GdkEventScroll *ev, gpointer user_data)
|
||||||
|
{
|
||||||
|
gint i = GPOINTER_TO_INT(user_data);
|
||||||
|
int plainspeed = info->status_tokens[SAMPLE_SPEED];
|
||||||
|
|
||||||
|
if(ev->direction == GDK_SCROLL_UP ) {
|
||||||
|
plainspeed = plainspeed + 1;
|
||||||
|
} else if (ev->direction == GDK_SCROLL_DOWN ) {
|
||||||
|
plainspeed = plainspeed - 1;
|
||||||
|
}
|
||||||
|
update_slider_value( "speed_slider", plainspeed, 0 );
|
||||||
|
|
||||||
|
veejay_msg(0, "%s: %d,%d",__FUNCTION__,ev->direction,i);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void vj_gui_init(char *glade_file, int launcher, char *hostname, int port_num, int use_threads)
|
void vj_gui_init(char *glade_file, int launcher, char *hostname, int port_num, int use_threads)
|
||||||
{
|
{
|
||||||
@@ -6330,15 +6391,25 @@ void vj_gui_init(char *glade_file, int launcher, char *hostname, int port_num,
|
|||||||
NULL );
|
NULL );
|
||||||
|
|
||||||
GtkWidget *box = glade_xml_get_widget_( info->main_window, "sample_bank_hbox" );
|
GtkWidget *box = glade_xml_get_widget_( info->main_window, "sample_bank_hbox" );
|
||||||
info->sample_bank_pad = gtk_notebook_new();
|
info->sample_bank_pad = new_bank_pad( box,0 );
|
||||||
gtk_notebook_set_tab_pos( GTK_NOTEBOOK(info->sample_bank_pad), GTK_POS_BOTTOM );
|
|
||||||
gtk_notebook_set_show_tabs( GTK_NOTEBOOK( info->sample_bank_pad ), FALSE );
|
|
||||||
gtk_box_pack_start (GTK_BOX (box), GTK_WIDGET(info->sample_bank_pad), TRUE, TRUE, 0);
|
|
||||||
setup_samplebank( NUM_SAMPLES_PER_COL, NUM_SAMPLES_PER_ROW );
|
|
||||||
|
|
||||||
|
//QuickSelect slots
|
||||||
create_ref_slots( 10 );
|
create_ref_slots( 10 );
|
||||||
|
|
||||||
|
|
||||||
|
//SEQ
|
||||||
create_sequencer_slots( 10 );
|
create_sequencer_slots( 10 );
|
||||||
|
|
||||||
|
char slider_name[16];
|
||||||
|
for( i = 0 ; i < 8 ; i ++ ) {
|
||||||
|
sprintf(slider_name, "slider_p%d",i);
|
||||||
|
GtkWidget *slider = glade_xml_get_widget( info->main_window, slider_name );
|
||||||
|
g_signal_connect( GTK_OBJECT(slider), "scroll-event", G_CALLBACK(slider_scroll_event), (gpointer) i );
|
||||||
|
}
|
||||||
|
|
||||||
|
g_signal_connect( GTK_OBJECT( glade_xml_get_widget(info->main_window, "speed_slider") ), "scroll-event",
|
||||||
|
G_CALLBACK(speed_scroll_event), NULL );
|
||||||
|
|
||||||
veejay_memset( vj_event_list, 0, sizeof( vj_event_list ));
|
veejay_memset( vj_event_list, 0, sizeof( vj_event_list ));
|
||||||
veejay_memset( vims_keys_list, 0, sizeof( vims_keys_list) );
|
veejay_memset( vims_keys_list, 0, sizeof( vims_keys_list) );
|
||||||
|
|
||||||
@@ -6515,8 +6586,6 @@ int vj_gui_reconnect(char *hostname,char *group_name, int port_num)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// gveejay_status_lock( info );
|
|
||||||
|
|
||||||
if(!vj_client_connect( info->client, hostname, group_name, port_num ) )
|
if(!vj_client_connect( info->client, hostname, group_name, port_num ) )
|
||||||
{
|
{
|
||||||
if(info->client)
|
if(info->client)
|
||||||
@@ -6573,8 +6642,7 @@ int vj_gui_reconnect(char *hostname,char *group_name, int port_num)
|
|||||||
info->uc.reload_hint[HINT_ENTRY] = 1;
|
info->uc.reload_hint[HINT_ENTRY] = 1;
|
||||||
info->uc.reload_hint[HINT_SEQ_ACT] = 1;
|
info->uc.reload_hint[HINT_SEQ_ACT] = 1;
|
||||||
info->uc.reload_hint[HINT_HISTORY] = 1;
|
info->uc.reload_hint[HINT_HISTORY] = 1;
|
||||||
|
|
||||||
// gveejay_status_unlock( info );
|
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@@ -6611,12 +6679,12 @@ void reloaded_schedule_restart()
|
|||||||
|
|
||||||
void reloaded_restart()
|
void reloaded_restart()
|
||||||
{
|
{
|
||||||
#ifdef STRICT_CHECKING
|
|
||||||
assert( info->watch.state == STATE_STOPPED );
|
|
||||||
#endif
|
|
||||||
GtkWidget *cd = glade_xml_get_widget_(info->main_window, "veejay_connection" );
|
GtkWidget *cd = glade_xml_get_widget_(info->main_window, "veejay_connection" );
|
||||||
GtkWidget *mw = glade_xml_get_widget_(info->main_window,"gveejay_window" );
|
GtkWidget *mw = glade_xml_get_widget_(info->main_window,"gveejay_window" );
|
||||||
|
#ifdef STRICT_CHECKING
|
||||||
|
assert( cd != NULL );
|
||||||
|
assert( mw != NULL );
|
||||||
|
#endif
|
||||||
// disable and hide mainwindow
|
// disable and hide mainwindow
|
||||||
if(info->sensitive)
|
if(info->sensitive)
|
||||||
vj_gui_disable();
|
vj_gui_disable();
|
||||||
@@ -6661,6 +6729,10 @@ gboolean is_alive( int *do_sync )
|
|||||||
{
|
{
|
||||||
if(info->client)
|
if(info->client)
|
||||||
vj_gui_disconnect();
|
vj_gui_disconnect();
|
||||||
|
// reloaded_schedule_restart();
|
||||||
|
reloaded_restart();
|
||||||
|
*do_sync = 0;
|
||||||
|
return TRUE;
|
||||||
// return FALSE;
|
// return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -6688,10 +6760,6 @@ gboolean is_alive( int *do_sync )
|
|||||||
info->key_id = gtk_key_snooper_install( key_handler , NULL);
|
info->key_id = gtk_key_snooper_install( key_handler , NULL);
|
||||||
multrack_audoadd( info->mt, remote, port );
|
multrack_audoadd( info->mt, remote, port );
|
||||||
*do_sync = 1;
|
*do_sync = 1;
|
||||||
// if(user_preview==0)
|
|
||||||
// multitrack_set_quality( info->mt, 2 );
|
|
||||||
// else
|
|
||||||
// {
|
|
||||||
if( user_preview ) {
|
if( user_preview ) {
|
||||||
info->preview_locked = 1;
|
info->preview_locked = 1;
|
||||||
multitrack_set_quality( info->mt, user_preview );
|
multitrack_set_quality( info->mt, user_preview );
|
||||||
@@ -6837,10 +6905,11 @@ static int add_bank( gint bank_num )
|
|||||||
gchar str_label[5];
|
gchar str_label[5];
|
||||||
gchar frame_label[20];
|
gchar frame_label[20];
|
||||||
sprintf(str_label, "%d", bank_num );
|
sprintf(str_label, "%d", bank_num );
|
||||||
sprintf(frame_label, "Samples %d to %d",
|
sprintf(frame_label, "Slots %d to %d",
|
||||||
(bank_num * NUM_SAMPLES_PER_PAGE), (bank_num * NUM_SAMPLES_PER_PAGE) + NUM_SAMPLES_PER_PAGE );
|
(bank_num * NUM_SAMPLES_PER_PAGE), (bank_num * NUM_SAMPLES_PER_PAGE) + NUM_SAMPLES_PER_PAGE );
|
||||||
|
|
||||||
setup_samplebank( NUM_SAMPLES_PER_COL, NUM_SAMPLES_PER_ROW );
|
setup_samplebank( NUM_SAMPLES_PER_COL, NUM_SAMPLES_PER_ROW, info->sample_bank_pad, &(info->image_dimensions[0]),
|
||||||
|
&(info->image_dimensions[1]) );
|
||||||
|
|
||||||
info->sample_banks[bank_num] = (sample_bank_t*) vj_calloc(sizeof(sample_bank_t));
|
info->sample_banks[bank_num] = (sample_bank_t*) vj_calloc(sizeof(sample_bank_t));
|
||||||
info->sample_banks[bank_num]->bank_number = bank_num;
|
info->sample_banks[bank_num]->bank_number = bank_num;
|
||||||
@@ -6852,7 +6921,7 @@ static int add_bank( gint bank_num )
|
|||||||
{
|
{
|
||||||
slot[j] = (sample_slot_t*) vj_calloc(sizeof(sample_slot_t) );
|
slot[j] = (sample_slot_t*) vj_calloc(sizeof(sample_slot_t) );
|
||||||
gui_slot[j] = (sample_gui_slot_t*) vj_calloc(sizeof(sample_gui_slot_t));
|
gui_slot[j] = (sample_gui_slot_t*) vj_calloc(sizeof(sample_gui_slot_t));
|
||||||
slot[j]->rawdata = (guchar*) vj_calloc(sizeof(guchar) * 3 * 128 * 128 );
|
// slot[j]->rawdata = (guchar*) vj_calloc(sizeof(guchar) * 3 * 128 * 128 );
|
||||||
slot[j]->slot_number = j;
|
slot[j]->slot_number = j;
|
||||||
slot[j]->sample_id = -1;
|
slot[j]->sample_id = -1;
|
||||||
slot[j]->sample_type = -1;
|
slot[j]->sample_type = -1;
|
||||||
@@ -6958,7 +7027,7 @@ void free_samplebank(void)
|
|||||||
if(slot->title) free(slot->title);
|
if(slot->title) free(slot->title);
|
||||||
if(slot->timecode) free(slot->timecode);
|
if(slot->timecode) free(slot->timecode);
|
||||||
if(slot->pixbuf) gdk_pixbuf_unref(slot->pixbuf);
|
if(slot->pixbuf) gdk_pixbuf_unref(slot->pixbuf);
|
||||||
if(slot->rawdata) free(slot->rawdata);
|
// if(slot->rawdata) free(slot->rawdata);
|
||||||
free(slot);
|
free(slot);
|
||||||
free(gslot);
|
free(gslot);
|
||||||
info->sample_banks[i]->slot[j] = NULL;
|
info->sample_banks[i]->slot[j] = NULL;
|
||||||
@@ -6973,13 +7042,19 @@ void free_samplebank(void)
|
|||||||
}
|
}
|
||||||
#define RUP8(num)(((num)+8)&~8)
|
#define RUP8(num)(((num)+8)&~8)
|
||||||
|
|
||||||
void setup_samplebank(gint num_cols, gint num_rows)
|
|
||||||
|
//@ OK
|
||||||
|
void setup_samplebank(gint num_cols, gint num_rows, GtkWidget *pad, int *idx, int *idy)
|
||||||
{
|
{
|
||||||
GdkRectangle result;
|
GdkRectangle result;
|
||||||
if(info->el.width > 0 && info->el.height > 0 )
|
if(info->el.width <= 0 || info->el.height <= 0 ) {
|
||||||
{
|
*idx = 0;
|
||||||
|
*idy = 0;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
else {
|
||||||
widget_get_rect_in_screen(
|
widget_get_rect_in_screen(
|
||||||
info->sample_bank_pad,
|
pad,
|
||||||
&result
|
&result
|
||||||
);
|
);
|
||||||
result.width -= ( num_rows * 16);
|
result.width -= ( num_rows * 16);
|
||||||
@@ -6988,15 +7063,13 @@ void setup_samplebank(gint num_cols, gint num_rows)
|
|||||||
gint image_height = result.height / num_cols;
|
gint image_height = result.height / num_cols;
|
||||||
float ratio = (float) info->el.height / (float) info->el.width;
|
float ratio = (float) info->el.height / (float) info->el.width;
|
||||||
image_height = image_width * ratio;
|
image_height = image_width * ratio;
|
||||||
info->image_dimensions[0] = 64;
|
*idx = 64;
|
||||||
info->image_dimensions[1] = 64 * ratio;
|
*idy = 64 * ratio;
|
||||||
|
// info->image_dimensions[0] = 64;
|
||||||
|
// info->image_dimensions[1] = 64 * ratio;
|
||||||
|
veejay_msg(0, "Image: %dx%d", image_width,image_height );
|
||||||
}
|
}
|
||||||
else
|
veejay_msg(VEEJAY_MSG_INFO, "Sample bank image dimensions: %dx%d", *idx,*idy);
|
||||||
{
|
|
||||||
info->image_dimensions[0] = 0 ;
|
|
||||||
info->image_dimensions[1] = 0;
|
|
||||||
}
|
|
||||||
veejay_msg(VEEJAY_MSG_INFO, "Sample bank image dimensions: %dx%d", info->image_dimensions[0],info->image_dimensions[1]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------------------------------------
|
/* --------------------------------------------------------------------------------------------------------------------------
|
||||||
@@ -7291,18 +7364,12 @@ static void create_slot(gint bank_nr, gint slot_nr, gint w, gint h)
|
|||||||
gui_slot->event_box = gtk_event_box_new();
|
gui_slot->event_box = gtk_event_box_new();
|
||||||
gtk_event_box_set_visible_window(GTK_EVENT_BOX(gui_slot->event_box), TRUE);
|
gtk_event_box_set_visible_window(GTK_EVENT_BOX(gui_slot->event_box), TRUE);
|
||||||
|
|
||||||
|
|
||||||
GTK_WIDGET_SET_FLAGS(gui_slot->event_box,GTK_CAN_FOCUS);
|
GTK_WIDGET_SET_FLAGS(gui_slot->event_box,GTK_CAN_FOCUS);
|
||||||
g_signal_connect( G_OBJECT(gui_slot->event_box),
|
g_signal_connect( G_OBJECT(gui_slot->event_box),
|
||||||
"button_press_event",
|
"button_press_event",
|
||||||
G_CALLBACK(on_slot_activated_by_mouse),
|
G_CALLBACK(on_slot_activated_by_mouse),
|
||||||
(gpointer)slot_nr
|
(gpointer)slot_nr
|
||||||
);
|
);
|
||||||
g_signal_connect( G_OBJECT(gui_slot->event_box),
|
|
||||||
"key_press_event",
|
|
||||||
G_CALLBACK(on_slot_activated_by_key),
|
|
||||||
(gpointer)slot_nr
|
|
||||||
);
|
|
||||||
gtk_widget_show(GTK_WIDGET(gui_slot->event_box));
|
gtk_widget_show(GTK_WIDGET(gui_slot->event_box));
|
||||||
/* the surrounding frame for each slot */
|
/* the surrounding frame for each slot */
|
||||||
gui_slot->frame = gtk_frame_new(NULL);
|
gui_slot->frame = gtk_frame_new(NULL);
|
||||||
@@ -7376,11 +7443,9 @@ static gboolean on_slot_activated_by_mouse (GtkWidget *widget, GdkEventButton *e
|
|||||||
if(bank_nr < 0 )
|
if(bank_nr < 0 )
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
// slot_nr = (gint *)user_data;
|
|
||||||
slot_nr = GPOINTER_TO_INT(user_data);
|
slot_nr = GPOINTER_TO_INT(user_data);
|
||||||
sample_bank_t **sample_banks = info->sample_banks;
|
sample_bank_t **sample_banks = info->sample_banks;
|
||||||
|
|
||||||
/* Dont select slot if nothing is there */
|
|
||||||
if( info->sample_banks[ bank_nr ]->slot[ slot_nr ]->sample_id <= 0 )
|
if( info->sample_banks[ bank_nr ]->slot[ slot_nr ]->sample_id <= 0 )
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
@@ -7392,26 +7457,42 @@ static gboolean on_slot_activated_by_mouse (GtkWidget *widget, GdkEventButton *e
|
|||||||
}
|
}
|
||||||
else if(event->type == GDK_BUTTON_PRESS )
|
else if(event->type == GDK_BUTTON_PRESS )
|
||||||
{
|
{
|
||||||
if(info->selection_slot)
|
if( (event->state & GDK_SHIFT_MASK ) == GDK_SHIFT_MASK ) {
|
||||||
set_selection_of_slot_in_samplebank(FALSE);
|
sample_slot_t *x = sample_banks[bank_nr]->slot[slot_nr];
|
||||||
info->selection_slot = sample_banks[bank_nr]->slot[slot_nr];
|
multi_vims( VIMS_CHAIN_ENTRY_SET_SOURCE_CHANNEL,
|
||||||
info->selection_gui_slot = sample_banks[bank_nr]->gui_slot[slot_nr];
|
"%d %d %d %d",
|
||||||
set_selection_of_slot_in_samplebank(TRUE );
|
0,
|
||||||
|
info->uc.selected_chain_entry,
|
||||||
|
x->sample_type,
|
||||||
|
x->sample_id );
|
||||||
|
|
||||||
|
if(x->sample_id == 1 ) {
|
||||||
|
vj_msg(VEEJAY_MSG_INFO, "Set mixing channel %d to Stream %d", info->uc.selected_chain_entry,
|
||||||
|
x->sample_id );
|
||||||
|
} else {
|
||||||
|
vj_msg(VEEJAY_MSG_INFO, "Set mixing channel %d to Sample %d", info->uc.selected_chain_entry,
|
||||||
|
x->sample_id);
|
||||||
|
}
|
||||||
|
|
||||||
|
char trip[100];
|
||||||
|
snprintf(trip, sizeof(trip), "%03d:%d %d %d %d",VIMS_CHAIN_ENTRY_SET_SOURCE_CHANNEL,
|
||||||
|
0,
|
||||||
|
info->uc.selected_chain_entry,
|
||||||
|
x->sample_type,
|
||||||
|
x->sample_id );
|
||||||
|
|
||||||
|
vj_midi_learning_vims( info->midi, NULL, trip, 0 );
|
||||||
|
} else {
|
||||||
|
if(info->selection_slot)
|
||||||
|
set_selection_of_slot_in_samplebank(FALSE);
|
||||||
|
info->selection_slot = sample_banks[bank_nr]->slot[slot_nr];
|
||||||
|
info->selection_gui_slot = sample_banks[bank_nr]->gui_slot[slot_nr];
|
||||||
|
set_selection_of_slot_in_samplebank(TRUE );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// redraw bank page?
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
}
|
}
|
||||||
/* --------------------------------------------------------------------------------------------------------------------------
|
|
||||||
* Handler of key presses on the GUI-elements of one slot
|
|
||||||
-------------------------------------------------------------------------------------------------------------------------- */
|
|
||||||
static gboolean on_slot_activated_by_key (GtkWidget *widget, GdkEventKey *event, gpointer user_data)
|
|
||||||
{
|
|
||||||
// test
|
|
||||||
printf("%s\n","press");
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static void indicate_sequence( gboolean active, sequence_gui_slot_t *slot )
|
static void indicate_sequence( gboolean active, sequence_gui_slot_t *slot )
|
||||||
|
|||||||
@@ -127,6 +127,8 @@ static gboolean event_release (GtkWidget *widget, GdkEventButton *bev, gpointer
|
|||||||
|
|
||||||
static gboolean event_motion (GtkWidget *widget, GdkEventMotion *mev, gpointer user_data);
|
static gboolean event_motion (GtkWidget *widget, GdkEventMotion *mev, gpointer user_data);
|
||||||
|
|
||||||
|
static gboolean event_scroll (GtkWidget *widget, GdkEventScroll *mev, gpointer user_data);
|
||||||
|
|
||||||
static void timeline_class_init( TimelineSelectionClass *class );
|
static void timeline_class_init( TimelineSelectionClass *class );
|
||||||
|
|
||||||
static void timeline_init(TimelineSelection *te );
|
static void timeline_init(TimelineSelection *te );
|
||||||
@@ -527,6 +529,30 @@ static void move_selection( GtkWidget *widget, gdouble x, gdouble width )
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
event_scroll (GtkWidget *widget, GdkEventScroll *ev, gpointer user_data)
|
||||||
|
{
|
||||||
|
TimelineSelection *te = TIMELINE_SELECTION (widget);
|
||||||
|
gdouble width = (gdouble) widget->allocation.width;
|
||||||
|
gint x,y;
|
||||||
|
GdkModifierType state;
|
||||||
|
gdk_window_get_pointer( ev->window, &x,&y,&state );
|
||||||
|
|
||||||
|
if( ev->direction == GDK_SCROLL_UP ) {
|
||||||
|
gdouble cur_pos = timeline_get_pos(widget);
|
||||||
|
timeline_set_pos( widget, cur_pos + 1 );
|
||||||
|
}
|
||||||
|
else if(ev->direction == GDK_SCROLL_DOWN ) {
|
||||||
|
gdouble cur_pos = timeline_get_pos(widget);
|
||||||
|
timeline_set_pos( widget, cur_pos - 1 );
|
||||||
|
}
|
||||||
|
|
||||||
|
gtk_widget_queue_draw( widget );
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static gboolean event_press(GtkWidget *widget, GdkEventButton *ev, gpointer user_data)
|
static gboolean event_press(GtkWidget *widget, GdkEventButton *ev, gpointer user_data)
|
||||||
{
|
{
|
||||||
TimelineSelection *te = TIMELINE_SELECTION( widget );
|
TimelineSelection *te = TIMELINE_SELECTION( widget );
|
||||||
@@ -535,6 +561,7 @@ static gboolean event_press(GtkWidget *widget, GdkEventButton *ev, gpointer user
|
|||||||
te->grab_button = ev->button;
|
te->grab_button = ev->button;
|
||||||
te->current_location = MOUSE_WIDGET;
|
te->current_location = MOUSE_WIDGET;
|
||||||
|
|
||||||
|
|
||||||
if( ev->type == GDK_2BUTTON_PRESS && te->grab_button == 1 )
|
if( ev->type == GDK_2BUTTON_PRESS && te->grab_button == 1 )
|
||||||
{
|
{
|
||||||
timeline_clear_points( widget );
|
timeline_clear_points( widget );
|
||||||
@@ -827,7 +854,7 @@ GtkWidget *timeline_new(void)
|
|||||||
GDK_EXPOSURE_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_POINTER_MOTION_MASK |
|
GDK_EXPOSURE_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_POINTER_MOTION_MASK |
|
||||||
GDK_BUTTON1_MOTION_MASK | GDK_BUTTON2_MOTION_MASK |
|
GDK_BUTTON1_MOTION_MASK | GDK_BUTTON2_MOTION_MASK |
|
||||||
GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK |
|
GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK |
|
||||||
GDK_BUTTON3_MOTION_MASK | GDK_2BUTTON_PRESS );
|
GDK_BUTTON3_MOTION_MASK | GDK_2BUTTON_PRESS | GDK_SCROLL_MASK );
|
||||||
|
|
||||||
g_signal_connect( G_OBJECT(widget), "expose_event", G_CALLBACK(timeline_expose), NULL );
|
g_signal_connect( G_OBJECT(widget), "expose_event", G_CALLBACK(timeline_expose), NULL );
|
||||||
g_signal_connect( G_OBJECT(widget), "motion_notify_event",
|
g_signal_connect( G_OBJECT(widget), "motion_notify_event",
|
||||||
@@ -836,6 +863,8 @@ GtkWidget *timeline_new(void)
|
|||||||
G_CALLBACK(event_press), NULL );
|
G_CALLBACK(event_press), NULL );
|
||||||
g_signal_connect( G_OBJECT(widget), "button_release_event",
|
g_signal_connect( G_OBJECT(widget), "button_release_event",
|
||||||
G_CALLBACK(event_release), NULL );
|
G_CALLBACK(event_release), NULL );
|
||||||
|
g_signal_connect( G_OBJECT(widget), "scroll_event",
|
||||||
|
G_CALLBACK( event_scroll ), NULL );
|
||||||
|
|
||||||
te->widget = widget;
|
te->widget = widget;
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user