2 * ui.c -- GTK+ 2 melted gui
3 * Copyright (C) 2012 Maksym Veremeyenko <verem@m1stereo.tv>
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software Foundation,
17 * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
24 #include <sys/types.h>
30 #include <gdk/gdkkeysyms.h>
35 #include "ui_buttons.h"
40 typedef struct column_desc
46 static const column_desc_t playlist_columns
[] =
82 const static column_desc_t library_columns
[] =
103 static GtkWidget
* create_label(GtkWidget
* top
, char* text
, char* reg
, GtkJustification jtype
)
107 label
= gtk_label_new ("");
108 gtk_widget_show (label
);
111 gtk_label_set_justify (GTK_LABEL (label
), jtype
);
114 GLADE_HOOKUP_OBJECT (top
, label
, reg
);
117 gtk_label_set_text(GTK_LABEL (label
), text
);
122 static GtkWidget
* create_treeview_list(GtkWidget
* top
, char* name
, const column_desc_t columns
[])
127 GtkTreeSelection
*selection
;
128 GtkCellRenderer
*renderer
;
129 GtkTreeViewColumn
*column
;
130 GtkListStore
*list_store
;
131 GType list_store_types
[32];
133 treeview
= gtk_tree_view_new ();
134 gtk_widget_show (treeview
);
135 gtk_tree_view_set_rules_hint(GTK_TREE_VIEW(treeview
), TRUE
);
136 gtk_tree_view_set_grid_lines(GTK_TREE_VIEW(treeview
), GTK_TREE_VIEW_GRID_LINES_BOTH
);
138 selection
= gtk_tree_view_get_selection(GTK_TREE_VIEW(treeview
));
139 gtk_tree_selection_set_mode(selection
, GTK_SELECTION_MULTIPLE
);
141 for(i
= 0, count
= 0; columns
[i
].title
; i
++, count
++)
142 list_store_types
[i
] = (columns
[i
].type
== G_TYPE_OBJECT
)?GDK_TYPE_PIXBUF
:columns
[i
].type
;
143 list_store_types
[count
] = G_TYPE_INT
;
144 list_store_types
[count
+ 1] = G_TYPE_BOOLEAN
;
145 list_store_types
[count
+ 2] = G_TYPE_STRING
;
147 list_store
= gtk_list_store_newv(count
+ 3, list_store_types
);
149 gtk_tree_view_set_model( GTK_TREE_VIEW( treeview
), GTK_TREE_MODEL( list_store
) );
151 for(i
= 0; columns
[i
].title
; i
++)
156 if(columns
[i
].type
== G_TYPE_OBJECT
)
158 renderer
= gtk_cell_renderer_pixbuf_new();
159 gtk_cell_renderer_set_padding(renderer
, 0, 0);
162 else if(columns
[i
].type
== G_TYPE_BOOLEAN
)
164 renderer
= gtk_cell_renderer_toggle_new();
169 renderer
= gtk_cell_renderer_text_new();
172 column
= gtk_tree_view_column_new_with_attributes(
173 columns
[i
].title
, renderer
,
175 "background-set", count
+ 1,
176 "background", count
+ 2,
181 column
= gtk_tree_view_column_new_with_attributes(
182 columns
[i
].title
, renderer
,
186 gtk_tree_view_append_column(GTK_TREE_VIEW( treeview
), column
);
189 g_object_unref(list_store
);
191 GLADE_HOOKUP_OBJECT (top
, treeview
, name
);
196 static GtkWidget
* create_treeview_tree(GtkWidget
* top
, char* name
, const column_desc_t columns
[])
201 GtkTreeSelection
*selection
;
202 GtkCellRenderer
*renderer
;
203 GtkTreeViewColumn
*column
;
204 GtkTreeStore
*tree_store
;
205 GType tree_store_types
[32];
207 treeview
= gtk_tree_view_new ();
208 gtk_widget_show (treeview
);
209 gtk_tree_view_set_rules_hint(GTK_TREE_VIEW(treeview
), TRUE
);
210 gtk_tree_view_set_grid_lines(GTK_TREE_VIEW(treeview
), GTK_TREE_VIEW_GRID_LINES_BOTH
);
212 selection
= gtk_tree_view_get_selection(GTK_TREE_VIEW(treeview
));
213 gtk_tree_selection_set_mode(selection
, GTK_SELECTION_MULTIPLE
);
215 for(i
= 0, count
= 0; columns
[i
].title
; i
++, count
++)
216 tree_store_types
[i
] = (columns
[i
].type
== G_TYPE_OBJECT
)?GDK_TYPE_PIXBUF
:columns
[i
].type
;
217 tree_store_types
[count
+ 0] = G_TYPE_POINTER
;
218 tree_store_types
[count
+ 1] = G_TYPE_POINTER
;
219 tree_store_types
[count
+ 2] = G_TYPE_BOOLEAN
;
220 tree_store_types
[count
+ 3] = G_TYPE_STRING
;
222 tree_store
= gtk_tree_store_newv(count
+ 4, tree_store_types
);
224 gtk_tree_view_set_model( GTK_TREE_VIEW( treeview
), GTK_TREE_MODEL( tree_store
) );
226 for(i
= 0; columns
[i
].title
; i
++)
231 if(columns
[i
].type
== G_TYPE_OBJECT
)
233 renderer
= gtk_cell_renderer_pixbuf_new();
234 gtk_cell_renderer_set_padding(renderer
, 0, 0);
237 else if(columns
[i
].type
== G_TYPE_BOOLEAN
)
239 renderer
= gtk_cell_renderer_toggle_new();
244 renderer
= gtk_cell_renderer_text_new();
247 column
= gtk_tree_view_column_new_with_attributes(
248 columns
[i
].title
, renderer
,
250 "background-set", count
+ 2,
251 "background", count
+ 3,
256 column
= gtk_tree_view_column_new_with_attributes(
257 columns
[i
].title
, renderer
,
261 gtk_tree_view_append_column(GTK_TREE_VIEW( treeview
), column
);
264 g_object_unref(tree_store
);
266 GLADE_HOOKUP_OBJECT (top
, treeview
, name
);
271 static GtkWidget
* pane_library_tree(GtkWidget
* top
, instance_t
* app
)
273 GtkWidget
*scrolledwindow
;
275 scrolledwindow
= gtk_scrolled_window_new (NULL
, NULL
);
276 gtk_widget_show (scrolledwindow
);
277 gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolledwindow
),
278 GTK_POLICY_AUTOMATIC
, GTK_POLICY_AUTOMATIC
);
280 gtk_container_add (GTK_CONTAINER (scrolledwindow
),
281 app
->library_tree
= create_treeview_tree(top
, "treeview_library", library_columns
));
283 return scrolledwindow
;
286 static GtkWidget
* pane_library_buttons(GtkWidget
* top
, instance_t
* app
)
290 hbox
= gtk_hbox_new (FALSE
, 0);
291 gtk_widget_show (hbox
);
293 /* playlist modify buttons */
294 gtk_box_pack_start (GTK_BOX (hbox
),
295 ui_create_button(top
, app
, BUTTON_LIBRARY_ADD
),
297 gtk_box_pack_start (GTK_BOX (hbox
),
298 ui_create_button(top
, app
, BUTTON_LIBRARY_REFRESH
),
302 gtk_box_pack_start (GTK_BOX (hbox
),
303 create_label(top
, NULL
, NULL
, GTK_JUSTIFY_CENTER
),
309 static GtkWidget
* pane_library_search_buttons(GtkWidget
* top
, instance_t
* app
)
313 hbox
= gtk_hbox_new (FALSE
, 0);
314 gtk_widget_show (hbox
);
317 gtk_box_pack_start (GTK_BOX (hbox
),
318 app
->library
.search
= gtk_entry_new(),
320 gtk_widget_show(app
->library
.search
);
322 /* playlist modify buttons */
323 gtk_box_pack_start (GTK_BOX (hbox
),
324 ui_create_button(top
, app
, BUTTON_LIBRARY_FIND
),
326 gtk_box_pack_start (GTK_BOX (hbox
),
327 ui_create_button(top
, app
, BUTTON_LIBRARY_FIND_NEXT
),
333 static GtkWidget
* pane_library(GtkWidget
* top
, instance_t
* app
)
337 vbox
= gtk_vbox_new (FALSE
, 0);
338 gtk_widget_show (vbox
);
339 gtk_widget_set_size_request(vbox
, 300, -1);
341 /* add buttons box */
342 gtk_box_pack_start (GTK_BOX (vbox
),
343 pane_library_buttons(top
, app
),
347 gtk_box_pack_start (GTK_BOX (vbox
),
348 pane_library_tree(top
, app
),
351 /* add search buttons */
352 gtk_box_pack_start (GTK_BOX (vbox
),
353 pane_library_search_buttons(top
, app
),
359 static GtkWidget
* create_channel_status(GtkWidget
* top
, instance_t
* app
, int idx
)
367 player
= &app
->players
.item
[idx
];
369 snprintf(name
, sizeof(name
), "unit %d [%c]", player
->unit
, idx
+ 'A');
371 frame
= gtk_frame_new(name
);
372 gtk_widget_show(frame
);
374 vbox
= gtk_vbox_new(FALSE
, 0);
375 gtk_container_add(GTK_CONTAINER(frame
), vbox
);
376 gtk_widget_show(vbox
);
379 gtk_box_pack_start(GTK_BOX (vbox
),
380 player
->label_status
= create_label(top
, "OFFLINE", NULL
, GTK_JUSTIFY_LEFT
),
384 gtk_box_pack_start(GTK_BOX (vbox
),
385 create_label(top
, " ", NULL
, GTK_JUSTIFY_CENTER
),
389 gtk_box_pack_start (GTK_BOX (vbox
),
390 player
->label_clip
= create_label(top
, "U0002323", NULL
, GTK_JUSTIFY_LEFT
),
393 /* block state/current timecode */
394 gtk_box_pack_start(GTK_BOX (vbox
),
395 hbox
= gtk_hbox_new(TRUE
, 0),
397 gtk_widget_show(hbox
);
401 gtk_box_pack_start(GTK_BOX (hbox
),
402 player
->label_state
= create_label(top
, "PLAYING", NULL
, GTK_JUSTIFY_LEFT
),
405 /* current timecode */
406 gtk_box_pack_start(GTK_BOX (hbox
),
407 player
->label_tc_cur
= create_label(top
, "00:00:00:00", NULL
, GTK_JUSTIFY_LEFT
),
411 /* block remain label/remain timecode */
412 gtk_box_pack_start(GTK_BOX (vbox
),
413 hbox
= gtk_hbox_new(TRUE
, 0),
415 gtk_widget_show (hbox
);
419 gtk_box_pack_start(GTK_BOX (hbox
),
420 create_label(top
, "remain:", NULL
, GTK_JUSTIFY_LEFT
),
423 /* remaining timecode */
424 gtk_box_pack_start(GTK_BOX (hbox
),
425 player
->label_tc_rem
= create_label(top
, "00:00:00:00", NULL
, GTK_JUSTIFY_LEFT
),
432 static GtkWidget
* pane_operate_status(GtkWidget
* top
, instance_t
* app
)
437 vbox
= gtk_vbox_new (FALSE
, 0);
438 gtk_widget_show (vbox
);
439 gtk_widget_set_size_request(vbox
, 250, -1);
441 for(i
= 0; i
< app
->players
.count
; i
++)
443 gtk_box_pack_start (GTK_BOX (vbox
),
444 create_channel_status(top
, app
, i
),
448 gtk_box_pack_start (GTK_BOX (vbox
),
449 create_label(top
, NULL
, NULL
, GTK_JUSTIFY_CENTER
),
454 gtk_box_pack_start (GTK_BOX (vbox
),
455 create_label(top
, NULL
, NULL
, GTK_JUSTIFY_CENTER
),
461 static GtkWidget
* pane_operate_buttons_playlist(GtkWidget
* top
, instance_t
* app
)
465 hbox
= gtk_hbox_new (FALSE
, 0);
466 gtk_widget_show (hbox
);
468 /* playlist load/save buttons */
469 gtk_box_pack_start (GTK_BOX (hbox
),
470 ui_create_button(top
, app
, BUTTON_PLAYLIST_LOAD
),
472 gtk_box_pack_start (GTK_BOX (hbox
),
473 ui_create_button(top
, app
, BUTTON_PLAYLIST_SAVE
),
477 gtk_box_pack_start (GTK_BOX (hbox
),
478 create_label(top
, " ", NULL
, GTK_JUSTIFY_CENTER
),
481 /* playlist modify buttons */
482 gtk_box_pack_start (GTK_BOX (hbox
),
483 ui_create_button(top
, app
, BUTTON_PLAYLIST_ITEM_ADD
),
485 gtk_box_pack_start (GTK_BOX (hbox
),
486 ui_create_button(top
, app
, BUTTON_PLAYLIST_ITEM_EDIT
),
488 gtk_box_pack_start (GTK_BOX (hbox
),
489 ui_create_button(top
, app
, BUTTON_PLAYLIST_ITEM_DEL
),
493 gtk_box_pack_start (GTK_BOX (hbox
),
494 create_label(top
, " ", NULL
, GTK_JUSTIFY_CENTER
),
497 /* playlist block buttons */
498 gtk_box_pack_start (GTK_BOX (hbox
),
499 ui_create_button(top
, app
, BUTTON_PLAYLIST_BLOCK_SINGLE
),
501 gtk_box_pack_start (GTK_BOX (hbox
),
502 ui_create_button(top
, app
, BUTTON_PLAYLIST_BLOCK_LOOP
),
506 gtk_box_pack_start (GTK_BOX (hbox
),
507 create_label(top
, " ", NULL
, GTK_JUSTIFY_CENTER
),
510 /* playlist move items buttons */
511 gtk_box_pack_start (GTK_BOX (hbox
),
512 ui_create_button(top
, app
, BUTTON_PLAYLIST_ITEM_UP
),
514 gtk_box_pack_start (GTK_BOX (hbox
),
515 ui_create_button(top
, app
, BUTTON_PLAYLIST_ITEM_DOWN
),
519 gtk_box_pack_start (GTK_BOX (hbox
),
520 create_label(top
, " ", NULL
, GTK_JUSTIFY_CENTER
),
523 /* playlist relink */
524 gtk_box_pack_start (GTK_BOX (hbox
),
525 ui_create_button(top
, app
, BUTTON_PLAYLIST_RELINK
),
531 static GtkWidget
* pane_operate_grid(GtkWidget
* top
, instance_t
* app
)
533 GtkWidget
*scrolledwindow
;
535 scrolledwindow
= gtk_scrolled_window_new (NULL
, NULL
);
536 gtk_widget_show (scrolledwindow
);
537 gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolledwindow
),
538 GTK_POLICY_AUTOMATIC
, GTK_POLICY_AUTOMATIC
);
540 gtk_container_add (GTK_CONTAINER (scrolledwindow
),
541 app
->playlist_grid
= create_treeview_list(top
, "treeview_playlist", playlist_columns
));
543 return scrolledwindow
;
546 static GtkWidget
* pane_operate_buttons_operate(GtkWidget
* top
, instance_t
* app
)
550 hbox
= gtk_hbox_new (FALSE
, 0);
551 gtk_widget_show (hbox
);
554 gtk_box_pack_start (GTK_BOX (hbox
),
555 create_label(top
, NULL
, NULL
, GTK_JUSTIFY_CENTER
),
558 /* playlist modify buttons */
559 gtk_box_pack_start (GTK_BOX (hbox
),
560 ui_create_button(top
, app
, BUTTON_PLAYER_CUE
),
562 gtk_box_pack_start (GTK_BOX (hbox
),
563 ui_create_button(top
, app
, BUTTON_PLAYER_PLAY
),
565 gtk_box_pack_start (GTK_BOX (hbox
),
566 ui_create_button(top
, app
, BUTTON_PLAYER_PAUSE
),
568 gtk_box_pack_start (GTK_BOX (hbox
),
569 ui_create_button(top
, app
, BUTTON_PLAYER_STOP
),
573 gtk_box_pack_start (GTK_BOX (hbox
),
574 create_label(top
, NULL
, NULL
, GTK_JUSTIFY_CENTER
),
580 static GtkWidget
* pane_operate_operate(GtkWidget
* top
, instance_t
* app
)
584 vbox
= gtk_vbox_new (FALSE
, 0);
585 gtk_widget_show (vbox
);
587 /* add buttons box #1 */
588 gtk_box_pack_start (GTK_BOX (vbox
),
589 pane_operate_buttons_playlist(top
, app
),
592 /* add buttons box */
593 gtk_box_pack_start (GTK_BOX (vbox
),
594 pane_operate_grid(top
, app
),
597 /* add buttons box #1 */
598 gtk_box_pack_start (GTK_BOX (vbox
),
599 pane_operate_buttons_operate(top
, app
),
606 static GtkWidget
* pane_operate(GtkWidget
* top
, instance_t
* app
)
610 hbox
= gtk_hbox_new (FALSE
, 0);
611 gtk_widget_show (hbox
);
613 /* add buttons box */
614 gtk_box_pack_start (GTK_BOX (hbox
),
615 pane_operate_status(top
, app
),
618 /* add buttons box */
619 gtk_box_pack_start (GTK_BOX (hbox
),
620 pane_operate_operate(top
, app
),
627 static GtkWidget
* pane_top(GtkWidget
* top
, instance_t
* app
)
631 pane
= gtk_hpaned_new ();
632 gtk_widget_show (pane
);
634 gtk_paned_set_position (GTK_PANED (pane
), 800);
636 gtk_paned_pack1 (GTK_PANED (pane
),
637 pane_operate(top
, app
),
640 gtk_paned_pack2 (GTK_PANED (pane
),
641 pane_library(top
, app
),
647 GtkWidget
* ui_create(instance_t
* app
)
652 wnd
= gtk_window_new (GTK_WINDOW_TOPLEVEL
);
653 GLADE_HOOKUP_OBJECT_NO_REF (wnd
, wnd
, PACKAGE
"_window");
655 gtk_window_set_title (GTK_WINDOW (wnd
), _(PRODUCT_NAME
));
656 gtk_window_set_default_size (GTK_WINDOW (wnd
), 1024, 768);
658 vbox
= gtk_vbox_new(FALSE
, 0);
659 gtk_widget_show(vbox
);
661 gtk_container_add(GTK_CONTAINER(wnd
), vbox
);
663 gtk_box_pack_start (GTK_BOX (vbox
),
666 gtk_box_pack_start (GTK_BOX (vbox
),
667 app
->status_label
= create_label(wnd
, "started", NULL
, GTK_JUSTIFY_LEFT
),
670 app
->playlist
.block_icons
[PLAYLIST_ITEM_BLOCK_BEGIN
] =
671 create_pixbuf("block_type_block_start_16x16.png");
672 app
->playlist
.block_icons
[PLAYLIST_ITEM_BLOCK_BODY
] =
673 create_pixbuf("block_type_block_middle_16x16.png");
674 app
->playlist
.block_icons
[PLAYLIST_ITEM_BLOCK_END
] =
675 create_pixbuf("block_type_block_end_16x16.png");
676 app
->playlist
.block_icons
[PLAYLIST_ITEM_BLOCK_SINGLE
] =
677 create_pixbuf("block_type_block_single_16x16.png");
678 app
->playlist
.block_icons
[PLAYLIST_ITEM_LOOP_BEGIN
] =
679 create_pixbuf("block_type_loop_start_16x16.png");
680 app
->playlist
.block_icons
[PLAYLIST_ITEM_LOOP_BODY
] =
681 create_pixbuf("block_type_loop_middle_16x16.png");
682 app
->playlist
.block_icons
[PLAYLIST_ITEM_LOOP_END
] =
683 create_pixbuf("block_type_loop_end_16x16.png");
684 app
->playlist
.block_icons
[PLAYLIST_ITEM_LOOP_SINGLE
] =
685 create_pixbuf("block_type_block_loop_16x16.png");
690 int ui_playlist_item_dialog(instance_t
* app
, playlist_item_t
* item
)
696 GtkWidget
*box
, *table
;
697 GtkWidget
*entry
[4], *combo
;
699 dlg
= gtk_dialog_new_with_buttons(
701 GTK_WINDOW(app
->window
),
703 GTK_STOCK_OK
, GTK_RESPONSE_ACCEPT
,
704 GTK_STOCK_CANCEL
, GTK_RESPONSE_REJECT
,
707 box
= gtk_dialog_get_content_area(GTK_DIALOG(dlg
));
709 table
= gtk_table_new(5, 2, TRUE
);
710 gtk_widget_show(table
);
711 gtk_box_pack_start(GTK_BOX(box
), table
, TRUE
, TRUE
, 0);
713 gtk_table_attach(GTK_TABLE(table
),
714 create_label(NULL
, "ID:", NULL
, 0),
716 GTK_FILL
/* | GTK_SHRINK */, GTK_FILL
| GTK_SHRINK
, 5, 5);
718 gtk_table_attach(GTK_TABLE(table
),
719 create_label(NULL
, "IN:", NULL
, GTK_JUSTIFY_RIGHT
),
721 GTK_FILL
/* | GTK_SHRINK */, GTK_FILL
| GTK_SHRINK
, 5, 5);
723 gtk_table_attach(GTK_TABLE(table
),
724 create_label(NULL
, "DUR:", NULL
, GTK_JUSTIFY_RIGHT
),
726 GTK_FILL
/* | GTK_SHRINK */, GTK_FILL
| GTK_SHRINK
, 5, 5);
728 gtk_table_attach(GTK_TABLE(table
),
729 create_label(NULL
, "TITLE:", NULL
, GTK_JUSTIFY_RIGHT
),
731 GTK_FILL
/* | GTK_SHRINK */, GTK_FILL
| GTK_SHRINK
, 5, 5);
733 gtk_table_attach(GTK_TABLE(table
),
734 create_label(NULL
, "CHANNEL:", NULL
, GTK_JUSTIFY_RIGHT
),
736 GTK_FILL
/* | GTK_SHRINK */, GTK_FILL
| GTK_SHRINK
, 5, 5);
739 gtk_table_attach(GTK_TABLE(table
),
740 entry
[0] = gtk_entry_new_with_max_length(32),
742 GTK_FILL
/* | GTK_SHRINK */, GTK_FILL
| GTK_SHRINK
, 5, 5);
744 gtk_table_attach(GTK_TABLE(table
),
745 entry
[1] = gtk_entry_new_with_max_length(12),
747 GTK_FILL
/* | GTK_SHRINK */, GTK_FILL
| GTK_SHRINK
, 5, 5);
749 gtk_table_attach(GTK_TABLE(table
),
750 entry
[2] = gtk_entry_new_with_max_length(12),
752 GTK_FILL
/* | GTK_SHRINK */, GTK_FILL
| GTK_SHRINK
, 5, 5);
754 gtk_table_attach(GTK_TABLE(table
),
755 entry
[3] = gtk_entry_new_with_max_length(128),
757 GTK_FILL
/* | GTK_SHRINK */, GTK_FILL
| GTK_SHRINK
, 5, 5);
759 gtk_table_attach(GTK_TABLE(table
),
760 combo
= gtk_combo_box_new_text(),
762 GTK_FILL
/* | GTK_SHRINK */, GTK_FILL
| GTK_SHRINK
, 5, 5);
766 gtk_entry_set_text(GTK_ENTRY(entry
[0]), item
->id
);
767 gtk_entry_set_text(GTK_ENTRY(entry
[1]), frames2tc(item
->in
, 25.0, tc
));
768 gtk_entry_set_text(GTK_ENTRY(entry
[2]), frames2tc(item
->dur
, 25.0, tc
));
769 gtk_entry_set_text(GTK_ENTRY(entry
[3]), item
->title
);
770 gtk_combo_box_append_text(GTK_COMBO_BOX(combo
), "A");
771 gtk_combo_box_append_text(GTK_COMBO_BOX(combo
), "B");
772 gtk_combo_box_append_text(GTK_COMBO_BOX(combo
), "C");
773 gtk_combo_box_append_text(GTK_COMBO_BOX(combo
), "D");
774 gtk_combo_box_set_active(GTK_COMBO_BOX(combo
), item
->player
);
776 gtk_widget_show_all(dlg
);
781 response
= gtk_dialog_run(GTK_DIALOG(dlg
));
783 if( GTK_RESPONSE_REJECT
== response
||
784 GTK_RESPONSE_DELETE_EVENT
== response
||
785 GTK_RESPONSE_CANCEL
== response
)
794 /* get item data back */
795 strncpy(item
->id
, gtk_entry_get_text(GTK_ENTRY(entry
[0])), PATH_MAX
);
796 tc2frames((char*)gtk_entry_get_text(GTK_ENTRY(entry
[1])), 25.0, &item
->in
);
797 tc2frames((char*)gtk_entry_get_text(GTK_ENTRY(entry
[2])), 25.0, &item
->dur
);
798 strncpy(item
->title
, gtk_entry_get_text(GTK_ENTRY(entry
[3])), PATH_MAX
);
799 item
->player
= gtk_combo_box_get_active(GTK_COMBO_BOX(combo
));
801 /* check if all data entered correctly */
807 gtk_widget_hide(dlg
);
808 gtk_widget_destroy(dlg
);
813 /********************************************************************************/
815 void ui_update_player(player_t
* player
, char *tc_cur
, char *tc_rem
, char *state
, char *status
, char *clip
)
817 /* update status in status page */
819 gtk_label_set_text(GTK_LABEL (player
->label_tc_cur
), tc_cur
);
820 gtk_label_set_text(GTK_LABEL (player
->label_tc_rem
), tc_rem
);
821 gtk_label_set_text(GTK_LABEL (player
->label_state
), state
);
822 gtk_label_set_text(GTK_LABEL (player
->label_status
), status
);
823 gtk_label_set_text(GTK_LABEL (player
->label_clip
), clip
);
828 static gboolean
ui_playlist_draw_item_rem_proc(
829 GtkTreeModel
*model
, GtkTreePath
*path
, GtkTreeIter
*iter
, gpointer user_data
)
832 void** args
= (void**)user_data
;
833 GtkListStore
*list_store
= (GtkListStore
*)args
[1];
834 int idx
= (int)args
[2];
835 char* rem
= (char*)args
[3];
837 gtk_tree_model_get(model
, iter
, 7, &i
, -1);
839 if(i
!= idx
) return FALSE
;
841 gtk_list_store_set(list_store
, iter
, 0, rem
, -1);
846 void ui_playlist_draw_item_rem(instance_t
* app
, int idx
, char* rem
)
849 GtkListStore
*list_store
;
853 list_store
= GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW(app
->playlist_grid
)));
855 item
[0] = (void*)app
;
856 item
[1] = (void*)list_store
;
857 item
[2] = (void*)idx
;
858 item
[3] = (void*)rem
;
860 gtk_tree_model_foreach(GTK_TREE_MODEL(list_store
), ui_playlist_draw_item_rem_proc
, item
);
866 void ui_playlist_select_item(instance_t
* app
, int idx
)
870 path
= gtk_tree_path_new_from_indices(idx
, -1);
872 gtk_tree_selection_select_path(gtk_tree_view_get_selection(GTK_TREE_VIEW(app
->playlist_grid
)), path
);
873 gtk_tree_view_set_cursor(GTK_TREE_VIEW(app
->playlist_grid
), path
, NULL
, FALSE
);
874 gtk_tree_path_free(path
);
877 void ui_playlist_draw(instance_t
* app
)
881 char tc1
[12], tc2
[12];
882 GtkListStore
*list_store
;
885 sel
= playlist_get_first_selected_item_idx(app
);
887 list_store
= GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW(app
->playlist_grid
)));
888 gtk_list_store_clear(list_store
);
890 pthread_mutex_lock(&app
->playlist
.lock
);
892 for(i
= 0;i
< app
->playlist
.count
; i
++)
896 if(PLAYLIST_BLOCK_BEGIN
& app
->playlist
.item
[i
].type
)
897 snprintf(ch
, sizeof(ch
), "%c", 'A' + app
->playlist
.item
[i
].player
);
901 gtk_list_store_append(list_store
, &iter
);
903 gtk_list_store_set(list_store
, &iter
,
905 1, app
->playlist
.block_icons
[app
->playlist
.item
[i
].type
],
907 3, app
->playlist
.item
[i
].id
,
908 4, frames2tc(app
->playlist
.item
[i
].in
, 25.0, tc1
),
909 5, frames2tc(app
->playlist
.item
[i
].dur
, 25.0, tc2
),
910 6, app
->playlist
.item
[i
].title
,
912 8, (app
->playlist
.item
[i
].error
!= 0),
913 9, (app
->playlist
.item
[i
].error
& PLAYLIST_ITEM_ERROR_LIB
)?
"red":"orange",
917 app
->playlist
.ver_prev
= app
->playlist
.ver_curr
;
920 ui_playlist_select_item(app
, sel
);
922 pthread_mutex_unlock(&app
->playlist
.lock
);
925 typedef struct ui_playlist_draw_item_desc
927 GtkListStore
*list_store
;
930 } ui_playlist_draw_item_t
;
932 static gboolean ui_playlist_draw_item_iter
941 char tc1
[12], tc2
[12];
943 ui_playlist_draw_item_t
* item
= (ui_playlist_draw_item_t
*)user_data
;
944 instance_t
* app
= item
->app
;
946 gtk_tree_model_get(model
, iter
, 7, &i
, -1);
948 if(i
!= item
->idx
) return FALSE
;
950 if(PLAYLIST_BLOCK_BEGIN
& app
->playlist
.item
[i
].type
)
951 snprintf(ch
, sizeof(ch
), "%c", 'A' + app
->playlist
.item
[i
].player
);
955 gtk_list_store_set(item
->list_store
, iter
,
957 1, app
->playlist
.block_icons
[app
->playlist
.item
[i
].type
],
959 3, app
->playlist
.item
[i
].id
,
960 4, frames2tc(app
->playlist
.item
[i
].in
, 25.0, tc1
),
961 5, frames2tc(app
->playlist
.item
[i
].dur
, 25.0, tc2
),
962 6, app
->playlist
.item
[i
].title
,
964 8, (app
->playlist
.item
[i
].error
!= 0),
965 9, (app
->playlist
.item
[i
].error
& PLAYLIST_ITEM_ERROR_LIB
)?
"red":"orange",
971 void ui_playlist_draw_item(instance_t
* app
, int idx
)
973 GtkListStore
*list_store
;
974 ui_playlist_draw_item_t item
;
976 list_store
= GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW(app
->playlist_grid
)));
978 pthread_mutex_lock(&app
->playlist
.lock
);
982 item
.list_store
= list_store
;
983 gtk_tree_model_foreach(GTK_TREE_MODEL(list_store
), ui_playlist_draw_item_iter
, &item
);
985 pthread_mutex_unlock(&app
->playlist
.lock
);