Mercurial > audlegacy
annotate src/audacious/ui_main.c @ 3599:24ae9b303a9d trunk
removed lastfm from the core, rewriting it as a plugin
author | Cristi Magherusan <majeru@atheme-project.org> |
---|---|
date | Sat, 22 Sep 2007 22:50:57 +0300 |
parents | 21601ce39fa1 |
children | aba660a4a15d |
rev | line source |
---|---|
2313 | 1 /* Audacious - Cross-platform multimedia player |
2 * Copyright (C) 2005-2006 Audacious development team. | |
3 * | |
4 * BMP - Cross-platform multimedia player | |
5 * Copyright (C) 2003-2004 BMP development team. | |
6 * | |
7 * Based on XMMS: | |
8 * Copyright (C) 1998-2003 XMMS development team. | |
9 * | |
10 * This program is free software; you can redistribute it and/or modify | |
11 * it under the terms of the GNU General Public License as published by | |
3121
3b6d316f8b09
GPL3 relicensing.
William Pitcock <nenolod@atheme-project.org>
parents:
3108
diff
changeset
|
12 * the Free Software Foundation; under version 3 of the License. |
2313 | 13 * |
14 * This program is distributed in the hope that it will be useful, | |
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
17 * GNU General Public License for more details. | |
18 * | |
19 * You should have received a copy of the GNU General Public License | |
3121
3b6d316f8b09
GPL3 relicensing.
William Pitcock <nenolod@atheme-project.org>
parents:
3108
diff
changeset
|
20 * along with this program. If not, see <http://www.gnu.org/licenses>. |
3123
f1c756f39e6c
Invoke "Plugins are not derived work" clause provided by GPL3.
William Pitcock <nenolod@atheme-project.org>
parents:
3121
diff
changeset
|
21 * |
f1c756f39e6c
Invoke "Plugins are not derived work" clause provided by GPL3.
William Pitcock <nenolod@atheme-project.org>
parents:
3121
diff
changeset
|
22 * The Audacious team does not consider modular code linking to |
f1c756f39e6c
Invoke "Plugins are not derived work" clause provided by GPL3.
William Pitcock <nenolod@atheme-project.org>
parents:
3121
diff
changeset
|
23 * Audacious or using our public API to be a derived work. |
2313 | 24 */ |
25 | |
26 #ifdef HAVE_CONFIG_H | |
27 # include "config.h" | |
28 #endif | |
29 | |
30 | |
31 #include <glib.h> | |
32 #include <glib/gi18n.h> | |
33 #include <glib/gprintf.h> | |
34 #include <gtk/gtk.h> | |
35 #include <gtk/gtkmessagedialog.h> | |
36 | |
37 /* GDK including */ | |
38 #include "platform/smartinclude.h" | |
39 | |
40 #include <math.h> | |
41 #include <stdlib.h> | |
42 #include <string.h> | |
43 | |
44 #include <sys/types.h> | |
45 | |
46 #if defined(USE_REGEX_ONIGURUMA) | |
47 #include <onigposix.h> | |
48 #elif defined(USE_REGEX_PCRE) | |
49 #include <pcreposix.h> | |
50 #else | |
51 #include <regex.h> | |
52 #endif | |
53 | |
54 #include "ui_main.h" | |
55 #include "icons-stock.h" | |
56 | |
57 #include "actions-mainwin.h" | |
58 | |
59 #include "main.h" | |
2717 | 60 #include "configdb.h" |
2313 | 61 #include "dnd.h" |
62 #include "dock.h" | |
63 #include "hints.h" | |
64 #include "input.h" | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
65 #include "playback.h" |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
66 #include "playlist.h" |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
67 #include "pluginenum.h" |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
68 #include "ui_credits.h" |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
69 #include "ui_equalizer.h" |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
70 #include "ui_fileopener.h" |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
71 #include "ui_manager.h" |
2313 | 72 #include "ui_playlist.h" |
73 #include "ui_preferences.h" | |
74 #include "ui_skinselector.h" | |
2422 | 75 #include "ui_urlopener.h" |
2373
ad1d7687814c
[svn] made strings.h for existing strings.c, cleanups
mf0102
parents:
2354
diff
changeset
|
76 #include "strings.h" |
2313 | 77 #include "util.h" |
78 #include "visualization.h" | |
79 | |
3251 | 80 #include "skin.h" |
2494
59661bd074b4
[svn] Try to put some skinned window code in a common place.
nenolod
parents:
2485
diff
changeset
|
81 #include "ui_skinned_window.h" |
2842
c2622a939e9e
rename audacious_pbutton to ui_skinned_button
Tomasz Mon <desowin@gmail.com>
parents:
2840
diff
changeset
|
82 #include "ui_skinned_button.h" |
2911 | 83 #include "ui_skinned_textbox.h" |
3001
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
84 #include "ui_skinned_number.h" |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
85 #include "ui_skinned_horizontal_slider.h" |
3069
093759970e44
replace Menurow with UiSkinnedMenurow
Tomasz Mon <desowin@gmail.com>
parents:
3057
diff
changeset
|
86 #include "ui_skinned_menurow.h" |
3072
84de3244aeaa
replace Playstatus with UiSkinnedPlaystatus
Tomasz Mon <desowin@gmail.com>
parents:
3070
diff
changeset
|
87 #include "ui_skinned_playstatus.h" |
3073
da99b90d63d3
replace MonoStereo with UiSkinnedMonoStereo
Tomasz Mon <desowin@gmail.com>
parents:
3072
diff
changeset
|
88 #include "ui_skinned_monostereo.h" |
3217 | 89 #include "ui_skinned_playlist.h" |
2500 | 90 #include "ui_jumptotrack.h" |
2494
59661bd074b4
[svn] Try to put some skinned window code in a common place.
nenolod
parents:
2485
diff
changeset
|
91 |
3165
8775dfc57ead
Remove mainwin_set_info_text() craq. Still some work to do.
William Pitcock <nenolod@atheme-project.org>
parents:
3157
diff
changeset
|
92 #include "ui_main_evlisteners.h" |
8775dfc57ead
Remove mainwin_set_info_text() craq. Still some work to do.
William Pitcock <nenolod@atheme-project.org>
parents:
3157
diff
changeset
|
93 |
2313 | 94 static GTimeVal cb_time; /* click delay for tristate is defined by TRISTATE_THRESHOLD */ |
95 | |
96 #define ITEM_SEPARATOR {"/-", NULL, NULL, 0, "<Separator>"} | |
97 #define TRISTATE_THRESHOLD 200 | |
98 | |
99 #define VOLSET_DISP_TIMES 5 | |
100 | |
101 enum { | |
102 MAINWIN_SEEK_REV = -1, | |
103 MAINWIN_SEEK_NIL, | |
104 MAINWIN_SEEK_FWD | |
105 }; | |
106 | |
107 typedef struct _PlaybackInfo PlaybackInfo; | |
108 | |
109 struct _PlaybackInfo { | |
110 gchar *title; | |
111 gint bitrate; | |
112 gint frequency; | |
113 gint n_channels; | |
114 }; | |
115 | |
116 GtkWidget *mainwin = NULL; | |
117 GtkWidget *err = NULL; /* an error dialog for miscellaneous error messages */ | |
118 | |
119 static GdkBitmap *nullmask; | |
120 static gint balance; | |
121 | |
122 static GtkWidget *mainwin_jtt = NULL; | |
123 | |
124 gint seek_state = MAINWIN_SEEK_NIL; | |
125 gint seek_initial_pos = 0; | |
126 | |
2821 | 127 static GtkWidget *mainwin_menubtn; |
128 static GtkWidget *mainwin_minimize, *mainwin_shade, *mainwin_close; | |
129 | |
130 static GtkWidget *mainwin_rew, *mainwin_fwd; | |
131 static GtkWidget *mainwin_eject; | |
132 static GtkWidget *mainwin_play, *mainwin_pause, *mainwin_stop; | |
2313 | 133 |
2853
bec320cfcc12
use UiSkinnedButton instead of PButton in equalizerwin
Tomasz Mon <desowin@gmail.com>
parents:
2844
diff
changeset
|
134 static GtkWidget *mainwin_shuffle, *mainwin_repeat; |
bec320cfcc12
use UiSkinnedButton instead of PButton in equalizerwin
Tomasz Mon <desowin@gmail.com>
parents:
2844
diff
changeset
|
135 GtkWidget *mainwin_eq, *mainwin_pl; |
2843
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
136 |
3565
21601ce39fa1
let mainwin_othertext use xfont when cfg.mainwin_use_xfont is TRUE
Tomasz Mon <desowin@gmail.com>
parents:
3533
diff
changeset
|
137 GtkWidget *mainwin_info, *mainwin_othertext; |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
138 GtkWidget *mainwin_stime_min, *mainwin_stime_sec; |
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
139 |
3565
21601ce39fa1
let mainwin_othertext use xfont when cfg.mainwin_use_xfont is TRUE
Tomasz Mon <desowin@gmail.com>
parents:
3533
diff
changeset
|
140 static GtkWidget *mainwin_rate_text, *mainwin_freq_text; |
2313 | 141 |
3072
84de3244aeaa
replace Playstatus with UiSkinnedPlaystatus
Tomasz Mon <desowin@gmail.com>
parents:
3070
diff
changeset
|
142 GtkWidget *mainwin_playstatus; |
2313 | 143 |
3001
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
144 GtkWidget *mainwin_minus_num, *mainwin_10min_num, *mainwin_min_num; |
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
145 GtkWidget *mainwin_10sec_num, *mainwin_sec_num; |
2313 | 146 |
147 static gboolean setting_volume = FALSE; | |
148 | |
3020 | 149 GtkWidget *mainwin_vis; |
3054 | 150 GtkWidget *mainwin_svis; |
2313 | 151 |
3042
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
152 GtkWidget *mainwin_sposition = NULL; |
2313 | 153 |
3069
093759970e44
replace Menurow with UiSkinnedMenurow
Tomasz Mon <desowin@gmail.com>
parents:
3057
diff
changeset
|
154 static GtkWidget *mainwin_menurow; |
3045
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
155 static GtkWidget *mainwin_volume, *mainwin_balance; |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
156 GtkWidget *mainwin_position; |
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
157 |
3073
da99b90d63d3
replace MonoStereo with UiSkinnedMonoStereo
Tomasz Mon <desowin@gmail.com>
parents:
3072
diff
changeset
|
158 static GtkWidget *mainwin_monostereo; |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
159 static GtkWidget *mainwin_srew, *mainwin_splay, *mainwin_spause; |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
160 static GtkWidget *mainwin_sstop, *mainwin_sfwd, *mainwin_seject, *mainwin_about; |
2313 | 161 |
162 static gint mainwin_timeout_id; | |
163 | |
164 static gboolean mainwin_info_text_locked = FALSE; | |
165 | |
166 static int ab_position_a = -1; | |
167 static int ab_position_b = -1; | |
168 | |
169 static PlaybackInfo playback_info = { NULL, 0, 0, 0 }; | |
170 | |
3241 | 171 static void mainwin_refresh_visible(void); |
2313 | 172 static gint mainwin_idle_func(gpointer data); |
173 | |
174 static void set_timer_mode_menu_cb(TimerMode mode); | |
175 static void set_timer_mode(TimerMode mode); | |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
176 static void change_timer_mode(void); |
2313 | 177 |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
178 void mainwin_position_motion_cb(GtkWidget *widget, gint pos); |
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
179 void mainwin_position_release_cb(GtkWidget *widget, gint pos); |
2313 | 180 |
181 void set_doublesize(gboolean doublesize); | |
2843
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
182 void mainwin_eq_pushed(gboolean toggled); |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
183 void mainwin_pl_pushed(gboolean toggled); |
2313 | 184 |
185 | |
186 /* FIXME: placed here for now */ | |
187 void | |
188 playback_get_sample_params(gint * bitrate, | |
189 gint * frequency, | |
190 gint * n_channels) | |
191 { | |
192 if (bitrate) | |
193 *bitrate = playback_info.bitrate; | |
194 | |
195 if (frequency) | |
196 *frequency = playback_info.frequency; | |
197 | |
198 if (n_channels) | |
199 *n_channels = playback_info.n_channels; | |
200 } | |
201 | |
202 static void | |
203 playback_set_sample_params(gint bitrate, | |
204 gint frequency, | |
205 gint n_channels) | |
206 { | |
207 if (bitrate >= 0) | |
208 playback_info.bitrate = bitrate; | |
209 | |
210 if (frequency >= 0) | |
211 playback_info.frequency = frequency; | |
212 | |
213 if (n_channels >= 0) | |
214 playback_info.n_channels = n_channels; | |
215 } | |
216 | |
217 static void | |
218 mainwin_set_title_scroll(gboolean scroll) | |
219 { | |
220 cfg.autoscroll = scroll; | |
2911 | 221 ui_skinned_textbox_set_scroll(mainwin_info, cfg.autoscroll); |
2313 | 222 } |
223 | |
224 | |
225 void | |
226 mainwin_set_always_on_top(gboolean always) | |
227 { | |
228 GtkAction *action = gtk_action_group_get_action( | |
229 toggleaction_group_others , "view always on top" ); | |
230 gtk_toggle_action_set_active( GTK_TOGGLE_ACTION(action) , always ); | |
231 } | |
232 | |
233 static void | |
234 mainwin_set_shape_mask(void) | |
235 { | |
236 if (!cfg.player_visible) | |
237 return; | |
238 | |
239 if (cfg.doublesize == FALSE) | |
240 gtk_widget_shape_combine_mask(mainwin, | |
241 skin_get_mask(bmp_active_skin, | |
242 SKIN_MASK_MAIN), 0, 0); | |
243 else | |
244 gtk_widget_shape_combine_mask(mainwin, NULL, 0, 0); | |
245 } | |
246 | |
247 static void | |
248 mainwin_set_shade(gboolean shaded) | |
249 { | |
250 GtkAction *action = gtk_action_group_get_action( | |
251 toggleaction_group_others , "roll up player" ); | |
252 gtk_toggle_action_set_active( GTK_TOGGLE_ACTION(action) , shaded ); | |
253 } | |
254 | |
255 static void | |
256 mainwin_set_shade_menu_cb(gboolean shaded) | |
257 { | |
258 cfg.player_shaded = shaded; | |
259 | |
260 mainwin_set_shape_mask(); | |
261 if (shaded) { | |
262 dock_shade(dock_window_list, GTK_WINDOW(mainwin), | |
263 MAINWIN_SHADED_HEIGHT * (cfg.doublesize + 1)); | |
3241 | 264 } else { |
265 gint height = !bmp_active_skin->properties.mainwin_height ? MAINWIN_HEIGHT : | |
266 bmp_active_skin->properties.mainwin_height; | |
2313 | 267 |
268 dock_shade(dock_window_list, GTK_WINDOW(mainwin), height * (cfg.doublesize + 1)); | |
269 } | |
270 | |
3241 | 271 mainwin_refresh_visible(); |
3006
3c4ed53a685f
use ui_skinned_set_push_button_data instead accessing values directly
Tomasz Mon <desowin@gmail.com>
parents:
3005
diff
changeset
|
272 ui_skinned_set_push_button_data(mainwin_shade, 0, cfg.player_shaded ? 27 : 18, 9, cfg.player_shaded ? 27 : 18); |
2313 | 273 } |
274 | |
275 static void | |
276 mainwin_vis_set_refresh(RefreshRate rate) | |
277 { | |
278 cfg.vis_refresh = rate; | |
279 } | |
280 | |
281 static void | |
282 mainwin_vis_set_afalloff(FalloffSpeed speed) | |
283 { | |
284 cfg.analyzer_falloff = speed; | |
285 } | |
286 | |
287 static void | |
288 mainwin_vis_set_pfalloff(FalloffSpeed speed) | |
289 { | |
290 cfg.peaks_falloff = speed; | |
291 } | |
292 | |
293 static void | |
294 mainwin_vis_set_analyzer_mode(AnalyzerMode mode) | |
295 { | |
296 cfg.analyzer_mode = mode; | |
297 } | |
298 | |
299 static void | |
300 mainwin_vis_set_analyzer_type(AnalyzerType mode) | |
301 { | |
302 cfg.analyzer_type = mode; | |
303 } | |
304 | |
305 void | |
306 mainwin_vis_set_type(VisType mode) | |
307 { | |
308 GtkAction *action; | |
309 | |
310 switch ( mode ) | |
311 { | |
312 case VIS_ANALYZER: | |
313 action = gtk_action_group_get_action( | |
314 radioaction_group_vismode , "vismode analyzer" ); | |
315 break; | |
316 case VIS_SCOPE: | |
317 action = gtk_action_group_get_action( | |
318 radioaction_group_vismode , "vismode scope" ); | |
319 break; | |
320 case VIS_VOICEPRINT: | |
321 action = gtk_action_group_get_action( | |
322 radioaction_group_vismode , "vismode voiceprint" ); | |
323 break; | |
324 case VIS_OFF: | |
325 default: | |
326 action = gtk_action_group_get_action( | |
327 radioaction_group_vismode , "vismode off" ); | |
328 break; | |
329 } | |
330 | |
331 gtk_toggle_action_set_active( GTK_TOGGLE_ACTION(action) , TRUE ); | |
332 } | |
333 | |
334 static void | |
335 mainwin_vis_set_type_menu_cb(VisType mode) | |
336 { | |
337 cfg.vis_type = mode; | |
338 | |
339 if (mode == VIS_OFF) { | |
3054 | 340 if (cfg.player_shaded) { |
341 ui_svis_set_visible(mainwin_svis, FALSE); | |
342 ui_vis_set_visible(mainwin_vis, TRUE); | |
343 } else { | |
344 ui_svis_set_visible(mainwin_svis, TRUE); | |
3020 | 345 ui_vis_set_visible(mainwin_vis, FALSE); |
346 } | |
2313 | 347 } |
348 if (mode == VIS_ANALYZER || mode == VIS_SCOPE || mode == VIS_VOICEPRINT) { | |
3054 | 349 if (cfg.player_shaded) { |
350 ui_svis_clear_data(mainwin_svis); | |
351 ui_svis_set_visible(mainwin_svis, TRUE); | |
352 ui_vis_clear_data(mainwin_vis); | |
353 ui_vis_set_visible(mainwin_vis, FALSE); | |
354 } else { | |
355 ui_svis_clear_data(mainwin_svis); | |
356 ui_svis_set_visible(mainwin_svis, FALSE); | |
357 ui_vis_clear_data(mainwin_vis); | |
358 ui_vis_set_visible(mainwin_vis, TRUE); | |
359 } | |
2313 | 360 } |
361 } | |
362 | |
363 static void | |
364 mainwin_menubtn_cb(void) | |
365 { | |
366 gint x, y; | |
367 gtk_window_get_position(GTK_WINDOW(mainwin), &x, &y); | |
368 ui_manager_popup_menu_show(GTK_MENU(mainwin_general_menu), | |
369 x + 6 * (1 + cfg.doublesize), | |
370 y + MAINWIN_SHADED_HEIGHT * (1 + cfg.doublesize), | |
371 1, GDK_CURRENT_TIME); | |
372 } | |
373 | |
2964
7926d46872c8
right click on mainwin_about brings menu
Tomasz Mon <desowin@gmail.com>
parents:
2959
diff
changeset
|
374 static void |
7926d46872c8
right click on mainwin_about brings menu
Tomasz Mon <desowin@gmail.com>
parents:
2959
diff
changeset
|
375 mainwin_about_cb(void) |
7926d46872c8
right click on mainwin_about brings menu
Tomasz Mon <desowin@gmail.com>
parents:
2959
diff
changeset
|
376 { |
7926d46872c8
right click on mainwin_about brings menu
Tomasz Mon <desowin@gmail.com>
parents:
2959
diff
changeset
|
377 gint x, y; |
7926d46872c8
right click on mainwin_about brings menu
Tomasz Mon <desowin@gmail.com>
parents:
2959
diff
changeset
|
378 gdk_window_get_pointer(NULL, &x, &y, NULL); |
7926d46872c8
right click on mainwin_about brings menu
Tomasz Mon <desowin@gmail.com>
parents:
2959
diff
changeset
|
379 ui_manager_popup_menu_show(GTK_MENU(mainwin_general_menu), |
7926d46872c8
right click on mainwin_about brings menu
Tomasz Mon <desowin@gmail.com>
parents:
2959
diff
changeset
|
380 x + 6 * (1 + cfg.doublesize), |
7926d46872c8
right click on mainwin_about brings menu
Tomasz Mon <desowin@gmail.com>
parents:
2959
diff
changeset
|
381 y + MAINWIN_SHADED_HEIGHT * (1 + cfg.doublesize), |
7926d46872c8
right click on mainwin_about brings menu
Tomasz Mon <desowin@gmail.com>
parents:
2959
diff
changeset
|
382 1, GDK_CURRENT_TIME); |
7926d46872c8
right click on mainwin_about brings menu
Tomasz Mon <desowin@gmail.com>
parents:
2959
diff
changeset
|
383 } |
7926d46872c8
right click on mainwin_about brings menu
Tomasz Mon <desowin@gmail.com>
parents:
2959
diff
changeset
|
384 |
2313 | 385 void |
386 mainwin_minimize_cb(void) | |
387 { | |
388 if (!mainwin) | |
389 return; | |
390 | |
391 gtk_window_iconify(GTK_WINDOW(mainwin)); | |
392 } | |
393 | |
394 static void | |
395 mainwin_shade_toggle(void) | |
396 { | |
397 mainwin_set_shade(!cfg.player_shaded); | |
398 } | |
399 | |
400 void | |
401 mainwin_quit_cb(void) | |
402 { | |
403 GList *playlists = NULL, *playlists_top = NULL; | |
404 | |
3460
0fcff78c0c2c
Make the shutdown procedure more sane and improve playlist clearing
Matti Hamalainen <ccr@tnsp.org>
parents:
3406
diff
changeset
|
405 playlist_stop_get_info_thread(); |
0fcff78c0c2c
Make the shutdown procedure more sane and improve playlist clearing
Matti Hamalainen <ccr@tnsp.org>
parents:
3406
diff
changeset
|
406 |
2313 | 407 gtk_widget_hide(equalizerwin); |
408 gtk_widget_hide(playlistwin); | |
409 gtk_widget_hide(mainwin); | |
410 | |
411 g_source_remove(mainwin_timeout_id); | |
412 | |
413 bmp_config_save(); | |
414 gtk_accel_map_save(bmp_paths[BMP_PATH_ACCEL_FILE]); | |
415 | |
416 plugin_system_cleanup(); | |
417 | |
418 | |
419 /* free and clear each playlist */ | |
420 playlists = playlist_get_playlists(); | |
421 playlists_top = playlists; | |
422 while ( playlists != NULL ) | |
423 { | |
424 playlist_clear((Playlist*)playlists->data); | |
425 playlist_free((Playlist*)playlists->data); | |
426 playlists = g_list_next(playlists); | |
427 } | |
428 g_list_free( playlists_top ); | |
429 | |
430 gtk_main_quit(); | |
431 | |
432 exit(EXIT_SUCCESS); | |
433 } | |
434 | |
3024
883713b145f8
use button-press-event signals
Tomasz Mon <desowin@gmail.com>
parents:
3023
diff
changeset
|
435 gboolean |
883713b145f8
use button-press-event signals
Tomasz Mon <desowin@gmail.com>
parents:
3023
diff
changeset
|
436 mainwin_vis_cb(GtkWidget *widget, GdkEventButton *event) |
3020 | 437 { |
3024
883713b145f8
use button-press-event signals
Tomasz Mon <desowin@gmail.com>
parents:
3023
diff
changeset
|
438 if (event->button == 1) { |
883713b145f8
use button-press-event signals
Tomasz Mon <desowin@gmail.com>
parents:
3023
diff
changeset
|
439 cfg.vis_type++; |
883713b145f8
use button-press-event signals
Tomasz Mon <desowin@gmail.com>
parents:
3023
diff
changeset
|
440 |
883713b145f8
use button-press-event signals
Tomasz Mon <desowin@gmail.com>
parents:
3023
diff
changeset
|
441 if (cfg.vis_type > VIS_OFF) |
883713b145f8
use button-press-event signals
Tomasz Mon <desowin@gmail.com>
parents:
3023
diff
changeset
|
442 cfg.vis_type = VIS_ANALYZER; |
883713b145f8
use button-press-event signals
Tomasz Mon <desowin@gmail.com>
parents:
3023
diff
changeset
|
443 |
883713b145f8
use button-press-event signals
Tomasz Mon <desowin@gmail.com>
parents:
3023
diff
changeset
|
444 mainwin_vis_set_type(cfg.vis_type); |
883713b145f8
use button-press-event signals
Tomasz Mon <desowin@gmail.com>
parents:
3023
diff
changeset
|
445 } else if (event->button == 3) { |
883713b145f8
use button-press-event signals
Tomasz Mon <desowin@gmail.com>
parents:
3023
diff
changeset
|
446 gint x, y; |
883713b145f8
use button-press-event signals
Tomasz Mon <desowin@gmail.com>
parents:
3023
diff
changeset
|
447 gdk_window_get_pointer(NULL, &x, &y, NULL); |
883713b145f8
use button-press-event signals
Tomasz Mon <desowin@gmail.com>
parents:
3023
diff
changeset
|
448 ui_manager_popup_menu_show(GTK_MENU(mainwin_visualization_menu), |
883713b145f8
use button-press-event signals
Tomasz Mon <desowin@gmail.com>
parents:
3023
diff
changeset
|
449 x, y, 3, event->time); |
883713b145f8
use button-press-event signals
Tomasz Mon <desowin@gmail.com>
parents:
3023
diff
changeset
|
450 } |
883713b145f8
use button-press-event signals
Tomasz Mon <desowin@gmail.com>
parents:
3023
diff
changeset
|
451 return TRUE; |
3020 | 452 } |
453 | |
2313 | 454 static void |
455 mainwin_destroy(GtkWidget * widget, gpointer data) | |
456 { | |
457 mainwin_quit_cb(); | |
458 } | |
459 | |
460 static gchar *mainwin_tb_old_text = NULL; | |
461 | |
462 void | |
463 mainwin_lock_info_text(const gchar * text) | |
464 { | |
465 if (mainwin_info_text_locked != TRUE) | |
466 mainwin_tb_old_text = g_strdup(bmp_active_skin->properties.mainwin_othertext_is_status ? | |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
467 UI_SKINNED_TEXTBOX(mainwin_othertext)->text : UI_SKINNED_TEXTBOX(mainwin_info)->text); |
2313 | 468 |
469 mainwin_info_text_locked = TRUE; | |
2911 | 470 if (bmp_active_skin->properties.mainwin_othertext_is_status) |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
471 ui_skinned_textbox_set_text(mainwin_othertext, text); |
2911 | 472 else |
473 ui_skinned_textbox_set_text(mainwin_info, text); | |
2313 | 474 } |
475 | |
476 void | |
477 mainwin_release_info_text(void) | |
478 { | |
479 mainwin_info_text_locked = FALSE; | |
480 | |
481 if (mainwin_tb_old_text != NULL) | |
482 { | |
2911 | 483 if (bmp_active_skin->properties.mainwin_othertext_is_status) |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
484 ui_skinned_textbox_set_text(mainwin_othertext, mainwin_tb_old_text); |
2911 | 485 else |
486 ui_skinned_textbox_set_text(mainwin_info, mainwin_tb_old_text); | |
2313 | 487 g_free(mainwin_tb_old_text); |
488 mainwin_tb_old_text = NULL; | |
489 } | |
490 } | |
491 | |
492 | |
493 static gchar * | |
494 make_mainwin_title(const gchar * title) | |
495 { | |
496 if (title) | |
497 return g_strdup_printf(_("%s - Audacious"), title); | |
498 else | |
499 return g_strdup(_("Audacious")); | |
500 } | |
501 | |
502 void | |
503 mainwin_set_song_title(const gchar * title) | |
504 { | |
3191
c44eb2f310f0
revive dsd's titlebar patch (r3083) due to it works fine with message passing UI update.
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3190
diff
changeset
|
505 gchar *mainwin_title_text = make_mainwin_title(title); |
c44eb2f310f0
revive dsd's titlebar patch (r3083) due to it works fine with message passing UI update.
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3190
diff
changeset
|
506 gtk_window_set_title(GTK_WINDOW(mainwin), mainwin_title_text); |
2313 | 507 } |
508 | |
3241 | 509 static void |
510 mainwin_refresh_visible(void) | |
511 { | |
3277
949480cc9d98
don't do gtk_widget_show_all(mainwin) when player is not visible
Tomasz Mon <desowin@gmail.com>
parents:
3251
diff
changeset
|
512 if (!bmp_active_skin || !cfg.player_visible) |
3241 | 513 return; |
514 | |
515 gtk_widget_show_all(mainwin); | |
516 | |
517 if (!bmp_active_skin->properties.mainwin_text_visible) | |
518 gtk_widget_hide(mainwin_info); | |
519 | |
520 if (!bmp_active_skin->properties.mainwin_vis_visible) | |
521 gtk_widget_hide(mainwin_vis); | |
522 | |
523 if (!bmp_active_skin->properties.mainwin_menurow_visible) | |
524 gtk_widget_hide(mainwin_menurow); | |
525 | |
526 if (bmp_active_skin->properties.mainwin_othertext) { | |
527 gtk_widget_hide(mainwin_rate_text); | |
528 gtk_widget_hide(mainwin_freq_text); | |
529 gtk_widget_hide(mainwin_monostereo); | |
530 | |
531 if (!bmp_active_skin->properties.mainwin_othertext_visible) | |
532 gtk_widget_hide(mainwin_othertext); | |
533 } else { | |
534 gtk_widget_hide(mainwin_othertext); | |
535 } | |
536 | |
537 if (!bmp_active_skin->properties.mainwin_vis_visible) | |
538 gtk_widget_hide(mainwin_vis); | |
539 | |
540 if (!playback_get_playing()) { | |
541 gtk_widget_hide(mainwin_minus_num); | |
542 gtk_widget_hide(mainwin_10min_num); | |
543 gtk_widget_hide(mainwin_min_num); | |
544 gtk_widget_hide(mainwin_10sec_num); | |
545 gtk_widget_hide(mainwin_sec_num); | |
546 | |
547 gtk_widget_hide(mainwin_stime_min); | |
548 gtk_widget_hide(mainwin_stime_sec); | |
549 | |
550 gtk_widget_hide(mainwin_position); | |
551 gtk_widget_hide(mainwin_sposition); | |
552 } | |
553 | |
554 if (cfg.player_shaded) { | |
555 ui_svis_clear_data(mainwin_svis); | |
556 if (cfg.vis_type != VIS_OFF) | |
557 ui_svis_set_visible(mainwin_svis, TRUE); | |
558 else | |
559 ui_svis_set_visible(mainwin_svis, FALSE); | |
560 | |
561 ui_skinned_textbox_set_scroll(mainwin_info, FALSE); | |
562 if (!playback_get_playing()) { | |
563 gtk_widget_hide(mainwin_sposition); | |
564 gtk_widget_hide(mainwin_stime_min); | |
565 gtk_widget_hide(mainwin_stime_sec); | |
566 } | |
567 } else { | |
568 gtk_widget_hide(mainwin_srew); | |
569 gtk_widget_hide(mainwin_splay); | |
570 gtk_widget_hide(mainwin_spause); | |
571 gtk_widget_hide(mainwin_sstop); | |
572 gtk_widget_hide(mainwin_sfwd); | |
573 gtk_widget_hide(mainwin_seject); | |
574 gtk_widget_hide(mainwin_stime_min); | |
575 gtk_widget_hide(mainwin_stime_sec); | |
576 gtk_widget_hide(mainwin_svis); | |
577 gtk_widget_hide(mainwin_sposition); | |
578 ui_vis_clear_data(mainwin_vis); | |
579 if (cfg.vis_type != VIS_OFF) | |
580 ui_vis_set_visible(mainwin_vis, TRUE); | |
581 else | |
582 ui_vis_set_visible(mainwin_vis, FALSE); | |
583 | |
584 ui_skinned_textbox_set_scroll(mainwin_info, cfg.autoscroll); | |
585 } | |
586 } | |
587 | |
3221
9583cd62231f
implement ui_skinned_window_expose
Tomasz Mon <desowin@gmail.com>
parents:
3218
diff
changeset
|
588 void |
2313 | 589 mainwin_refresh_hints(void) |
590 { | |
591 /* positioning and size attributes */ | |
592 if (bmp_active_skin->properties.mainwin_vis_x && bmp_active_skin->properties.mainwin_vis_y) | |
3020 | 593 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_vis), bmp_active_skin->properties.mainwin_vis_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
594 bmp_active_skin->properties.mainwin_vis_y); |
2313 | 595 |
596 if (bmp_active_skin->properties.mainwin_vis_width) | |
3020 | 597 gtk_widget_set_size_request(mainwin_vis, bmp_active_skin->properties.mainwin_vis_width*(1+cfg.doublesize), |
598 UI_VIS(mainwin_vis)->height*(1+cfg.doublesize)); | |
2313 | 599 |
600 if (bmp_active_skin->properties.mainwin_text_x && bmp_active_skin->properties.mainwin_text_y) | |
2911 | 601 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_info), bmp_active_skin->properties.mainwin_text_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
602 bmp_active_skin->properties.mainwin_text_y); |
2313 | 603 |
604 if (bmp_active_skin->properties.mainwin_text_width) | |
2911 | 605 gtk_widget_set_size_request(mainwin_info, bmp_active_skin->properties.mainwin_text_width*(1+cfg.doublesize), |
606 UI_SKINNED_TEXTBOX(mainwin_info)->height*(1+cfg.doublesize)); | |
2313 | 607 |
608 if (bmp_active_skin->properties.mainwin_infobar_x && bmp_active_skin->properties.mainwin_infobar_y) | |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
609 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_othertext), bmp_active_skin->properties.mainwin_infobar_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
610 bmp_active_skin->properties.mainwin_infobar_y); |
2313 | 611 |
612 if (bmp_active_skin->properties.mainwin_number_0_x && bmp_active_skin->properties.mainwin_number_0_y) | |
3001
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
613 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_minus_num), bmp_active_skin->properties.mainwin_number_0_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
614 bmp_active_skin->properties.mainwin_number_0_y); |
2313 | 615 |
616 if (bmp_active_skin->properties.mainwin_number_1_x && bmp_active_skin->properties.mainwin_number_1_y) | |
3001
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
617 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_10min_num), bmp_active_skin->properties.mainwin_number_1_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
618 bmp_active_skin->properties.mainwin_number_1_y); |
2313 | 619 |
620 if (bmp_active_skin->properties.mainwin_number_2_x && bmp_active_skin->properties.mainwin_number_2_y) | |
3001
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
621 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_min_num), bmp_active_skin->properties.mainwin_number_2_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
622 bmp_active_skin->properties.mainwin_number_2_y); |
2313 | 623 |
624 if (bmp_active_skin->properties.mainwin_number_3_x && bmp_active_skin->properties.mainwin_number_3_y) | |
3001
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
625 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_10sec_num), bmp_active_skin->properties.mainwin_number_3_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
626 bmp_active_skin->properties.mainwin_number_3_y); |
2313 | 627 |
628 if (bmp_active_skin->properties.mainwin_number_4_x && bmp_active_skin->properties.mainwin_number_4_y) | |
3001
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
629 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_sec_num), bmp_active_skin->properties.mainwin_number_4_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
630 bmp_active_skin->properties.mainwin_number_4_y); |
2313 | 631 |
632 if (bmp_active_skin->properties.mainwin_playstatus_x && bmp_active_skin->properties.mainwin_playstatus_y) | |
3072
84de3244aeaa
replace Playstatus with UiSkinnedPlaystatus
Tomasz Mon <desowin@gmail.com>
parents:
3070
diff
changeset
|
633 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), mainwin_playstatus, bmp_active_skin->properties.mainwin_playstatus_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
634 bmp_active_skin->properties.mainwin_playstatus_y); |
2313 | 635 |
636 if (bmp_active_skin->properties.mainwin_volume_x && bmp_active_skin->properties.mainwin_volume_y) | |
3045
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
637 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_volume), bmp_active_skin->properties.mainwin_volume_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
638 bmp_active_skin->properties.mainwin_volume_y); |
2313 | 639 |
640 if (bmp_active_skin->properties.mainwin_balance_x && bmp_active_skin->properties.mainwin_balance_y) | |
3045
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
641 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_balance), bmp_active_skin->properties.mainwin_balance_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
642 bmp_active_skin->properties.mainwin_balance_y); |
2313 | 643 |
644 if (bmp_active_skin->properties.mainwin_position_x && bmp_active_skin->properties.mainwin_position_y) | |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
645 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_position), bmp_active_skin->properties.mainwin_position_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
646 bmp_active_skin->properties.mainwin_position_y); |
2313 | 647 |
648 if (bmp_active_skin->properties.mainwin_previous_x && bmp_active_skin->properties.mainwin_previous_y) | |
2821 | 649 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), mainwin_rew, bmp_active_skin->properties.mainwin_previous_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
650 bmp_active_skin->properties.mainwin_previous_y); |
2313 | 651 |
652 if (bmp_active_skin->properties.mainwin_play_x && bmp_active_skin->properties.mainwin_play_y) | |
2821 | 653 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_play), bmp_active_skin->properties.mainwin_play_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
654 bmp_active_skin->properties.mainwin_play_y); |
2313 | 655 |
656 if (bmp_active_skin->properties.mainwin_pause_x && bmp_active_skin->properties.mainwin_pause_y) | |
2821 | 657 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_pause), bmp_active_skin->properties.mainwin_pause_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
658 bmp_active_skin->properties.mainwin_pause_y); |
2313 | 659 |
660 if (bmp_active_skin->properties.mainwin_stop_x && bmp_active_skin->properties.mainwin_stop_y) | |
2821 | 661 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_stop), bmp_active_skin->properties.mainwin_stop_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
662 bmp_active_skin->properties.mainwin_stop_y); |
2313 | 663 |
664 if (bmp_active_skin->properties.mainwin_next_x && bmp_active_skin->properties.mainwin_next_y) | |
2821 | 665 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_fwd), bmp_active_skin->properties.mainwin_next_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
666 bmp_active_skin->properties.mainwin_next_y); |
2313 | 667 |
668 if (bmp_active_skin->properties.mainwin_eject_x && bmp_active_skin->properties.mainwin_eject_y) | |
2821 | 669 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_eject), bmp_active_skin->properties.mainwin_eject_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
670 bmp_active_skin->properties.mainwin_eject_y); |
2313 | 671 |
672 if (bmp_active_skin->properties.mainwin_eqbutton_x && bmp_active_skin->properties.mainwin_eqbutton_y) | |
2843
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
673 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_eq), bmp_active_skin->properties.mainwin_eqbutton_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
674 bmp_active_skin->properties.mainwin_eqbutton_y); |
2313 | 675 |
676 if (bmp_active_skin->properties.mainwin_plbutton_x && bmp_active_skin->properties.mainwin_plbutton_y) | |
2843
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
677 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_pl), bmp_active_skin->properties.mainwin_plbutton_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
678 bmp_active_skin->properties.mainwin_plbutton_y); |
2313 | 679 |
680 if (bmp_active_skin->properties.mainwin_shuffle_x && bmp_active_skin->properties.mainwin_shuffle_y) | |
2843
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
681 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_shuffle), bmp_active_skin->properties.mainwin_shuffle_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
682 bmp_active_skin->properties.mainwin_shuffle_y); |
2313 | 683 |
684 if (bmp_active_skin->properties.mainwin_repeat_x && bmp_active_skin->properties.mainwin_repeat_y) | |
2843
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
685 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_repeat), bmp_active_skin->properties.mainwin_repeat_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
686 bmp_active_skin->properties.mainwin_repeat_y); |
2313 | 687 |
688 if (bmp_active_skin->properties.mainwin_about_x && bmp_active_skin->properties.mainwin_about_y) | |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
689 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_about), bmp_active_skin->properties.mainwin_about_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
690 bmp_active_skin->properties.mainwin_about_y); |
2313 | 691 |
692 if (bmp_active_skin->properties.mainwin_minimize_x && bmp_active_skin->properties.mainwin_minimize_y) | |
2821 | 693 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_minimize), cfg.player_shaded ? 244 : bmp_active_skin->properties.mainwin_minimize_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
694 cfg.player_shaded ? 3 : bmp_active_skin->properties.mainwin_minimize_y); |
2313 | 695 |
696 if (bmp_active_skin->properties.mainwin_shade_x && bmp_active_skin->properties.mainwin_shade_y) | |
2821 | 697 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_shade), cfg.player_shaded ? 254 : bmp_active_skin->properties.mainwin_shade_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
698 cfg.player_shaded ? 3 : bmp_active_skin->properties.mainwin_shade_y); |
2313 | 699 |
700 if (bmp_active_skin->properties.mainwin_close_x && bmp_active_skin->properties.mainwin_close_y) | |
2821 | 701 gtk_fixed_move(GTK_FIXED(SKINNED_WINDOW(mainwin)->fixed), GTK_WIDGET(mainwin_close), cfg.player_shaded ? 264 : bmp_active_skin->properties.mainwin_close_x, |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
702 cfg.player_shaded ? 3 : bmp_active_skin->properties.mainwin_close_y); |
2313 | 703 |
3241 | 704 mainwin_refresh_visible(); |
2313 | 705 /* window size, mainwinWidth && mainwinHeight properties */ |
706 if (bmp_active_skin->properties.mainwin_height && bmp_active_skin->properties.mainwin_width) | |
707 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
708 gint width, height; |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
709 |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
710 gdk_window_get_size(mainwin->window, &width, &height); |
2313 | 711 |
712 if (width == bmp_active_skin->properties.mainwin_width * (cfg.doublesize + 1) && | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
713 height == bmp_active_skin->properties.mainwin_height * (cfg.doublesize + 1)) |
2313 | 714 return; |
715 | |
716 dock_window_resize(GTK_WINDOW(mainwin), cfg.player_shaded ? MAINWIN_SHADED_WIDTH * (cfg.doublesize + 1) : bmp_active_skin->properties.mainwin_width * (cfg.doublesize + 1), | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
717 cfg.player_shaded ? MAINWIN_SHADED_HEIGHT * (cfg.doublesize + 1) : bmp_active_skin->properties.mainwin_height * (cfg.doublesize + 1), |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
718 bmp_active_skin->properties.mainwin_width * (cfg.doublesize + 1), |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
719 bmp_active_skin->properties.mainwin_height * (cfg.doublesize + 1)); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
720 |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
721 gdk_flush(); |
2313 | 722 } |
723 } | |
724 | |
725 void | |
726 mainwin_set_song_info(gint bitrate, | |
727 gint frequency, | |
728 gint n_channels) | |
729 { | |
2949
7a88f6d9cd92
use g_strdup_printf instead of fixed-size gchar*
Tomasz Mon <desowin@gmail.com>
parents:
2947
diff
changeset
|
730 gchar *text; |
2313 | 731 gchar *title; |
732 Playlist *playlist = playlist_get_active(); | |
733 | |
734 playback_set_sample_params(bitrate, frequency, n_channels); | |
735 | |
3221
9583cd62231f
implement ui_skinned_window_expose
Tomasz Mon <desowin@gmail.com>
parents:
3218
diff
changeset
|
736 GDK_THREADS_ENTER(); |
2313 | 737 if (bitrate != -1) { |
738 bitrate /= 1000; | |
739 | |
740 if (bitrate < 1000) { | |
741 /* Show bitrate in 1000s */ | |
2949
7a88f6d9cd92
use g_strdup_printf instead of fixed-size gchar*
Tomasz Mon <desowin@gmail.com>
parents:
2947
diff
changeset
|
742 text = g_strdup_printf("%3d", bitrate); |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
743 ui_skinned_textbox_set_text(mainwin_rate_text, text); |
2313 | 744 } |
745 else { | |
746 /* Show bitrate in 100,000s */ | |
2949
7a88f6d9cd92
use g_strdup_printf instead of fixed-size gchar*
Tomasz Mon <desowin@gmail.com>
parents:
2947
diff
changeset
|
747 text = g_strdup_printf("%2dH", bitrate / 100); |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
748 ui_skinned_textbox_set_text(mainwin_rate_text, text); |
2313 | 749 } |
750 } | |
751 else | |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
752 ui_skinned_textbox_set_text(mainwin_rate_text, _("VBR")); |
2313 | 753 |
754 /* Show sampling frequency in kHz */ | |
2949
7a88f6d9cd92
use g_strdup_printf instead of fixed-size gchar*
Tomasz Mon <desowin@gmail.com>
parents:
2947
diff
changeset
|
755 text = g_strdup_printf("%2d", frequency / 1000); |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
756 ui_skinned_textbox_set_text(mainwin_freq_text, text); |
2313 | 757 |
3073
da99b90d63d3
replace MonoStereo with UiSkinnedMonoStereo
Tomasz Mon <desowin@gmail.com>
parents:
3072
diff
changeset
|
758 ui_skinned_monostereo_set_num_channels(mainwin_monostereo, n_channels); |
2313 | 759 |
760 if (!playback_get_paused() && mainwin_playstatus != NULL) | |
3072
84de3244aeaa
replace Playstatus with UiSkinnedPlaystatus
Tomasz Mon <desowin@gmail.com>
parents:
3070
diff
changeset
|
761 ui_skinned_playstatus_set_status(mainwin_playstatus, STATUS_PLAY); |
2313 | 762 |
3241 | 763 if (bmp_active_skin && bmp_active_skin->properties.mainwin_othertext) |
2313 | 764 { |
765 if (bitrate != -1) | |
2949
7a88f6d9cd92
use g_strdup_printf instead of fixed-size gchar*
Tomasz Mon <desowin@gmail.com>
parents:
2947
diff
changeset
|
766 text = g_strdup_printf("%d kbps, %0.1f kHz, %s", |
2313 | 767 bitrate, |
768 (gfloat) frequency / 1000, | |
769 (n_channels > 1) ? _("stereo") : _("mono")); | |
770 else | |
2949
7a88f6d9cd92
use g_strdup_printf instead of fixed-size gchar*
Tomasz Mon <desowin@gmail.com>
parents:
2947
diff
changeset
|
771 text = g_strdup_printf("VBR, %0.1f kHz, %s", |
2313 | 772 (gfloat) frequency / 1000, |
773 (n_channels > 1) ? _("stereo") : _("mono")); | |
774 | |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
775 ui_skinned_textbox_set_text(mainwin_othertext, text); |
2313 | 776 } |
777 | |
778 title = playlist_get_info_text(playlist); | |
779 mainwin_set_song_title(title); | |
780 g_free(title); | |
3221
9583cd62231f
implement ui_skinned_window_expose
Tomasz Mon <desowin@gmail.com>
parents:
3218
diff
changeset
|
781 GDK_THREADS_LEAVE(); |
2313 | 782 } |
783 | |
784 void | |
785 mainwin_clear_song_info(void) | |
786 { | |
787 if (!mainwin) | |
788 return; | |
789 | |
790 /* clear title */ | |
3191
c44eb2f310f0
revive dsd's titlebar patch (r3083) due to it works fine with message passing UI update.
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3190
diff
changeset
|
791 mainwin_set_song_title(NULL); |
2313 | 792 |
793 /* clear sampling parameters */ | |
794 playback_set_sample_params(0, 0, 0); | |
795 | |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
796 UI_SKINNED_HORIZONTAL_SLIDER(mainwin_position)->pressed = FALSE; |
3042
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
797 UI_SKINNED_HORIZONTAL_SLIDER(mainwin_sposition)->pressed = FALSE; |
2313 | 798 |
799 /* clear sampling parameter displays */ | |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
800 ui_skinned_textbox_set_text(mainwin_rate_text, " "); |
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
801 ui_skinned_textbox_set_text(mainwin_freq_text, " "); |
3073
da99b90d63d3
replace MonoStereo with UiSkinnedMonoStereo
Tomasz Mon <desowin@gmail.com>
parents:
3072
diff
changeset
|
802 ui_skinned_monostereo_set_num_channels(mainwin_monostereo, 0); |
2313 | 803 |
804 if (mainwin_playstatus != NULL) | |
3072
84de3244aeaa
replace Playstatus with UiSkinnedPlaystatus
Tomasz Mon <desowin@gmail.com>
parents:
3070
diff
changeset
|
805 ui_skinned_playstatus_set_status(mainwin_playstatus, STATUS_STOP); |
2313 | 806 |
3241 | 807 mainwin_refresh_visible(); |
2313 | 808 |
809 playlistwin_hide_timer(); | |
3026
e9e925c3adb5
we don't need ui_vis_clear, it only caused problem
Tomasz Mon <desowin@gmail.com>
parents:
3025
diff
changeset
|
810 ui_vis_clear_data(mainwin_vis); |
3054 | 811 ui_svis_clear_data(mainwin_svis); |
2313 | 812 } |
813 | |
814 void | |
815 mainwin_disable_seekbar(void) | |
816 { | |
817 if (!mainwin) | |
818 return; | |
819 | |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
820 gtk_widget_hide(mainwin_position); |
3042
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
821 gtk_widget_hide(mainwin_sposition); |
2313 | 822 } |
823 | |
824 static gboolean | |
825 mainwin_mouse_button_release(GtkWidget * widget, | |
826 GdkEventButton * event, | |
827 gpointer callback_data) | |
828 { | |
829 if (dock_is_moving(GTK_WINDOW(mainwin))) { | |
830 dock_move_release(GTK_WINDOW(mainwin)); | |
831 } | |
832 | |
833 return FALSE; | |
834 } | |
835 | |
836 void | |
837 mainwin_scrolled(GtkWidget *widget, GdkEventScroll *event, | |
838 gpointer callback_data) | |
839 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
840 Playlist *playlist = playlist_get_active(); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
841 |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
842 switch (event->direction) { |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
843 case GDK_SCROLL_UP: |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
844 mainwin_set_volume_diff(cfg.mouse_change); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
845 break; |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
846 case GDK_SCROLL_DOWN: |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
847 mainwin_set_volume_diff(-cfg.mouse_change); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
848 break; |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
849 case GDK_SCROLL_LEFT: |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
850 if (playlist_get_current_length(playlist) != -1) |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
851 playback_seek(CLAMP(playback_get_time() - 1000, |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
852 0, playlist_get_current_length(playlist)) / 1000); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
853 break; |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
854 case GDK_SCROLL_RIGHT: |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
855 if (playlist_get_current_length(playlist) != -1) |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
856 playback_seek(CLAMP(playback_get_time() + 1000, |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
857 0, playlist_get_current_length(playlist)) / 1000); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
858 break; |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
859 } |
2313 | 860 } |
861 | |
862 static gboolean | |
863 mainwin_mouse_button_press(GtkWidget * widget, | |
864 GdkEventButton * event, | |
865 gpointer callback_data) | |
866 { | |
867 if (cfg.doublesize) { | |
868 /* | |
869 * A hack to make doublesize transparent to callbacks. | |
870 * We should make a copy of this data instead of | |
871 * tampering with the data we get from gtk+ | |
872 */ | |
873 event->x /= 2; | |
874 event->y /= 2; | |
875 } | |
876 | |
877 if (event->button == 1 && event->type == GDK_BUTTON_PRESS && | |
878 (cfg.easy_move || event->y < 14)) { | |
2497
204d1bab71f9
[svn] - if (0 && hint_move_resize_available()) -- i'm not sure how this linked as we do not have a hint_move_resize_available().
nenolod
parents:
2496
diff
changeset
|
879 gtk_window_present(GTK_WINDOW(mainwin)); |
204d1bab71f9
[svn] - if (0 && hint_move_resize_available()) -- i'm not sure how this linked as we do not have a hint_move_resize_available().
nenolod
parents:
2496
diff
changeset
|
880 dock_move_press(dock_window_list, GTK_WINDOW(mainwin), event, |
204d1bab71f9
[svn] - if (0 && hint_move_resize_available()) -- i'm not sure how this linked as we do not have a hint_move_resize_available().
nenolod
parents:
2496
diff
changeset
|
881 TRUE); |
2313 | 882 } |
3218
018b37cf0730
hasta la vista old widgetcore
Tomasz Mon <desowin@gmail.com>
parents:
3217
diff
changeset
|
883 else if (event->button == 1 && event->type == GDK_2BUTTON_PRESS && event->y < 14) { |
2313 | 884 mainwin_set_shade(!cfg.player_shaded); |
885 if (dock_is_moving(GTK_WINDOW(mainwin))) | |
886 dock_move_release(GTK_WINDOW(mainwin)); | |
887 } | |
888 | |
889 if (event->button == 3) { | |
3054 | 890 if ( (event->y > 70) && (event->x < 128) ) |
2313 | 891 { |
892 | |
893 ui_manager_popup_menu_show(GTK_MENU(mainwin_playback_menu), | |
894 event->x_root, | |
895 event->y_root, 3, event->time); | |
896 } else { | |
897 /* | |
898 * Pop up the main menu a few pixels down. | |
899 * This will avoid that anything is selected | |
900 * if one right-clicks to focus the window | |
901 * without raising it. | |
902 * | |
903 ***MD I think the above is stupid, people don't expect this | |
904 * | |
905 */ | |
906 ui_manager_popup_menu_show(GTK_MENU(mainwin_general_menu), | |
907 event->x_root, | |
908 event->y_root, 3, event->time); | |
909 } | |
910 } | |
911 | |
912 return FALSE; | |
913 } | |
914 | |
915 static gboolean | |
916 mainwin_keypress(GtkWidget * grab_widget, | |
917 GdkEventKey * event, | |
918 gpointer data) | |
919 { | |
920 Playlist *playlist = playlist_get_active(); | |
921 | |
922 switch (event->keyval) { | |
923 | |
924 case GDK_Up: | |
925 case GDK_KP_Up: | |
926 case GDK_KP_8: | |
927 mainwin_set_volume_diff(2); | |
928 break; | |
929 case GDK_Down: | |
930 case GDK_KP_Down: | |
931 case GDK_KP_2: | |
932 mainwin_set_volume_diff(-2); | |
933 break; | |
934 case GDK_Left: | |
935 case GDK_KP_Left: | |
936 case GDK_KP_7: | |
937 if (playlist_get_current_length(playlist) != -1) | |
938 playback_seek(CLAMP | |
939 (playback_get_time() - 5000, 0, | |
940 playlist_get_current_length(playlist)) / 1000); | |
941 break; | |
942 case GDK_Right: | |
943 case GDK_KP_Right: | |
944 case GDK_KP_9: | |
945 if (playlist_get_current_length(playlist) != -1) | |
946 playback_seek(CLAMP | |
947 (playback_get_time() + 5000, 0, | |
948 playlist_get_current_length(playlist)) / 1000); | |
949 break; | |
950 case GDK_KP_4: | |
951 playlist_prev(playlist); | |
952 break; | |
953 case GDK_KP_6: | |
954 playlist_next(playlist); | |
955 break; | |
956 case GDK_KP_Insert: | |
2500 | 957 ui_jump_to_track(); |
2313 | 958 break; |
3184
564359ff9304
bound the Enter key to the play button
Cristi Magherusan <majeru@atheme-project.org>
parents:
3177
diff
changeset
|
959 case GDK_Return: |
564359ff9304
bound the Enter key to the play button
Cristi Magherusan <majeru@atheme-project.org>
parents:
3177
diff
changeset
|
960 case GDK_KP_Enter: |
2313 | 961 case GDK_KP_5: |
962 mainwin_play_pushed(); | |
963 break; | |
2693
b47f5577bea0
[svn] - Made the Space key pause/unpause playback (like e.g. mplayer)
mf0102
parents:
2651
diff
changeset
|
964 case GDK_space: |
b47f5577bea0
[svn] - Made the Space key pause/unpause playback (like e.g. mplayer)
mf0102
parents:
2651
diff
changeset
|
965 playback_pause(); |
b47f5577bea0
[svn] - Made the Space key pause/unpause playback (like e.g. mplayer)
mf0102
parents:
2651
diff
changeset
|
966 break; |
2313 | 967 case GDK_Escape: |
968 mainwin_minimize_cb(); | |
969 break; | |
3350
1292e4ca0f08
press ctrl+tab to switch between windows
Tomasz Mon <desowin@gmail.com>
parents:
3311
diff
changeset
|
970 case GDK_Tab: |
1292e4ca0f08
press ctrl+tab to switch between windows
Tomasz Mon <desowin@gmail.com>
parents:
3311
diff
changeset
|
971 if (event->state & GDK_CONTROL_MASK) |
3533
09e457d346f9
Fix Ctrl-Tab in main window.
Jonathan Schleifer <js@h3c.de>
parents:
3531
diff
changeset
|
972 equalizerwin_real_show(); |
3350
1292e4ca0f08
press ctrl+tab to switch between windows
Tomasz Mon <desowin@gmail.com>
parents:
3311
diff
changeset
|
973 break; |
3531
18391c12c18c
Ctrl-C copies current title to clipboard now.
Jonathan Schleifer <js@h3c.de>
parents:
3526
diff
changeset
|
974 case GDK_c: |
18391c12c18c
Ctrl-C copies current title to clipboard now.
Jonathan Schleifer <js@h3c.de>
parents:
3526
diff
changeset
|
975 if (event->state & GDK_CONTROL_MASK) { |
18391c12c18c
Ctrl-C copies current title to clipboard now.
Jonathan Schleifer <js@h3c.de>
parents:
3526
diff
changeset
|
976 Playlist *playlist = playlist_get_active(); |
18391c12c18c
Ctrl-C copies current title to clipboard now.
Jonathan Schleifer <js@h3c.de>
parents:
3526
diff
changeset
|
977 gint pos = playlist_get_position(playlist); |
18391c12c18c
Ctrl-C copies current title to clipboard now.
Jonathan Schleifer <js@h3c.de>
parents:
3526
diff
changeset
|
978 gchar *title = playlist_get_songtitle(playlist, pos); |
18391c12c18c
Ctrl-C copies current title to clipboard now.
Jonathan Schleifer <js@h3c.de>
parents:
3526
diff
changeset
|
979 |
18391c12c18c
Ctrl-C copies current title to clipboard now.
Jonathan Schleifer <js@h3c.de>
parents:
3526
diff
changeset
|
980 if (title != NULL) { |
18391c12c18c
Ctrl-C copies current title to clipboard now.
Jonathan Schleifer <js@h3c.de>
parents:
3526
diff
changeset
|
981 GtkClipboard *clip = gtk_clipboard_get(GDK_SELECTION_CLIPBOARD); |
18391c12c18c
Ctrl-C copies current title to clipboard now.
Jonathan Schleifer <js@h3c.de>
parents:
3526
diff
changeset
|
982 gtk_clipboard_set_text(clip, title, -1); |
18391c12c18c
Ctrl-C copies current title to clipboard now.
Jonathan Schleifer <js@h3c.de>
parents:
3526
diff
changeset
|
983 gtk_clipboard_store(clip); |
18391c12c18c
Ctrl-C copies current title to clipboard now.
Jonathan Schleifer <js@h3c.de>
parents:
3526
diff
changeset
|
984 } |
18391c12c18c
Ctrl-C copies current title to clipboard now.
Jonathan Schleifer <js@h3c.de>
parents:
3526
diff
changeset
|
985 |
18391c12c18c
Ctrl-C copies current title to clipboard now.
Jonathan Schleifer <js@h3c.de>
parents:
3526
diff
changeset
|
986 return TRUE; |
18391c12c18c
Ctrl-C copies current title to clipboard now.
Jonathan Schleifer <js@h3c.de>
parents:
3526
diff
changeset
|
987 } |
18391c12c18c
Ctrl-C copies current title to clipboard now.
Jonathan Schleifer <js@h3c.de>
parents:
3526
diff
changeset
|
988 return FALSE; |
2313 | 989 default: |
990 return FALSE; | |
991 } | |
992 | |
993 return TRUE; | |
994 } | |
995 | |
996 static void | |
997 mainwin_jump_to_time_cb(GtkWidget * widget, | |
998 GtkWidget * entry) | |
999 { | |
1000 guint min = 0, sec = 0, params; | |
1001 gint time; | |
1002 Playlist *playlist = playlist_get_active(); | |
1003 | |
1004 params = sscanf(gtk_entry_get_text(GTK_ENTRY(entry)), "%u:%u", | |
1005 &min, &sec); | |
1006 if (params == 2) | |
1007 time = (min * 60) + sec; | |
1008 else if (params == 1) | |
1009 time = min; | |
1010 else | |
1011 return; | |
1012 | |
1013 if (playlist_get_current_length(playlist) > -1 && | |
1014 time <= (playlist_get_current_length(playlist) / 1000)) | |
1015 { | |
1016 playback_seek(time); | |
1017 gtk_widget_destroy(mainwin_jtt); | |
1018 } | |
1019 } | |
1020 | |
1021 | |
1022 void | |
1023 mainwin_jump_to_time(void) | |
1024 { | |
1025 GtkWidget *vbox, *hbox_new, *hbox_total; | |
1026 GtkWidget *time_entry, *label, *bbox, *jump, *cancel; | |
1027 guint tindex; | |
1028 gchar time_str[10]; | |
1029 | |
1030 if (!playback_get_playing()) { | |
1031 report_error("JIT can't be launched when no track is being played.\n"); | |
1032 return; | |
1033 } | |
1034 | |
1035 if (mainwin_jtt) { | |
1036 gtk_window_present(GTK_WINDOW(mainwin_jtt)); | |
1037 return; | |
1038 } | |
1039 | |
1040 mainwin_jtt = gtk_window_new(GTK_WINDOW_TOPLEVEL); | |
1041 gtk_window_set_type_hint(GTK_WINDOW(mainwin_jtt), | |
1042 GDK_WINDOW_TYPE_HINT_DIALOG); | |
1043 | |
1044 gtk_window_set_title(GTK_WINDOW(mainwin_jtt), _("Jump to Time")); | |
1045 gtk_window_set_position(GTK_WINDOW(mainwin_jtt), GTK_WIN_POS_CENTER); | |
1046 gtk_window_set_transient_for(GTK_WINDOW(mainwin_jtt), | |
1047 GTK_WINDOW(mainwin)); | |
1048 | |
1049 g_signal_connect(mainwin_jtt, "destroy", | |
1050 G_CALLBACK(gtk_widget_destroyed), &mainwin_jtt); | |
1051 gtk_container_border_width(GTK_CONTAINER(mainwin_jtt), 10); | |
1052 | |
1053 vbox = gtk_vbox_new(FALSE, 5); | |
1054 gtk_container_add(GTK_CONTAINER(mainwin_jtt), vbox); | |
1055 | |
1056 hbox_new = gtk_hbox_new(FALSE, 0); | |
1057 gtk_box_pack_start(GTK_BOX(vbox), hbox_new, TRUE, TRUE, 5); | |
1058 | |
1059 time_entry = gtk_entry_new(); | |
1060 gtk_box_pack_start(GTK_BOX(hbox_new), time_entry, FALSE, FALSE, 5); | |
1061 g_signal_connect(time_entry, "activate", | |
1062 G_CALLBACK(mainwin_jump_to_time_cb), time_entry); | |
1063 | |
1064 gtk_widget_set_size_request(time_entry, 70, -1); | |
1065 label = gtk_label_new(_("minutes:seconds")); | |
1066 gtk_box_pack_start(GTK_BOX(hbox_new), label, FALSE, FALSE, 5); | |
1067 | |
1068 hbox_total = gtk_hbox_new(FALSE, 0); | |
1069 gtk_box_pack_start(GTK_BOX(vbox), hbox_total, TRUE, TRUE, 5); | |
1070 gtk_widget_show(hbox_total); | |
1071 | |
1072 /* FIXME: Disable display of current track length. It's not | |
1073 updated when track changes */ | |
1074 #if 0 | |
1075 label = gtk_label_new(_("Track length:")); | |
1076 gtk_box_pack_start(GTK_BOX(hbox_total), label, FALSE, FALSE, 5); | |
1077 | |
1078 len = playlist_get_current_length() / 1000; | |
1079 g_snprintf(time_str, sizeof(time_str), "%u:%2.2u", len / 60, len % 60); | |
1080 label = gtk_label_new(time_str); | |
1081 | |
1082 gtk_box_pack_start(GTK_BOX(hbox_total), label, FALSE, FALSE, 10); | |
1083 #endif | |
1084 | |
1085 bbox = gtk_hbutton_box_new(); | |
1086 gtk_box_pack_start(GTK_BOX(vbox), bbox, TRUE, TRUE, 0); | |
1087 gtk_button_box_set_layout(GTK_BUTTON_BOX(bbox), GTK_BUTTONBOX_END); | |
1088 gtk_button_box_set_spacing(GTK_BUTTON_BOX(bbox), 5); | |
1089 | |
1090 cancel = gtk_button_new_from_stock(GTK_STOCK_CANCEL); | |
1091 GTK_WIDGET_SET_FLAGS(cancel, GTK_CAN_DEFAULT); | |
1092 gtk_container_add(GTK_CONTAINER(bbox), cancel); | |
1093 g_signal_connect_swapped(cancel, "clicked", | |
1094 G_CALLBACK(gtk_widget_destroy), mainwin_jtt); | |
1095 | |
1096 jump = gtk_button_new_from_stock(GTK_STOCK_JUMP_TO); | |
1097 GTK_WIDGET_SET_FLAGS(jump, GTK_CAN_DEFAULT); | |
1098 gtk_container_add(GTK_CONTAINER(bbox), jump); | |
1099 g_signal_connect(jump, "clicked", | |
1100 G_CALLBACK(mainwin_jump_to_time_cb), time_entry); | |
1101 | |
1102 tindex = playback_get_time() / 1000; | |
1103 g_snprintf(time_str, sizeof(time_str), "%u:%2.2u", tindex / 60, | |
1104 tindex % 60); | |
1105 gtk_entry_set_text(GTK_ENTRY(time_entry), time_str); | |
1106 | |
1107 gtk_entry_select_region(GTK_ENTRY(time_entry), 0, strlen(time_str)); | |
1108 | |
1109 gtk_widget_show_all(mainwin_jtt); | |
1110 | |
1111 gtk_widget_grab_focus(time_entry); | |
1112 gtk_widget_grab_default(jump); | |
1113 } | |
1114 | |
1115 /* | |
1116 * Rewritten 09/13/06: | |
1117 * | |
1118 * Remove all of this flaky iter/sourcelist/strsplit stuff. | |
1119 * All we care about is the filepath. | |
1120 * | |
2974
b93bd39923bf
Rework DnD received data function to use g_filename_from_uri().
William Pitcock <nenolod@atheme-project.org>
parents:
2964
diff
changeset
|
1121 * We can figure this out and easily pass it to g_filename_from_uri(). |
2313 | 1122 * - nenolod |
1123 */ | |
1124 void | |
1125 mainwin_drag_data_received(GtkWidget * widget, | |
1126 GdkDragContext * context, | |
1127 gint x, | |
1128 gint y, | |
1129 GtkSelectionData * selection_data, | |
1130 guint info, | |
1131 guint time, | |
1132 gpointer user_data) | |
1133 { | |
1134 Playlist *playlist = playlist_get_active(); | |
1135 | |
1136 g_return_if_fail(selection_data != NULL); | |
1137 g_return_if_fail(selection_data->data != NULL); | |
1138 | |
1139 if (str_has_prefix_nocase((gchar *) selection_data->data, "fonts:///")) | |
1140 { | |
2974
b93bd39923bf
Rework DnD received data function to use g_filename_from_uri().
William Pitcock <nenolod@atheme-project.org>
parents:
2964
diff
changeset
|
1141 gchar *path = (gchar *) selection_data->data; |
b93bd39923bf
Rework DnD received data function to use g_filename_from_uri().
William Pitcock <nenolod@atheme-project.org>
parents:
2964
diff
changeset
|
1142 gchar *decoded = g_filename_from_uri(path, NULL, NULL); |
b93bd39923bf
Rework DnD received data function to use g_filename_from_uri().
William Pitcock <nenolod@atheme-project.org>
parents:
2964
diff
changeset
|
1143 |
b93bd39923bf
Rework DnD received data function to use g_filename_from_uri().
William Pitcock <nenolod@atheme-project.org>
parents:
2964
diff
changeset
|
1144 if (decoded == NULL) |
b93bd39923bf
Rework DnD received data function to use g_filename_from_uri().
William Pitcock <nenolod@atheme-project.org>
parents:
2964
diff
changeset
|
1145 return; |
2313 | 1146 |
1147 cfg.playlist_font = g_strconcat(decoded, strrchr(cfg.playlist_font, ' '), NULL); | |
3217 | 1148 ui_skinned_playlist_set_font(cfg.playlist_font); |
2313 | 1149 playlistwin_update_list(playlist); |
1150 | |
1151 g_free(decoded); | |
1152 | |
1153 return; | |
1154 } | |
1155 | |
1156 playlist_clear(playlist); | |
1157 playlist_add_url(playlist, (gchar *) selection_data->data); | |
1158 playback_initiate(); | |
1159 } | |
1160 | |
1161 static void | |
1162 on_add_url_add_clicked(GtkWidget * widget, | |
1163 GtkWidget * entry) | |
1164 { | |
1165 const gchar *text = gtk_entry_get_text(GTK_ENTRY(entry)); | |
1166 if (text && *text) | |
1167 playlist_add_url(playlist_get_active(), text); | |
1168 } | |
1169 | |
1170 static void | |
1171 on_add_url_ok_clicked(GtkWidget * widget, | |
1172 GtkWidget * entry) | |
1173 { | |
1174 Playlist *playlist = playlist_get_active(); | |
1175 | |
1176 const gchar *text = gtk_entry_get_text(GTK_ENTRY(entry)); | |
1177 if (text && *text) | |
1178 { | |
1179 playlist_clear(playlist); | |
1180 playlist_add_url(playlist, text); | |
1181 playback_initiate(); | |
1182 } | |
1183 } | |
1184 | |
2651
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1185 static void |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1186 on_visibility_warning_toggle(GtkToggleButton *tbt, gpointer unused) |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1187 { |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1188 cfg.warn_about_win_visibility = !gtk_toggle_button_get_active(tbt); |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1189 } |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1190 |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1191 static void |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1192 on_visibility_warning_response(GtkDialog *dlg, gint r_id, gpointer unused) |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1193 { |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1194 switch (r_id) |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1195 { |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1196 case GTK_RESPONSE_OK: |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1197 mainwin_show(TRUE); |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1198 break; |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1199 case GTK_RESPONSE_CANCEL: |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1200 default: |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1201 break; |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1202 } |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1203 gtk_widget_destroy(GTK_WIDGET(dlg)); |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1204 } |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1205 |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1206 void |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1207 mainwin_show_visibility_warning(void) |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1208 { |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1209 if (cfg.warn_about_win_visibility) |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1210 { |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1211 GtkWidget *label, *checkbt, *vbox; |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1212 GtkWidget *warning_dlg = gtk_dialog_new_with_buttons( _("Audacious - visibility warning") , |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1213 GTK_WINDOW(mainwin) , GTK_DIALOG_DESTROY_WITH_PARENT , |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1214 _("Show main player window") , GTK_RESPONSE_OK , |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1215 _("Ignore") , GTK_RESPONSE_CANCEL , NULL ); |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1216 vbox = gtk_vbox_new( FALSE , 4 ); |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1217 gtk_container_set_border_width( GTK_CONTAINER(vbox) , 4 ); |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1218 gtk_box_pack_start( GTK_BOX(GTK_DIALOG(warning_dlg)->vbox) , vbox , TRUE , TRUE , 0 ); |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1219 label = gtk_label_new( _("Audacious has been started with all of its windows hidden.\n" |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1220 "You may want to show the player window again to control Audacious; " |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1221 "otherwise, you'll have to control it remotely via audtool or " |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1222 "enabled plugins (such as the statusicon plugin).") ); |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1223 gtk_label_set_line_wrap( GTK_LABEL(label) , TRUE ); |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1224 gtk_misc_set_alignment( GTK_MISC(label) , 0.0 , 0.0 ); |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1225 checkbt = gtk_check_button_new_with_label( _("Always ignore, show/hide is controlled remotely") ); |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1226 gtk_box_pack_start( GTK_BOX(vbox) , label , TRUE , TRUE , 0 ); |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1227 gtk_box_pack_start( GTK_BOX(vbox) , checkbt , TRUE , TRUE , 0 ); |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1228 g_signal_connect( G_OBJECT(checkbt) , "toggled" , |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1229 G_CALLBACK(on_visibility_warning_toggle) , NULL ); |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1230 g_signal_connect( G_OBJECT(warning_dlg) , "response" , |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1231 G_CALLBACK(on_visibility_warning_response) , NULL ); |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1232 gtk_widget_show_all(warning_dlg); |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1233 } |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1234 } |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1235 |
2313 | 1236 void |
1237 mainwin_show_add_url_window(void) | |
1238 { | |
1239 static GtkWidget *url_window = NULL; | |
1240 | |
1241 if (!url_window) { | |
1242 url_window = | |
1243 util_add_url_dialog_new(_("Enter location to play:"), | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
1244 G_CALLBACK(on_add_url_ok_clicked), |
2313 | 1245 G_CALLBACK(on_add_url_add_clicked)); |
1246 gtk_window_set_transient_for(GTK_WINDOW(url_window), | |
1247 GTK_WINDOW(mainwin)); | |
1248 g_signal_connect(url_window, "destroy", | |
1249 G_CALLBACK(gtk_widget_destroyed), | |
1250 &url_window); | |
1251 } | |
1252 | |
1253 gtk_window_present(GTK_WINDOW(url_window)); | |
1254 } | |
1255 | |
1256 static void | |
1257 check_set( GtkActionGroup * action_group , | |
1258 const gchar * action_name , | |
1259 gboolean is_on ) | |
1260 { | |
1261 /* check_set noew uses gtkaction */ | |
1262 GtkAction *action = gtk_action_group_get_action( action_group , action_name ); | |
1263 if ( action != NULL ) | |
1264 gtk_toggle_action_set_active( GTK_TOGGLE_ACTION(action) , is_on ); | |
1265 return; | |
1266 } | |
1267 | |
1268 void | |
1269 mainwin_eject_pushed(void) | |
1270 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
1271 run_filebrowser(PLAY_BUTTON); |
2313 | 1272 } |
1273 | |
1274 void | |
1275 mainwin_rev_pushed(void) | |
1276 { | |
1277 g_get_current_time(&cb_time); | |
1278 | |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
1279 seek_initial_pos = ui_skinned_horizontal_slider_get_position(mainwin_position); |
2313 | 1280 seek_state = MAINWIN_SEEK_REV; |
1281 } | |
1282 | |
1283 void | |
1284 mainwin_rev_release(void) | |
1285 { | |
1286 GTimeVal now_time; | |
1287 GTimeVal delta_time; | |
1288 gulong now_dur; | |
1289 | |
1290 g_get_current_time(&now_time); | |
1291 | |
1292 delta_time.tv_usec = now_time.tv_usec - cb_time.tv_usec; | |
1293 delta_time.tv_sec = now_time.tv_sec - cb_time.tv_sec; | |
1294 | |
1295 now_dur = labs((delta_time.tv_sec * 1000) + (glong) (delta_time.tv_usec / 1000)); | |
1296 | |
1297 if ( now_dur <= TRISTATE_THRESHOLD ) | |
1298 { | |
1299 /* interpret as 'skip to previous song' */ | |
1300 playlist_prev(playlist_get_active()); | |
1301 } | |
1302 else | |
1303 { | |
1304 /* interpret as 'seek' */ | |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
1305 mainwin_position_release_cb( mainwin_position, ui_skinned_horizontal_slider_get_position(mainwin_position) ); |
2313 | 1306 } |
1307 | |
1308 seek_state = MAINWIN_SEEK_NIL; | |
1309 } | |
1310 | |
1311 void | |
1312 mainwin_fwd_pushed(void) | |
1313 { | |
1314 g_get_current_time(&cb_time); | |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
1315 seek_initial_pos = ui_skinned_horizontal_slider_get_position(mainwin_position); |
2313 | 1316 seek_state = MAINWIN_SEEK_FWD; |
1317 } | |
1318 | |
1319 void | |
1320 mainwin_fwd_release(void) | |
1321 { | |
1322 GTimeVal now_time; | |
1323 GTimeVal delta_time; | |
1324 gulong now_dur; | |
1325 | |
1326 g_get_current_time(&now_time); | |
1327 | |
1328 delta_time.tv_usec = now_time.tv_usec - cb_time.tv_usec; | |
1329 delta_time.tv_sec = now_time.tv_sec - cb_time.tv_sec; | |
1330 | |
1331 now_dur = labs((delta_time.tv_sec * 1000) + (glong) (delta_time.tv_usec / 1000)); | |
1332 | |
1333 if ( now_dur <= TRISTATE_THRESHOLD ) | |
1334 { | |
2480
bb2f191895ce
[svn] - fixed crash when skipping to next song with an empty playlist
marvin
parents:
2478
diff
changeset
|
1335 /* interpret as 'skip to next song' */ |
2313 | 1336 playlist_next(playlist_get_active()); |
1337 } | |
1338 else | |
1339 { | |
1340 /* interpret as 'seek' */ | |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
1341 mainwin_position_release_cb( mainwin_position, ui_skinned_horizontal_slider_get_position(mainwin_position) ); |
2313 | 1342 } |
1343 | |
1344 seek_state = MAINWIN_SEEK_NIL; | |
1345 } | |
1346 | |
1347 void | |
1348 mainwin_play_pushed(void) | |
1349 { | |
1350 if (ab_position_a != -1) | |
1351 playback_seek(ab_position_a / 1000); | |
1352 if (playback_get_paused()) { | |
1353 playback_pause(); | |
1354 return; | |
1355 } | |
1356 | |
1357 if (playlist_get_length(playlist_get_active())) | |
1358 playback_initiate(); | |
1359 else | |
1360 mainwin_eject_pushed(); | |
1361 } | |
1362 | |
1363 void | |
1364 mainwin_stop_pushed(void) | |
1365 { | |
1366 ip_data.stop = TRUE; | |
3241 | 1367 playback_stop(); |
2313 | 1368 mainwin_clear_song_info(); |
3082
91df04ec5ef7
From: Daniel Drake <dsd@gentoo.org>
William Pitcock <nenolod@atheme-project.org>
parents:
3042
diff
changeset
|
1369 ab_position_a = ab_position_b = -1; |
2313 | 1370 ip_data.stop = FALSE; |
1371 } | |
1372 | |
1373 void | |
1374 mainwin_shuffle_pushed(gboolean toggled) | |
1375 { | |
1376 check_set( toggleaction_group_others , "playback shuffle" , toggled ); | |
1377 } | |
1378 | |
2843
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1379 void mainwin_shuffle_pushed_cb(void) { |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1380 mainwin_shuffle_pushed(UI_SKINNED_BUTTON(mainwin_shuffle)->inside); |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1381 } |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1382 |
2313 | 1383 void |
1384 mainwin_repeat_pushed(gboolean toggled) | |
1385 { | |
1386 check_set( toggleaction_group_others , "playback repeat" , toggled ); | |
1387 } | |
1388 | |
2843
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1389 void mainwin_repeat_pushed_cb(void) { |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1390 mainwin_repeat_pushed(UI_SKINNED_BUTTON(mainwin_repeat)->inside); |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1391 } |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1392 |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1393 void mainwin_equalizer_pushed_cb(void) { |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1394 mainwin_eq_pushed(UI_SKINNED_BUTTON(mainwin_eq)->inside); |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1395 } |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1396 |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1397 void mainwin_playlist_pushed_cb(void) { |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1398 mainwin_pl_pushed(UI_SKINNED_BUTTON(mainwin_pl)->inside); |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1399 } |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1400 |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1401 void |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1402 mainwin_eq_pushed(gboolean toggled) |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1403 { |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1404 equalizerwin_show(toggled); |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1405 } |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
1406 |
2313 | 1407 void |
1408 mainwin_pl_pushed(gboolean toggled) | |
1409 { | |
1410 if (toggled) | |
1411 playlistwin_show(); | |
1412 else | |
1413 playlistwin_hide(); | |
1414 } | |
1415 | |
1416 gint | |
1417 mainwin_spos_frame_cb(gint pos) | |
1418 { | |
1419 if (mainwin_sposition) { | |
3042
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
1420 gint x = 0; |
2313 | 1421 if (pos < 6) |
3042
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
1422 x = 17; |
2313 | 1423 else if (pos < 9) |
3042
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
1424 x = 20; |
2313 | 1425 else |
3042
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
1426 x = 23; |
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
1427 |
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
1428 UI_SKINNED_HORIZONTAL_SLIDER(mainwin_sposition)->knob_nx = x; |
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
1429 UI_SKINNED_HORIZONTAL_SLIDER(mainwin_sposition)->knob_px = x; |
2313 | 1430 } |
1431 return 1; | |
1432 } | |
1433 | |
1434 void | |
3042
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
1435 mainwin_spos_motion_cb(GtkWidget *widget, gint pos) |
2313 | 1436 { |
1437 gint time; | |
1438 gchar *time_msg; | |
1439 Playlist *playlist = playlist_get_active(); | |
1440 | |
1441 pos--; | |
1442 | |
1443 time = ((playlist_get_current_length(playlist) / 1000) * pos) / 12; | |
1444 | |
1445 if (cfg.timer_mode == TIMER_REMAINING) { | |
1446 time = (playlist_get_current_length(playlist) / 1000) - time; | |
1447 time_msg = g_strdup_printf("-%2.2d", time / 60); | |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
1448 ui_skinned_textbox_set_text(mainwin_stime_min, time_msg); |
2313 | 1449 g_free(time_msg); |
1450 } | |
1451 else { | |
1452 time_msg = g_strdup_printf(" %2.2d", time / 60); | |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
1453 ui_skinned_textbox_set_text(mainwin_stime_min, time_msg); |
2313 | 1454 g_free(time_msg); |
1455 } | |
1456 | |
1457 time_msg = g_strdup_printf("%2.2d", time % 60); | |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
1458 ui_skinned_textbox_set_text(mainwin_stime_sec, time_msg); |
2313 | 1459 g_free(time_msg); |
1460 } | |
1461 | |
1462 void | |
3042
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
1463 mainwin_spos_release_cb(GtkWidget *widget, gint pos) |
2313 | 1464 { |
1465 playback_seek(((playlist_get_current_length(playlist_get_active()) / 1000) * | |
1466 (pos - 1)) / 12); | |
1467 } | |
1468 | |
1469 void | |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
1470 mainwin_position_motion_cb(GtkWidget *widget, gint pos) |
2313 | 1471 { |
1472 gint length, time; | |
1473 gchar *seek_msg; | |
1474 | |
1475 length = playlist_get_current_length(playlist_get_active()) / 1000; | |
1476 time = (length * pos) / 219; | |
3108
710b3aca4d64
Lower-case letters are more convenient, aren't they ? (anyhow bitmap fonts option is still available)
Stany HENRY <StrassBoy@gmail.com>
parents:
3095
diff
changeset
|
1477 seek_msg = g_strdup_printf(_("Seek to: %d:%-2.2d/%d:%-2.2d (%d%%)"), |
2313 | 1478 time / 60, time % 60, |
1479 length / 60, length % 60, | |
1480 (length != 0) ? (time * 100) / length : 0); | |
1481 mainwin_lock_info_text(seek_msg); | |
1482 g_free(seek_msg); | |
1483 } | |
1484 | |
1485 void | |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
1486 mainwin_position_release_cb(GtkWidget *widget, gint pos) |
2313 | 1487 { |
1488 gint length, time; | |
1489 | |
1490 length = playlist_get_current_length(playlist_get_active()) / 1000; | |
1491 time = (length * pos) / 219; | |
1492 playback_seek(time); | |
1493 mainwin_release_info_text(); | |
1494 } | |
1495 | |
1496 gint | |
1497 mainwin_volume_frame_cb(gint pos) | |
1498 { | |
1499 return (gint) rint((pos / 52.0) * 28); | |
1500 } | |
1501 | |
1502 void | |
1503 mainwin_adjust_volume_motion(gint v) | |
1504 { | |
1505 gchar *volume_msg; | |
1506 | |
1507 setting_volume = TRUE; | |
1508 | |
3108
710b3aca4d64
Lower-case letters are more convenient, aren't they ? (anyhow bitmap fonts option is still available)
Stany HENRY <StrassBoy@gmail.com>
parents:
3095
diff
changeset
|
1509 volume_msg = g_strdup_printf(_("Volume: %d%%"), v); |
2313 | 1510 mainwin_lock_info_text(volume_msg); |
1511 g_free(volume_msg); | |
1512 | |
1513 if (balance < 0) | |
1514 input_set_volume(v, (v * (100 - abs(balance))) / 100); | |
1515 else if (balance > 0) | |
1516 input_set_volume((v * (100 - abs(balance))) / 100, v); | |
1517 else | |
1518 input_set_volume(v, v); | |
1519 } | |
1520 | |
1521 void | |
1522 mainwin_adjust_volume_release(void) | |
1523 { | |
1524 mainwin_release_info_text(); | |
1525 setting_volume = FALSE; | |
1526 read_volume(VOLUME_ADJUSTED); | |
1527 } | |
1528 | |
1529 void | |
1530 mainwin_adjust_balance_motion(gint b) | |
1531 { | |
1532 gchar *balance_msg; | |
1533 gint v, pvl, pvr; | |
1534 | |
1535 setting_volume = TRUE; | |
1536 balance = b; | |
1537 input_get_volume(&pvl, &pvr); | |
1538 v = MAX(pvl, pvr); | |
1539 if (b < 0) { | |
3108
710b3aca4d64
Lower-case letters are more convenient, aren't they ? (anyhow bitmap fonts option is still available)
Stany HENRY <StrassBoy@gmail.com>
parents:
3095
diff
changeset
|
1540 balance_msg = g_strdup_printf(_("Balance: %d%% left"), -b); |
2313 | 1541 input_set_volume(v, (gint) rint(((100 + b) / 100.0) * v)); |
1542 } | |
1543 else if (b == 0) { | |
3108
710b3aca4d64
Lower-case letters are more convenient, aren't they ? (anyhow bitmap fonts option is still available)
Stany HENRY <StrassBoy@gmail.com>
parents:
3095
diff
changeset
|
1544 balance_msg = g_strdup_printf(_("Balance: center")); |
2313 | 1545 input_set_volume(v, v); |
1546 } | |
1547 else { /* b > 0 */ | |
3108
710b3aca4d64
Lower-case letters are more convenient, aren't they ? (anyhow bitmap fonts option is still available)
Stany HENRY <StrassBoy@gmail.com>
parents:
3095
diff
changeset
|
1548 balance_msg = g_strdup_printf(_("Balance: %d%% right"), b); |
2313 | 1549 input_set_volume((gint) rint(((100 - b) / 100.0) * v), v); |
1550 } | |
1551 mainwin_lock_info_text(balance_msg); | |
1552 g_free(balance_msg); | |
1553 } | |
1554 | |
1555 void | |
1556 mainwin_adjust_balance_release(void) | |
1557 { | |
1558 mainwin_release_info_text(); | |
1559 setting_volume = FALSE; | |
1560 read_volume(VOLUME_ADJUSTED); | |
1561 } | |
1562 | |
1563 void | |
1564 mainwin_set_volume_slider(gint percent) | |
1565 { | |
3045
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
1566 ui_skinned_horizontal_slider_set_position(mainwin_volume, (gint) rint((percent * 51) / 100.0)); |
2313 | 1567 } |
1568 | |
1569 void | |
1570 mainwin_set_balance_slider(gint percent) | |
1571 { | |
3045
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
1572 ui_skinned_horizontal_slider_set_position(mainwin_balance, (gint) rint(((percent * 12) / 100.0) + 12)); |
2313 | 1573 } |
1574 | |
1575 void | |
3045
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
1576 mainwin_volume_motion_cb(GtkWidget *widget, gint pos) |
2313 | 1577 { |
1578 gint vol = (pos * 100) / 51; | |
1579 mainwin_adjust_volume_motion(vol); | |
1580 equalizerwin_set_volume_slider(vol); | |
1581 } | |
1582 | |
1583 void | |
3045
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
1584 mainwin_volume_release_cb(GtkWidget *widget, gint pos) |
2313 | 1585 { |
1586 mainwin_adjust_volume_release(); | |
1587 } | |
1588 | |
1589 gint | |
1590 mainwin_balance_frame_cb(gint pos) | |
1591 { | |
1592 return ((abs(pos - 12) * 28) / 13); | |
1593 } | |
1594 | |
1595 void | |
3045
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
1596 mainwin_balance_motion_cb(GtkWidget *widget, gint pos) |
2313 | 1597 { |
1598 gint bal = ((pos - 12) * 100) / 12; | |
1599 mainwin_adjust_balance_motion(bal); | |
1600 equalizerwin_set_balance_slider(bal); | |
1601 } | |
1602 | |
1603 void | |
3045
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
1604 mainwin_balance_release_cb(GtkWidget *widget, gint pos) |
2313 | 1605 { |
1606 mainwin_adjust_volume_release(); | |
1607 } | |
1608 | |
1609 void | |
1610 mainwin_set_volume_diff(gint diff) | |
1611 { | |
1612 gint vl, vr, vol; | |
1613 | |
1614 input_get_volume(&vl, &vr); | |
1615 vol = MAX(vl, vr); | |
1616 vol = CLAMP(vol + diff, 0, 100); | |
1617 | |
1618 mainwin_adjust_volume_motion(vol); | |
1619 setting_volume = FALSE; | |
1620 mainwin_set_volume_slider(vol); | |
1621 equalizerwin_set_volume_slider(vol); | |
1622 read_volume(VOLUME_SET); | |
1623 } | |
1624 | |
1625 void | |
1626 mainwin_set_balance_diff(gint diff) | |
1627 { | |
1628 gint b; | |
1629 b = CLAMP(balance + diff, -100, 100); | |
1630 mainwin_adjust_balance_motion(b); | |
1631 setting_volume = FALSE; | |
1632 mainwin_set_balance_slider(b); | |
1633 equalizerwin_set_balance_slider(b); | |
1634 read_volume(VOLUME_SET); | |
1635 } | |
1636 | |
1637 void | |
1638 mainwin_show(gboolean show) | |
1639 { | |
1640 if (show) | |
1641 mainwin_real_show(); | |
1642 else | |
1643 mainwin_real_hide(); | |
1644 } | |
1645 | |
1646 void | |
1647 mainwin_real_show(void) | |
1648 { | |
1649 cfg.player_visible = TRUE; | |
1650 | |
1651 check_set( toggleaction_group_others , "show player" , TRUE ); | |
1652 | |
1653 if (cfg.player_shaded) | |
3020 | 1654 ui_vis_clear_data(mainwin_vis); |
2947 | 1655 |
2313 | 1656 mainwin_set_shape_mask(); |
1657 | |
1658 if (cfg.show_wm_decorations) { | |
2906
68f3b7ff4333
Remove pposition_broken global variable.
William Pitcock <nenolod@atheme.org>
parents:
2853
diff
changeset
|
1659 if (cfg.player_x != -1 && cfg.save_window_position) |
2313 | 1660 gtk_window_move(GTK_WINDOW(mainwin), cfg.player_x, cfg.player_y); |
1661 | |
1662 gtk_widget_show(mainwin); | |
1663 return; | |
1664 } | |
1665 | |
2345
0fb47429ad7e
[svn] - in mainwin_real_show, do not return if a nullmask doesn't exist
giacomo
parents:
2339
diff
changeset
|
1666 if (nullmask) |
0fb47429ad7e
[svn] - in mainwin_real_show, do not return if a nullmask doesn't exist
giacomo
parents:
2339
diff
changeset
|
1667 { |
0fb47429ad7e
[svn] - in mainwin_real_show, do not return if a nullmask doesn't exist
giacomo
parents:
2339
diff
changeset
|
1668 g_object_unref(nullmask); |
0fb47429ad7e
[svn] - in mainwin_real_show, do not return if a nullmask doesn't exist
giacomo
parents:
2339
diff
changeset
|
1669 nullmask = NULL; |
0fb47429ad7e
[svn] - in mainwin_real_show, do not return if a nullmask doesn't exist
giacomo
parents:
2339
diff
changeset
|
1670 } |
2313 | 1671 |
3108
710b3aca4d64
Lower-case letters are more convenient, aren't they ? (anyhow bitmap fonts option is still available)
Stany HENRY <StrassBoy@gmail.com>
parents:
3095
diff
changeset
|
1672 gtk_window_resize(GTK_WINDOW(mainwin), |
2313 | 1673 !bmp_active_skin->properties.mainwin_width ? PLAYER_WIDTH : |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
1674 bmp_active_skin->properties.mainwin_width, |
2313 | 1675 !bmp_active_skin->properties.mainwin_height ? PLAYER_HEIGHT : |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
1676 bmp_active_skin->properties.mainwin_height); |
2313 | 1677 |
2651
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1678 if (cfg.player_x != -1 && cfg.save_window_position) |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1679 gtk_window_move(GTK_WINDOW(mainwin), cfg.player_x, cfg.player_y); |
4d5e6a8717dd
[svn] - allow the player to start with all of its windows hidden (but give a warning to the user, whose display can be disabled); also, try to remember player windows positions when they stay hidden between sessions
giacomo
parents:
2646
diff
changeset
|
1680 |
2313 | 1681 gtk_window_present(GTK_WINDOW(mainwin)); |
3241 | 1682 mainwin_refresh_hints(); |
2313 | 1683 } |
1684 | |
1685 void | |
1686 mainwin_real_hide(void) | |
1687 { | |
1688 GdkGC *gc; | |
1689 GdkColor pattern; | |
1690 | |
1691 check_set( toggleaction_group_others , "show player", FALSE); | |
1692 | |
1693 if (cfg.player_shaded) | |
3054 | 1694 ui_svis_clear_data(mainwin_svis); |
2313 | 1695 |
1696 if (!cfg.show_wm_decorations) { | |
1697 nullmask = gdk_pixmap_new(mainwin->window, 20, 20, 1); | |
1698 gc = gdk_gc_new(nullmask); | |
1699 pattern.pixel = 0; | |
1700 gdk_gc_set_foreground(gc, &pattern); | |
1701 gdk_draw_rectangle(nullmask, gc, TRUE, 0, 0, 20, 20); | |
1702 g_object_unref(gc); | |
1703 gtk_widget_shape_combine_mask(mainwin, nullmask, 0, 0); | |
1704 } | |
1705 | |
1706 gtk_widget_hide(mainwin); | |
1707 | |
1708 cfg.player_visible = FALSE; | |
1709 } | |
1710 | |
1711 | |
1712 void | |
1713 mainwin_set_stopaftersong(gboolean stop) | |
1714 { | |
1715 cfg.stopaftersong = stop; | |
1716 check_set(toggleaction_group_others, "stop after current song", cfg.stopaftersong); | |
1717 } | |
1718 | |
2769
bf2d80abf76e
[svn] Implemented CMD_IS_ADVANCE and CMD_TOGGLE_ADVANCE. Added partial MPRIS support. Root is complete, Player is partially implemented, and TrackList has not been started.
magma
parents:
2717
diff
changeset
|
1719 void |
bf2d80abf76e
[svn] Implemented CMD_IS_ADVANCE and CMD_TOGGLE_ADVANCE. Added partial MPRIS support. Root is complete, Player is partially implemented, and TrackList has not been started.
magma
parents:
2717
diff
changeset
|
1720 mainwin_set_noplaylistadvance(gboolean no_advance) |
bf2d80abf76e
[svn] Implemented CMD_IS_ADVANCE and CMD_TOGGLE_ADVANCE. Added partial MPRIS support. Root is complete, Player is partially implemented, and TrackList has not been started.
magma
parents:
2717
diff
changeset
|
1721 { |
bf2d80abf76e
[svn] Implemented CMD_IS_ADVANCE and CMD_TOGGLE_ADVANCE. Added partial MPRIS support. Root is complete, Player is partially implemented, and TrackList has not been started.
magma
parents:
2717
diff
changeset
|
1722 cfg.no_playlist_advance = no_advance; |
bf2d80abf76e
[svn] Implemented CMD_IS_ADVANCE and CMD_TOGGLE_ADVANCE. Added partial MPRIS support. Root is complete, Player is partially implemented, and TrackList has not been started.
magma
parents:
2717
diff
changeset
|
1723 check_set(toggleaction_group_others, "playback no playlist advance", cfg.no_playlist_advance); |
bf2d80abf76e
[svn] Implemented CMD_IS_ADVANCE and CMD_TOGGLE_ADVANCE. Added partial MPRIS support. Root is complete, Player is partially implemented, and TrackList has not been started.
magma
parents:
2717
diff
changeset
|
1724 } |
2313 | 1725 |
1726 static void | |
1727 mainwin_set_doublesize(gboolean doublesize) | |
1728 { | |
1729 gint height; | |
1730 | |
1731 if (cfg.player_shaded) | |
1732 height = MAINWIN_SHADED_HEIGHT; | |
1733 else | |
1734 height = bmp_active_skin->properties.mainwin_height; | |
1735 | |
1736 mainwin_set_shape_mask(); | |
1737 | |
1738 dock_window_resize(GTK_WINDOW(mainwin), cfg.player_shaded ? MAINWIN_SHADED_WIDTH : bmp_active_skin->properties.mainwin_width, | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
1739 cfg.player_shaded ? MAINWIN_SHADED_HEIGHT : bmp_active_skin->properties.mainwin_height, |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
1740 bmp_active_skin->properties.mainwin_width * 2, bmp_active_skin->properties.mainwin_height * 2); |
2313 | 1741 |
2821 | 1742 GList *iter; |
1743 for (iter = GTK_FIXED (SKINNED_WINDOW(mainwin)->fixed)->children; iter; iter = g_list_next (iter)) { | |
1744 GtkFixedChild *child_data = (GtkFixedChild *) iter->data; | |
1745 GtkWidget *child = child_data->widget; | |
2827 | 1746 g_signal_emit_by_name(child, "toggle-double-size"); |
2821 | 1747 } |
1748 | |
3221
9583cd62231f
implement ui_skinned_window_expose
Tomasz Mon <desowin@gmail.com>
parents:
3218
diff
changeset
|
1749 mainwin_refresh_hints(); |
2313 | 1750 } |
1751 | |
1752 void | |
1753 set_doublesize(gboolean doublesize) | |
1754 { | |
1755 cfg.doublesize = doublesize; | |
1756 | |
1757 mainwin_set_doublesize(doublesize); | |
1758 | |
1759 if (cfg.eq_doublesize_linked) | |
1760 equalizerwin_set_doublesize(doublesize); | |
1761 } | |
1762 | |
1763 | |
1764 | |
1765 void | |
1766 mainwin_general_menu_callback(gpointer data, | |
1767 guint action, | |
1768 GtkWidget * item) | |
1769 { | |
1770 Playlist *playlist = playlist_get_active(); | |
1771 | |
1772 switch (action) { | |
1773 case MAINWIN_GENERAL_PREFS: | |
1774 show_prefs_window(); | |
1775 break; | |
1776 case MAINWIN_GENERAL_ABOUT: | |
1777 show_about_window(); | |
1778 break; | |
1779 case MAINWIN_GENERAL_PLAYFILE: | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
1780 run_filebrowser(NO_PLAY_BUTTON); |
2313 | 1781 break; |
1782 case MAINWIN_GENERAL_PLAYLOCATION: | |
1783 mainwin_show_add_url_window(); | |
1784 break; | |
1785 case MAINWIN_GENERAL_FILEINFO: | |
1786 playlist_fileinfo_current(playlist); | |
1787 break; | |
1788 case MAINWIN_GENERAL_FOCUSPLWIN: | |
1789 gtk_window_present(GTK_WINDOW(playlistwin)); | |
1790 break; | |
1791 case MAINWIN_GENERAL_SHOWMWIN: | |
1792 mainwin_show(GTK_CHECK_MENU_ITEM(item)->active); | |
1793 break; | |
1794 case MAINWIN_GENERAL_SHOWPLWIN: | |
1795 if (GTK_CHECK_MENU_ITEM(item)->active) | |
1796 playlistwin_show(); | |
1797 else | |
1798 playlistwin_hide(); | |
1799 break; | |
1800 case MAINWIN_GENERAL_SHOWEQWIN: | |
1801 if (GTK_CHECK_MENU_ITEM(item)->active) | |
1802 equalizerwin_real_show(); | |
1803 else | |
1804 equalizerwin_real_hide(); | |
1805 break; | |
1806 case MAINWIN_GENERAL_PREV: | |
1807 playlist_prev(playlist); | |
1808 break; | |
1809 case MAINWIN_GENERAL_PLAY: | |
1810 mainwin_play_pushed(); | |
1811 break; | |
1812 case MAINWIN_GENERAL_PAUSE: | |
1813 playback_pause(); | |
1814 break; | |
1815 case MAINWIN_GENERAL_STOP: | |
1816 mainwin_stop_pushed(); | |
1817 break; | |
1818 case MAINWIN_GENERAL_NEXT: | |
1819 playlist_next(playlist); | |
1820 break; | |
1821 case MAINWIN_GENERAL_BACK5SEC: | |
1822 if (playback_get_playing() | |
1823 && playlist_get_current_length(playlist) != -1) | |
1824 playback_seek_relative(-5); | |
1825 break; | |
1826 case MAINWIN_GENERAL_FWD5SEC: | |
1827 if (playback_get_playing() | |
1828 && playlist_get_current_length(playlist) != -1) | |
1829 playback_seek_relative(5); | |
1830 break; | |
1831 case MAINWIN_GENERAL_START: | |
1832 playlist_set_position(playlist, 0); | |
1833 break; | |
1834 case MAINWIN_GENERAL_JTT: | |
1835 mainwin_jump_to_time(); | |
1836 break; | |
1837 case MAINWIN_GENERAL_JTF: | |
2500 | 1838 ui_jump_to_track(); |
2313 | 1839 break; |
1840 case MAINWIN_GENERAL_EXIT: | |
1841 mainwin_quit_cb(); | |
1842 break; | |
1843 case MAINWIN_GENERAL_SETAB: | |
1844 if (playlist_get_current_length(playlist) != -1) { | |
1845 if (ab_position_a == -1) { | |
1846 ab_position_a = playback_get_time(); | |
1847 ab_position_b = -1; | |
3108
710b3aca4d64
Lower-case letters are more convenient, aren't they ? (anyhow bitmap fonts option is still available)
Stany HENRY <StrassBoy@gmail.com>
parents:
3095
diff
changeset
|
1848 mainwin_lock_info_text("'Loop-Point A Position' set."); |
2313 | 1849 } else if (ab_position_b == -1) { |
1850 int time = playback_get_time(); | |
1851 if (time > ab_position_a) | |
1852 ab_position_b = time; | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
1853 mainwin_release_info_text(); |
2313 | 1854 } else { |
1855 ab_position_a = playback_get_time(); | |
1856 ab_position_b = -1; | |
3108
710b3aca4d64
Lower-case letters are more convenient, aren't they ? (anyhow bitmap fonts option is still available)
Stany HENRY <StrassBoy@gmail.com>
parents:
3095
diff
changeset
|
1857 mainwin_lock_info_text("'Loop-Point A Position' reset."); |
2313 | 1858 } |
1859 } | |
1860 break; | |
1861 case MAINWIN_GENERAL_CLEARAB: | |
1862 if (playlist_get_current_length(playlist) != -1) { | |
1863 ab_position_a = ab_position_b = -1; | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
1864 mainwin_release_info_text(); |
2313 | 1865 } |
1866 break; | |
1867 case MAINWIN_GENERAL_NEW_PL: | |
1868 { | |
1869 Playlist *new_pl = playlist_new(); | |
1870 playlist_add_playlist(new_pl); | |
1871 playlist_select_playlist(new_pl); | |
1872 } | |
1873 break; | |
1874 case MAINWIN_GENERAL_PREV_PL: | |
1875 playlist_select_prev(); | |
1876 break; | |
1877 case MAINWIN_GENERAL_NEXT_PL: | |
1878 playlist_select_next(); | |
1879 break; | |
1880 } | |
1881 } | |
1882 | |
1883 static void | |
3069
093759970e44
replace Menurow with UiSkinnedMenurow
Tomasz Mon <desowin@gmail.com>
parents:
3057
diff
changeset
|
1884 mainwin_mr_change(GtkWidget *widget, MenuRowItem i) |
2313 | 1885 { |
1886 switch (i) { | |
1887 case MENUROW_OPTIONS: | |
3108
710b3aca4d64
Lower-case letters are more convenient, aren't they ? (anyhow bitmap fonts option is still available)
Stany HENRY <StrassBoy@gmail.com>
parents:
3095
diff
changeset
|
1888 mainwin_lock_info_text(_("Options Menu")); |
2313 | 1889 break; |
1890 case MENUROW_ALWAYS: | |
3069
093759970e44
replace Menurow with UiSkinnedMenurow
Tomasz Mon <desowin@gmail.com>
parents:
3057
diff
changeset
|
1891 if (UI_SKINNED_MENUROW(mainwin_menurow)->always_selected) |
3108
710b3aca4d64
Lower-case letters are more convenient, aren't they ? (anyhow bitmap fonts option is still available)
Stany HENRY <StrassBoy@gmail.com>
parents:
3095
diff
changeset
|
1892 mainwin_lock_info_text(_("Disable 'Always On Top'")); |
2313 | 1893 else |
3108
710b3aca4d64
Lower-case letters are more convenient, aren't they ? (anyhow bitmap fonts option is still available)
Stany HENRY <StrassBoy@gmail.com>
parents:
3095
diff
changeset
|
1894 mainwin_lock_info_text(_("Enable 'Always On Top'")); |
2313 | 1895 break; |
1896 case MENUROW_FILEINFOBOX: | |
3108
710b3aca4d64
Lower-case letters are more convenient, aren't they ? (anyhow bitmap fonts option is still available)
Stany HENRY <StrassBoy@gmail.com>
parents:
3095
diff
changeset
|
1897 mainwin_lock_info_text(_("File Info Box")); |
2313 | 1898 break; |
1899 case MENUROW_DOUBLESIZE: | |
3069
093759970e44
replace Menurow with UiSkinnedMenurow
Tomasz Mon <desowin@gmail.com>
parents:
3057
diff
changeset
|
1900 if (UI_SKINNED_MENUROW(mainwin_menurow)->doublesize_selected) |
3108
710b3aca4d64
Lower-case letters are more convenient, aren't they ? (anyhow bitmap fonts option is still available)
Stany HENRY <StrassBoy@gmail.com>
parents:
3095
diff
changeset
|
1901 mainwin_lock_info_text(_("Disable 'Doublesize'")); |
2313 | 1902 else |
3108
710b3aca4d64
Lower-case letters are more convenient, aren't they ? (anyhow bitmap fonts option is still available)
Stany HENRY <StrassBoy@gmail.com>
parents:
3095
diff
changeset
|
1903 mainwin_lock_info_text(_("Enable 'Doublesize'")); |
2313 | 1904 break; |
1905 case MENUROW_VISUALIZATION: | |
3108
710b3aca4d64
Lower-case letters are more convenient, aren't they ? (anyhow bitmap fonts option is still available)
Stany HENRY <StrassBoy@gmail.com>
parents:
3095
diff
changeset
|
1906 mainwin_lock_info_text(_("Visualization Menu")); |
2313 | 1907 break; |
3165
8775dfc57ead
Remove mainwin_set_info_text() craq. Still some work to do.
William Pitcock <nenolod@atheme-project.org>
parents:
3157
diff
changeset
|
1908 case MENUROW_NONE: |
8775dfc57ead
Remove mainwin_set_info_text() craq. Still some work to do.
William Pitcock <nenolod@atheme-project.org>
parents:
3157
diff
changeset
|
1909 break; |
2313 | 1910 } |
1911 } | |
1912 | |
1913 static void | |
3069
093759970e44
replace Menurow with UiSkinnedMenurow
Tomasz Mon <desowin@gmail.com>
parents:
3057
diff
changeset
|
1914 mainwin_mr_release(GtkWidget *widget, MenuRowItem i) |
2313 | 1915 { |
1916 GdkModifierType modmask; | |
1917 gint x, y; | |
1918 | |
1919 switch (i) { | |
1920 case MENUROW_OPTIONS: | |
1921 gdk_window_get_pointer(NULL, &x, &y, &modmask); | |
1922 ui_manager_popup_menu_show(GTK_MENU(mainwin_view_menu), x, y, 1, | |
1923 GDK_CURRENT_TIME); | |
1924 break; | |
1925 case MENUROW_ALWAYS: | |
1926 gtk_toggle_action_set_active( | |
1927 GTK_TOGGLE_ACTION(gtk_action_group_get_action( | |
1928 toggleaction_group_others , "view always on top" )) , | |
3069
093759970e44
replace Menurow with UiSkinnedMenurow
Tomasz Mon <desowin@gmail.com>
parents:
3057
diff
changeset
|
1929 UI_SKINNED_MENUROW(mainwin_menurow)->always_selected ); |
2313 | 1930 break; |
1931 case MENUROW_FILEINFOBOX: | |
1932 playlist_fileinfo_current(playlist_get_active()); | |
1933 break; | |
1934 case MENUROW_DOUBLESIZE: | |
1935 gtk_toggle_action_set_active( | |
1936 GTK_TOGGLE_ACTION(gtk_action_group_get_action( | |
1937 toggleaction_group_others , "view doublesize" )) , | |
3069
093759970e44
replace Menurow with UiSkinnedMenurow
Tomasz Mon <desowin@gmail.com>
parents:
3057
diff
changeset
|
1938 UI_SKINNED_MENUROW(mainwin_menurow)->doublesize_selected ); |
2313 | 1939 break; |
1940 case MENUROW_VISUALIZATION: | |
1941 gdk_window_get_pointer(NULL, &x, &y, &modmask); | |
1942 ui_manager_popup_menu_show(GTK_MENU(mainwin_visualization_menu), x, y, 1, GDK_CURRENT_TIME); | |
1943 break; | |
1944 case MENUROW_NONE: | |
1945 break; | |
1946 } | |
1947 mainwin_release_info_text(); | |
1948 } | |
1949 | |
3157
f9d34bc5079f
Remove check for playback->error.
William Pitcock <nenolod@atheme-project.org>
parents:
3151
diff
changeset
|
1950 void |
f9d34bc5079f
Remove check for playback->error.
William Pitcock <nenolod@atheme-project.org>
parents:
3151
diff
changeset
|
1951 run_no_output_device_dialog(gpointer hook_data, gpointer user_data) |
2313 | 1952 { |
1953 const gchar *markup = | |
1954 N_("<b><big>Couldn't open audio.</big></b>\n\n" | |
1955 "Please check that:\n" | |
1956 "1. You have the correct output plugin selected.\n" | |
1957 "2. No other programs is blocking the soundcard.\n" | |
1958 "3. Your soundcard is configured properly.\n"); | |
1959 | |
3157
f9d34bc5079f
Remove check for playback->error.
William Pitcock <nenolod@atheme-project.org>
parents:
3151
diff
changeset
|
1960 GDK_THREADS_ENTER(); |
2313 | 1961 GtkWidget *dialog = |
1962 gtk_message_dialog_new_with_markup(GTK_WINDOW(mainwin), | |
1963 GTK_DIALOG_DESTROY_WITH_PARENT, | |
1964 GTK_MESSAGE_ERROR, | |
1965 GTK_BUTTONS_OK, | |
1966 _(markup)); | |
1967 gtk_dialog_run(GTK_DIALOG(dialog)); | |
1968 gtk_widget_destroy(dialog); | |
3157
f9d34bc5079f
Remove check for playback->error.
William Pitcock <nenolod@atheme-project.org>
parents:
3151
diff
changeset
|
1969 GDK_THREADS_LEAVE(); |
2313 | 1970 } |
1971 | |
1972 void | |
1973 read_volume(gint when) | |
1974 { | |
1975 static gint pvl = 0, pvr = 0; | |
1976 static gint times = VOLSET_DISP_TIMES; | |
1977 static gboolean changing = FALSE; | |
1978 | |
1979 gint vl, vr, b, v; | |
1980 | |
1981 input_get_volume(&vl, &vr); | |
1982 | |
1983 switch (when) { | |
1984 case VOLSET_STARTUP: | |
1985 vl = CLAMP(vl, 0, 100); | |
1986 vr = CLAMP(vr, 0, 100); | |
1987 pvl = vl; | |
1988 pvr = vr; | |
1989 v = MAX(vl, vr); | |
1990 if (vl > vr) | |
1991 b = (gint) rint(((gdouble) vr / vl) * 100) - 100; | |
1992 else if (vl < vr) | |
1993 b = 100 - (gint) rint(((gdouble) vl / vr) * 100); | |
1994 else | |
1995 b = 0; | |
1996 | |
1997 balance = b; | |
1998 mainwin_set_volume_slider(v); | |
1999 equalizerwin_set_volume_slider(v); | |
2000 mainwin_set_balance_slider(b); | |
2001 equalizerwin_set_balance_slider(b); | |
2002 return; | |
2003 | |
2004 case VOLSET_UPDATE: | |
2005 if (vl == -1 || vr == -1) | |
2006 return; | |
2007 | |
2008 if (setting_volume) { | |
2009 pvl = vl; | |
2010 pvr = vr; | |
2011 return; | |
2012 } | |
2013 | |
2014 if (pvr == vr && pvl == vl && changing) { | |
2015 if (times < VOLSET_DISP_TIMES) | |
2016 times++; | |
2017 else { | |
2018 mainwin_release_info_text(); | |
2019 changing = FALSE; | |
2020 } | |
2021 } | |
2022 else if (pvr != vr || pvl != vl) { | |
2023 gchar *tmp; | |
2024 | |
2025 v = MAX(vl, vr); | |
2026 if (vl > vr) | |
2027 b = (gint) rint(((gdouble) vr / vl) * 100) - 100; | |
2028 else if (vl < vr) | |
2029 b = 100 - (gint) rint(((gdouble) vl / vr) * 100); | |
2030 else | |
2031 b = 0; | |
2032 | |
2033 if (MAX(vl, vr) != MAX(pvl, pvr)) | |
2034 tmp = g_strdup_printf(_("VOLUME: %d%%"), v); | |
2035 else { | |
2036 if (vl > vr) { | |
2037 tmp = g_strdup_printf(_("BALANCE: %d%% LEFT"), -b); | |
2038 } | |
2039 else if (vr == vl) | |
2040 tmp = g_strdup_printf(_("BALANCE: CENTER")); | |
2041 else { /* (vl < vr) */ | |
2042 tmp = g_strdup_printf(_("BALANCE: %d%% RIGHT"), b); | |
2043 } | |
2044 } | |
2045 mainwin_lock_info_text(tmp); | |
2046 g_free(tmp); | |
2047 | |
2048 pvr = vr; | |
2049 pvl = vl; | |
2050 times = 0; | |
2051 changing = TRUE; | |
2052 mainwin_set_volume_slider(v); | |
2053 equalizerwin_set_volume_slider(v); | |
2054 | |
2055 /* Don't change the balance slider if the volume has been | |
2056 * set to zero. The balance can be anything, and our best | |
2057 * guess is what is was before. */ | |
2058 if (v > 0) { | |
2059 balance = b; | |
2060 mainwin_set_balance_slider(b); | |
2061 equalizerwin_set_balance_slider(b); | |
2062 } | |
2063 } | |
2064 break; | |
2065 | |
2066 case VOLUME_ADJUSTED: | |
2067 pvl = vl; | |
2068 pvr = vr; | |
2069 break; | |
2070 | |
2071 case VOLUME_SET: | |
2072 times = 0; | |
2073 changing = TRUE; | |
2074 pvl = vl; | |
2075 pvr = vr; | |
2076 break; | |
2077 } | |
2078 } | |
2079 | |
2080 | |
2081 /* TODO: HAL! */ | |
2082 gboolean | |
2083 can_play_cd(void) | |
2084 { | |
2085 GList *ilist; | |
2086 | |
2087 for (ilist = get_input_list(); ilist; ilist = g_list_next(ilist)) { | |
2088 InputPlugin *ip = INPUT_PLUGIN(ilist->data); | |
2089 | |
2090 if (!g_ascii_strcasecmp(g_basename(ip->filename), | |
2091 PLUGIN_FILENAME("cdaudio"))) { | |
2092 return TRUE; | |
2093 } | |
2094 } | |
2095 | |
2096 return FALSE; | |
2097 } | |
2098 | |
2099 | |
2100 static void | |
2101 set_timer_mode(TimerMode mode) | |
2102 { | |
2103 if (mode == TIMER_ELAPSED) | |
2104 check_set(radioaction_group_viewtime, "view time elapsed", TRUE); | |
2105 else | |
2106 check_set(radioaction_group_viewtime, "view time remaining", TRUE); | |
2107 } | |
2108 | |
2109 static void | |
2110 set_timer_mode_menu_cb(TimerMode mode) | |
2111 { | |
2112 cfg.timer_mode = mode; | |
2113 } | |
2114 | |
3366
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2115 gboolean |
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2116 change_timer_mode_cb(GtkWidget *widget, GdkEventButton *event) |
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2117 { |
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2118 if (event->button == 1) { |
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2119 change_timer_mode(); |
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2120 } else if (event->button == 3) |
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2121 return FALSE; |
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2122 |
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2123 return TRUE; |
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2124 } |
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2125 |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
2126 void change_timer_mode(void) { |
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
2127 if (cfg.timer_mode == TIMER_ELAPSED) |
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
2128 set_timer_mode(TIMER_REMAINING); |
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
2129 else |
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
2130 set_timer_mode(TIMER_ELAPSED); |
3367
b47e36a480b3
don't call mainwin_update_song_info if track isn't played
Tomasz Mon <desowin@gmail.com>
parents:
3366
diff
changeset
|
2131 if (playback_get_playing()) |
b47e36a480b3
don't call mainwin_update_song_info if track isn't played
Tomasz Mon <desowin@gmail.com>
parents:
3366
diff
changeset
|
2132 mainwin_update_song_info(); |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
2133 } |
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
2134 |
2313 | 2135 static void |
2136 mainwin_playlist_prev(void) | |
2137 { | |
2138 playlist_prev(playlist_get_active()); | |
2139 } | |
2140 | |
2141 static void | |
2142 mainwin_playlist_next(void) | |
2143 { | |
2144 playlist_next(playlist_get_active()); | |
2145 } | |
2146 | |
2147 void | |
2148 mainwin_setup_menus(void) | |
2149 { | |
2150 set_timer_mode(cfg.timer_mode); | |
2151 | |
2152 /* View menu */ | |
2153 | |
2154 check_set(toggleaction_group_others, "view always on top", cfg.always_on_top); | |
2155 check_set(toggleaction_group_others, "view put on all workspaces", cfg.sticky); | |
2156 check_set(toggleaction_group_others, "roll up player", cfg.player_shaded); | |
2157 check_set(toggleaction_group_others, "roll up playlist editor", cfg.playlist_shaded); | |
2158 check_set(toggleaction_group_others, "roll up equalizer", cfg.equalizer_shaded); | |
2159 check_set(toggleaction_group_others, "view easy move", cfg.easy_move); | |
2160 check_set(toggleaction_group_others, "view doublesize", cfg.doublesize); | |
2161 | |
2162 /* Songname menu */ | |
2163 | |
2164 check_set(toggleaction_group_others, "autoscroll songname", cfg.autoscroll); | |
2165 check_set(toggleaction_group_others, "stop after current song", cfg.stopaftersong); | |
2166 | |
2167 /* Playback menu */ | |
2168 | |
2169 check_set(toggleaction_group_others, "playback repeat", cfg.repeat); | |
2170 check_set(toggleaction_group_others, "playback shuffle", cfg.shuffle); | |
2171 check_set(toggleaction_group_others, "playback no playlist advance", cfg.no_playlist_advance); | |
2172 | |
2173 /* Visualization menu */ | |
2174 | |
2175 switch ( cfg.vis_type ) | |
2176 { | |
2177 case VIS_ANALYZER: | |
2178 check_set(radioaction_group_vismode, "vismode analyzer", TRUE); | |
2179 break; | |
2180 case VIS_SCOPE: | |
2181 check_set(radioaction_group_vismode, "vismode scope", TRUE); | |
2182 break; | |
2183 case VIS_VOICEPRINT: | |
2184 check_set(radioaction_group_vismode, "vismode voiceprint", TRUE); | |
2185 break; | |
2186 case VIS_OFF: | |
2187 default: | |
2188 check_set(radioaction_group_vismode, "vismode off", TRUE); | |
2189 break; | |
2190 } | |
2191 | |
2192 switch ( cfg.analyzer_mode ) | |
2193 { | |
2194 case ANALYZER_FIRE: | |
2195 check_set(radioaction_group_anamode, "anamode fire", TRUE); | |
2196 break; | |
2197 case ANALYZER_VLINES: | |
2198 check_set(radioaction_group_anamode, "anamode vertical lines", TRUE); | |
2199 break; | |
2200 case ANALYZER_NORMAL: | |
2201 default: | |
2202 check_set(radioaction_group_anamode, "anamode normal", TRUE); | |
2203 break; | |
2204 } | |
2205 | |
2206 switch ( cfg.analyzer_type ) | |
2207 { | |
2208 case ANALYZER_BARS: | |
2209 check_set(radioaction_group_anatype, "anatype bars", TRUE); | |
2210 break; | |
2211 case ANALYZER_LINES: | |
2212 default: | |
2213 check_set(radioaction_group_anatype, "anatype lines", TRUE); | |
2214 break; | |
2215 } | |
2216 | |
2217 check_set(toggleaction_group_others, "anamode peaks", cfg.analyzer_peaks ); | |
2218 | |
2219 switch ( cfg.scope_mode ) | |
2220 { | |
2221 case SCOPE_LINE: | |
2222 check_set(radioaction_group_scomode, "scomode line", TRUE); | |
2223 break; | |
2224 case SCOPE_SOLID: | |
2225 check_set(radioaction_group_scomode, "scomode solid", TRUE); | |
2226 break; | |
2227 case SCOPE_DOT: | |
2228 default: | |
2229 check_set(radioaction_group_scomode, "scomode dot", TRUE); | |
2230 break; | |
2231 } | |
2232 | |
2233 switch ( cfg.voiceprint_mode ) | |
2234 { | |
2235 case VOICEPRINT_FIRE: | |
2236 check_set(radioaction_group_vprmode, "vprmode fire", TRUE); | |
2237 break; | |
2238 case VOICEPRINT_ICE: | |
2239 check_set(radioaction_group_vprmode, "vprmode ice", TRUE); | |
2240 break; | |
2241 case VOICEPRINT_NORMAL: | |
2242 default: | |
2243 check_set(radioaction_group_vprmode, "vprmode normal", TRUE); | |
2244 break; | |
2245 } | |
2246 | |
2247 switch ( cfg.vu_mode ) | |
2248 { | |
2249 case VU_SMOOTH: | |
2250 check_set(radioaction_group_wshmode, "wshmode smooth", TRUE); | |
2251 break; | |
2252 case VU_NORMAL: | |
2253 default: | |
2254 check_set(radioaction_group_wshmode, "wshmode normal", TRUE); | |
2255 break; | |
2256 } | |
2257 | |
2258 switch ( cfg.vis_refresh ) | |
2259 { | |
2260 case REFRESH_HALF: | |
2261 check_set(radioaction_group_refrate, "refrate half", TRUE); | |
2262 break; | |
2263 case REFRESH_QUARTER: | |
2264 check_set(radioaction_group_refrate, "refrate quarter", TRUE); | |
2265 break; | |
2266 case REFRESH_EIGTH: | |
2267 check_set(radioaction_group_refrate, "refrate eighth", TRUE); | |
2268 break; | |
2269 case REFRESH_FULL: | |
2270 default: | |
2271 check_set(radioaction_group_refrate, "refrate full", TRUE); | |
2272 break; | |
2273 } | |
2274 | |
2275 switch ( cfg.analyzer_falloff ) | |
2276 { | |
2277 case FALLOFF_SLOW: | |
2278 check_set(radioaction_group_anafoff, "anafoff slow", TRUE); | |
2279 break; | |
2280 case FALLOFF_MEDIUM: | |
2281 check_set(radioaction_group_anafoff, "anafoff medium", TRUE); | |
2282 break; | |
2283 case FALLOFF_FAST: | |
2284 check_set(radioaction_group_anafoff, "anafoff fast", TRUE); | |
2285 break; | |
2286 case FALLOFF_FASTEST: | |
2287 check_set(radioaction_group_anafoff, "anafoff fastest", TRUE); | |
2288 break; | |
2289 case FALLOFF_SLOWEST: | |
2290 default: | |
2291 check_set(radioaction_group_anafoff, "anafoff slowest", TRUE); | |
2292 break; | |
2293 } | |
2294 | |
2295 switch ( cfg.peaks_falloff ) | |
2296 { | |
2297 case FALLOFF_SLOW: | |
2298 check_set(radioaction_group_peafoff, "peafoff slow", TRUE); | |
2299 break; | |
2300 case FALLOFF_MEDIUM: | |
2301 check_set(radioaction_group_peafoff, "peafoff medium", TRUE); | |
2302 break; | |
2303 case FALLOFF_FAST: | |
2304 check_set(radioaction_group_peafoff, "peafoff fast", TRUE); | |
2305 break; | |
2306 case FALLOFF_FASTEST: | |
2307 check_set(radioaction_group_peafoff, "peafoff fastest", TRUE); | |
2308 break; | |
2309 case FALLOFF_SLOWEST: | |
2310 default: | |
2311 check_set(radioaction_group_peafoff, "peafoff slowest", TRUE); | |
2312 break; | |
2313 } | |
2314 | |
2315 } | |
2316 | |
2911 | 2317 static void mainwin_info_double_clicked_cb(void) { |
2318 playlist_fileinfo_current(playlist_get_active()); | |
2319 } | |
2320 | |
2321 static void mainwin_info_right_clicked_cb(void) { | |
2322 gint x, y; | |
2323 gdk_window_get_pointer(NULL, &x, &y, NULL); | |
2324 ui_manager_popup_menu_show(GTK_MENU(mainwin_songname_menu), x, y, 3, GDK_CURRENT_TIME); | |
2325 } | |
2326 | |
2313 | 2327 static void |
2328 mainwin_create_widgets(void) | |
2329 { | |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2330 mainwin_menubtn = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2331 ui_skinned_push_button_setup(mainwin_menubtn, SKINNED_WINDOW(mainwin)->fixed, |
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2332 6, 3, 9, 9, 0, 0, 0, 9, SKIN_TITLEBAR); |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2333 g_signal_connect(mainwin_menubtn, "clicked", mainwin_menubtn_cb, NULL ); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2334 |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2335 mainwin_minimize = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2336 ui_skinned_push_button_setup(mainwin_minimize, SKINNED_WINDOW(mainwin)->fixed, |
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2337 244, 3, 9, 9, 9, 0, 9, 9, SKIN_TITLEBAR); |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2338 g_signal_connect(mainwin_minimize, "clicked", mainwin_minimize_cb, NULL ); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2339 |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2340 mainwin_shade = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2341 ui_skinned_push_button_setup(mainwin_shade, SKINNED_WINDOW(mainwin)->fixed, |
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2342 254, 3, 9, 9, 0, |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2343 cfg.player_shaded ? 27 : 18, 9, cfg.player_shaded ? 27 : 18, SKIN_TITLEBAR); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2344 g_signal_connect(mainwin_shade, "clicked", mainwin_shade_toggle, NULL ); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2345 |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2346 mainwin_close = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2347 ui_skinned_push_button_setup(mainwin_close, SKINNED_WINDOW(mainwin)->fixed, |
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2348 264, 3, 9, 9, 18, 0, 18, 9, SKIN_TITLEBAR); |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2349 g_signal_connect(mainwin_close, "clicked", mainwin_quit_cb, NULL ); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2350 |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2351 mainwin_rew = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2352 ui_skinned_push_button_setup(mainwin_rew, SKINNED_WINDOW(mainwin)->fixed, |
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2353 16, 88, 23, 18, 0, 0, 0, 18, SKIN_CBUTTONS); |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2354 g_signal_connect(mainwin_rew, "pressed", mainwin_rev_pushed, NULL); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2355 g_signal_connect(mainwin_rew, "released", mainwin_rev_release, NULL); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2356 |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2357 mainwin_fwd = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2358 ui_skinned_push_button_setup(mainwin_fwd, SKINNED_WINDOW(mainwin)->fixed, |
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2359 108, 88, 22, 18, 92, 0, 92, 18, SKIN_CBUTTONS); |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2360 g_signal_connect(mainwin_fwd, "pressed", mainwin_fwd_pushed, NULL); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2361 g_signal_connect(mainwin_fwd, "released", mainwin_fwd_release, NULL); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2362 |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2363 mainwin_play = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2364 ui_skinned_push_button_setup(mainwin_play, SKINNED_WINDOW(mainwin)->fixed, |
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2365 39, 88, 23, 18, 23, 0, 23, 18, SKIN_CBUTTONS); |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2366 g_signal_connect(mainwin_play, "clicked", mainwin_play_pushed, NULL ); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2367 |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2368 mainwin_pause = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2369 ui_skinned_push_button_setup(mainwin_pause, SKINNED_WINDOW(mainwin)->fixed, |
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2370 62, 88, 23, 18, 46, 0, 46, 18, SKIN_CBUTTONS); |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2371 g_signal_connect(mainwin_pause, "clicked", playback_pause, NULL ); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2372 |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2373 mainwin_stop = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2374 ui_skinned_push_button_setup(mainwin_stop, SKINNED_WINDOW(mainwin)->fixed, |
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2375 85, 88, 23, 18, 69, 0, 69, 18, SKIN_CBUTTONS); |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2376 g_signal_connect(mainwin_stop, "clicked", mainwin_stop_pushed, NULL ); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2377 |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2378 mainwin_eject = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2379 ui_skinned_push_button_setup(mainwin_eject, SKINNED_WINDOW(mainwin)->fixed, |
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2380 136, 89, 22, 16, 114, 0, 114, 16, SKIN_CBUTTONS); |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2381 g_signal_connect(mainwin_eject, "clicked", mainwin_eject_pushed, NULL); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2382 |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2383 mainwin_srew = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2384 ui_skinned_small_button_setup(mainwin_srew, SKINNED_WINDOW(mainwin)->fixed, 169, 4, 8, 7); |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2385 g_signal_connect(mainwin_srew, "clicked", mainwin_playlist_prev, NULL); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2386 |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2387 mainwin_splay = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2388 ui_skinned_small_button_setup(mainwin_splay, SKINNED_WINDOW(mainwin)->fixed, 177, 4, 10, 7); |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2389 g_signal_connect(mainwin_splay, "clicked", mainwin_play_pushed, NULL); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2390 |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2391 mainwin_spause = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2392 ui_skinned_small_button_setup(mainwin_spause, SKINNED_WINDOW(mainwin)->fixed, 187, 4, 10, 7); |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2393 g_signal_connect(mainwin_spause, "clicked", playback_pause, NULL); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2394 |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2395 mainwin_sstop = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2396 ui_skinned_small_button_setup(mainwin_sstop, SKINNED_WINDOW(mainwin)->fixed, 197, 4, 9, 7); |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2397 g_signal_connect(mainwin_sstop, "clicked", mainwin_stop_pushed, NULL); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2398 |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2399 mainwin_sfwd = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2400 ui_skinned_small_button_setup(mainwin_sfwd, SKINNED_WINDOW(mainwin)->fixed, 206, 4, 8, 7); |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2401 g_signal_connect(mainwin_sfwd, "clicked", mainwin_playlist_next, NULL); |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2402 |
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2403 mainwin_seject = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2404 ui_skinned_small_button_setup(mainwin_seject, SKINNED_WINDOW(mainwin)->fixed, 216, 4, 9, 7); |
2844
22da7cd0eca0
UiSkinnedButton can now work as SButton
Tomasz Mon <desowin@gmail.com>
parents:
2843
diff
changeset
|
2405 g_signal_connect(mainwin_seject, "clicked", mainwin_eject_pushed, NULL); |
2313 | 2406 |
2843
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
2407 mainwin_shuffle = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2408 ui_skinned_toggle_button_setup(mainwin_shuffle, SKINNED_WINDOW(mainwin)->fixed, |
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2409 164, 89, 46, 15, 28, 0, 28, 15, 28, 30, 28, 45, SKIN_SHUFREP); |
2843
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
2410 g_signal_connect(mainwin_shuffle, "clicked", mainwin_shuffle_pushed_cb, NULL); |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
2411 |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
2412 mainwin_repeat = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2413 ui_skinned_toggle_button_setup(mainwin_repeat, SKINNED_WINDOW(mainwin)->fixed, |
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2414 210, 89, 28, 15, 0, 0, 0, 15, 0, 30, 0, 45, SKIN_SHUFREP); |
2843
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
2415 g_signal_connect(mainwin_repeat, "clicked", mainwin_repeat_pushed_cb, NULL); |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
2416 |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
2417 mainwin_eq = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2418 ui_skinned_toggle_button_setup(mainwin_eq, SKINNED_WINDOW(mainwin)->fixed, |
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2419 219, 58, 23, 12, 0, 61, 46, 61, 0, 73, 46, 73, SKIN_SHUFREP); |
2843
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
2420 g_signal_connect(mainwin_eq, "clicked", mainwin_equalizer_pushed_cb, NULL); |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
2421 UI_SKINNED_BUTTON(mainwin_eq)->inside = cfg.equalizer_visible; |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
2422 |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
2423 mainwin_pl = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2424 ui_skinned_toggle_button_setup(mainwin_pl, SKINNED_WINDOW(mainwin)->fixed, |
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2425 242, 58, 23, 12, 23, 61, 69, 61, 23, 73, 69, 73, SKIN_SHUFREP); |
2843
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
2426 g_signal_connect(mainwin_pl, "clicked", mainwin_playlist_pushed_cb, NULL); |
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
2427 UI_SKINNED_BUTTON(mainwin_pl)->inside = cfg.playlist_visible; |
2313 | 2428 |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2429 mainwin_info = ui_skinned_textbox_new(SKINNED_WINDOW(mainwin)->fixed, 112, 27, 153, 1, SKIN_TEXT); |
2911 | 2430 ui_skinned_textbox_set_scroll(mainwin_info, cfg.autoscroll); |
2431 ui_skinned_textbox_set_xfont(mainwin_info, cfg.mainwin_use_xfont, cfg.mainwin_font); | |
2432 g_signal_connect(mainwin_info, "double-clicked", mainwin_info_double_clicked_cb, NULL); | |
2433 g_signal_connect(mainwin_info, "right-clicked", mainwin_info_right_clicked_cb, NULL); | |
2313 | 2434 |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2435 mainwin_othertext = ui_skinned_textbox_new(SKINNED_WINDOW(mainwin)->fixed, 112, 43, 153, 1, SKIN_TEXT); |
3565
21601ce39fa1
let mainwin_othertext use xfont when cfg.mainwin_use_xfont is TRUE
Tomasz Mon <desowin@gmail.com>
parents:
3533
diff
changeset
|
2436 ui_skinned_textbox_set_xfont(mainwin_othertext, cfg.mainwin_use_xfont, cfg.mainwin_font); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2437 |
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2438 mainwin_rate_text = ui_skinned_textbox_new(SKINNED_WINDOW(mainwin)->fixed, 111, 43, 15, 0, SKIN_TEXT); |
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2439 |
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2440 mainwin_freq_text = ui_skinned_textbox_new(SKINNED_WINDOW(mainwin)->fixed, 156, 43, 10, 0, SKIN_TEXT); |
2313 | 2441 |
3069
093759970e44
replace Menurow with UiSkinnedMenurow
Tomasz Mon <desowin@gmail.com>
parents:
3057
diff
changeset
|
2442 mainwin_menurow = ui_skinned_menurow_new(SKINNED_WINDOW(mainwin)->fixed, 10, 22, 304, 0, 304, 44, SKIN_TITLEBAR); |
093759970e44
replace Menurow with UiSkinnedMenurow
Tomasz Mon <desowin@gmail.com>
parents:
3057
diff
changeset
|
2443 g_signal_connect(mainwin_menurow, "change", G_CALLBACK(mainwin_mr_change), NULL); |
093759970e44
replace Menurow with UiSkinnedMenurow
Tomasz Mon <desowin@gmail.com>
parents:
3057
diff
changeset
|
2444 g_signal_connect(mainwin_menurow, "release", G_CALLBACK(mainwin_mr_release), NULL); |
2313 | 2445 |
3045
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
2446 mainwin_volume = ui_skinned_horizontal_slider_new(SKINNED_WINDOW(mainwin)->fixed, 107, 57, 68, |
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
2447 13, 15, 422, 0, 422, 14, 11, 15, 0, 0, 51, |
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
2448 mainwin_volume_frame_cb, SKIN_VOLUME); |
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
2449 g_signal_connect(mainwin_volume, "motion", G_CALLBACK(mainwin_volume_motion_cb), NULL); |
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
2450 g_signal_connect(mainwin_volume, "release", G_CALLBACK(mainwin_volume_release_cb), NULL); |
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
2451 |
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
2452 mainwin_balance = ui_skinned_horizontal_slider_new(SKINNED_WINDOW(mainwin)->fixed, 177, 57, 38, |
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
2453 13, 15, 422, 0, 422, 14, 11, 15, 9, 0, 24, |
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
2454 mainwin_balance_frame_cb, SKIN_BALANCE); |
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
2455 g_signal_connect(mainwin_balance, "motion", G_CALLBACK(mainwin_balance_motion_cb), NULL); |
464ae313343c
mainwin_volume and mainwin_balance are UiSkinnedHorizontalSliders now; add workaround for skins with too strait SKIN_VOLUME
Tomasz Mon <desowin@gmail.com>
parents:
3042
diff
changeset
|
2456 g_signal_connect(mainwin_balance, "release", G_CALLBACK(mainwin_balance_release_cb), NULL); |
2313 | 2457 |
3073
da99b90d63d3
replace MonoStereo with UiSkinnedMonoStereo
Tomasz Mon <desowin@gmail.com>
parents:
3072
diff
changeset
|
2458 mainwin_monostereo = ui_skinned_monostereo_new(SKINNED_WINDOW(mainwin)->fixed, 212, 41, SKIN_MONOSTEREO); |
2313 | 2459 |
3072
84de3244aeaa
replace Playstatus with UiSkinnedPlaystatus
Tomasz Mon <desowin@gmail.com>
parents:
3070
diff
changeset
|
2460 mainwin_playstatus = ui_skinned_playstatus_new(SKINNED_WINDOW(mainwin)->fixed, 24, 28); |
2313 | 2461 |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2462 mainwin_minus_num = ui_skinned_number_new(SKINNED_WINDOW(mainwin)->fixed, 36, 26, SKIN_NUMBERS); |
3366
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2463 g_signal_connect(mainwin_minus_num, "button-press-event", G_CALLBACK(change_timer_mode_cb), NULL); |
3001
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
2464 |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2465 mainwin_10min_num = ui_skinned_number_new(SKINNED_WINDOW(mainwin)->fixed, 48, 26, SKIN_NUMBERS); |
3366
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2466 g_signal_connect(mainwin_10min_num, "button-press-event", G_CALLBACK(change_timer_mode_cb), NULL); |
3001
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
2467 |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2468 mainwin_min_num = ui_skinned_number_new(SKINNED_WINDOW(mainwin)->fixed, 60, 26, SKIN_NUMBERS); |
3366
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2469 g_signal_connect(mainwin_min_num, "button-press-event", G_CALLBACK(change_timer_mode_cb), NULL); |
3001
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
2470 |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2471 mainwin_10sec_num = ui_skinned_number_new(SKINNED_WINDOW(mainwin)->fixed, 78, 26, SKIN_NUMBERS); |
3366
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2472 g_signal_connect(mainwin_10sec_num, "button-press-event", G_CALLBACK(change_timer_mode_cb), NULL); |
3001
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
2473 |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2474 mainwin_sec_num = ui_skinned_number_new(SKINNED_WINDOW(mainwin)->fixed, 90, 26, SKIN_NUMBERS); |
3366
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2475 g_signal_connect(mainwin_sec_num, "button-press-event", G_CALLBACK(change_timer_mode_cb), NULL); |
2313 | 2476 |
2964
7926d46872c8
right click on mainwin_about brings menu
Tomasz Mon <desowin@gmail.com>
parents:
2959
diff
changeset
|
2477 mainwin_about = ui_skinned_button_new(); |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2478 ui_skinned_small_button_setup(mainwin_about, SKINNED_WINDOW(mainwin)->fixed, 247, 83, 20, 25); |
2964
7926d46872c8
right click on mainwin_about brings menu
Tomasz Mon <desowin@gmail.com>
parents:
2959
diff
changeset
|
2479 g_signal_connect(mainwin_about, "clicked", show_about_window, NULL); |
7926d46872c8
right click on mainwin_about brings menu
Tomasz Mon <desowin@gmail.com>
parents:
2959
diff
changeset
|
2480 g_signal_connect(mainwin_about, "right-clicked", mainwin_about_cb, NULL ); |
2313 | 2481 |
3020 | 2482 mainwin_vis = ui_vis_new(SKINNED_WINDOW(mainwin)->fixed, 24, 43, 76); |
3024
883713b145f8
use button-press-event signals
Tomasz Mon <desowin@gmail.com>
parents:
3023
diff
changeset
|
2483 g_signal_connect(mainwin_vis, "button-press-event", G_CALLBACK(mainwin_vis_cb), NULL); |
3054 | 2484 mainwin_svis = ui_svis_new(SKINNED_WINDOW(mainwin)->fixed, 79, 5); |
2485 g_signal_connect(mainwin_svis, "button-press-event", G_CALLBACK(mainwin_vis_cb), NULL); | |
2313 | 2486 |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
2487 mainwin_position = ui_skinned_horizontal_slider_new(SKINNED_WINDOW(mainwin)->fixed, 16, 72, 248, |
3042
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
2488 10, 248, 0, 278, 0, 29, 10, 10, 0, 0, 219, |
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
2489 NULL, SKIN_POSBAR); |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
2490 g_signal_connect(mainwin_position, "motion", G_CALLBACK(mainwin_position_motion_cb), NULL); |
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
2491 g_signal_connect(mainwin_position, "release", G_CALLBACK(mainwin_position_release_cb), NULL); |
2313 | 2492 |
3042
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
2493 mainwin_sposition = ui_skinned_horizontal_slider_new(SKINNED_WINDOW(mainwin)->fixed, 226, 4, 17, |
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
2494 7, 17, 36, 17, 36, 3, 7, 36, 0, 1, 13, |
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
2495 mainwin_spos_frame_cb, SKIN_TITLEBAR); |
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
2496 g_signal_connect(mainwin_sposition, "motion", G_CALLBACK(mainwin_spos_motion_cb), NULL); |
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
2497 g_signal_connect(mainwin_sposition, "release", G_CALLBACK(mainwin_spos_release_cb), NULL); |
2313 | 2498 |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2499 mainwin_stime_min = ui_skinned_textbox_new(SKINNED_WINDOW(mainwin)->fixed, 130, 4, 15, FALSE, SKIN_TEXT); |
3366
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2500 g_signal_connect(mainwin_stime_min, "button-press-event", G_CALLBACK(change_timer_mode_cb), NULL); |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
2501 |
3005
3db40ad79fd9
request GdkGC when needed rather than carry one around
Tomasz Mon <desowin@gmail.com>
parents:
3004
diff
changeset
|
2502 mainwin_stime_sec = ui_skinned_textbox_new(SKINNED_WINDOW(mainwin)->fixed, 147, 4, 10, FALSE, SKIN_TEXT); |
3366
ac752b5db631
introduce change_timer_mode_cb
Tomasz Mon <desowin@gmail.com>
parents:
3351
diff
changeset
|
2503 g_signal_connect(mainwin_stime_sec, "button-press-event", G_CALLBACK(change_timer_mode_cb), NULL); |
2313 | 2504 |
2505 err = gtk_message_dialog_new(GTK_WINDOW(mainwin), GTK_DIALOG_DESTROY_WITH_PARENT|GTK_DIALOG_MODAL, | |
2506 GTK_MESSAGE_ERROR, GTK_BUTTONS_CLOSE, _("Error in Audacious.")); | |
2507 | |
2508 | |
2509 gtk_window_set_position(GTK_WINDOW(err), GTK_WIN_POS_CENTER); | |
2510 /* Dang well better set an error message or you'll see this */ | |
2511 gtk_message_dialog_format_secondary_text(GTK_MESSAGE_DIALOG(err), | |
2512 "Boo! Bad stuff! Booga Booga!"); | |
3157
f9d34bc5079f
Remove check for playback->error.
William Pitcock <nenolod@atheme-project.org>
parents:
3151
diff
changeset
|
2513 |
f9d34bc5079f
Remove check for playback->error.
William Pitcock <nenolod@atheme-project.org>
parents:
3151
diff
changeset
|
2514 hook_associate("playback audio error", (void *) mainwin_stop_pushed, NULL); |
f9d34bc5079f
Remove check for playback->error.
William Pitcock <nenolod@atheme-project.org>
parents:
3151
diff
changeset
|
2515 hook_associate("playback audio error", (void *) run_no_output_device_dialog, NULL); |
2313 | 2516 } |
2517 | |
2518 static void | |
2519 mainwin_create_window(void) | |
2520 { | |
2521 gint width, height; | |
2522 | |
3068
c5189bc4100b
Refactor skinned window code.
William Pitcock <nenolod@atheme-project.org>
parents:
3065
diff
changeset
|
2523 mainwin = ui_skinned_window_new("player"); |
2313 | 2524 gtk_window_set_title(GTK_WINDOW(mainwin), _("Audacious")); |
2525 gtk_window_set_role(GTK_WINDOW(mainwin), "player"); | |
2526 gtk_window_set_resizable(GTK_WINDOW(mainwin), FALSE); | |
2527 | |
2528 width = cfg.player_shaded ? MAINWIN_SHADED_WIDTH : bmp_active_skin->properties.mainwin_width; | |
2529 height = cfg.player_shaded ? MAINWIN_SHADED_HEIGHT : bmp_active_skin->properties.mainwin_height; | |
2530 | |
2531 if (cfg.doublesize) { | |
2532 width *= 2; | |
2533 height *= 2; | |
2534 } | |
2535 | |
2536 gtk_widget_set_size_request(mainwin, width, height); | |
2537 | |
2538 if (cfg.player_x != -1 && cfg.save_window_position) | |
2539 gtk_window_move(GTK_WINDOW(mainwin), cfg.player_x, cfg.player_y); | |
2540 | |
2541 g_signal_connect(mainwin, "destroy", G_CALLBACK(mainwin_destroy), NULL); | |
2542 g_signal_connect(mainwin, "button_press_event", | |
2543 G_CALLBACK(mainwin_mouse_button_press), NULL); | |
2544 g_signal_connect(mainwin, "scroll_event", | |
2545 G_CALLBACK(mainwin_scrolled), NULL); | |
2546 g_signal_connect(mainwin, "button_release_event", | |
2547 G_CALLBACK(mainwin_mouse_button_release), NULL); | |
2548 | |
2549 bmp_drag_dest_set(mainwin); | |
2550 | |
2551 g_signal_connect(mainwin, "key_press_event", | |
2552 G_CALLBACK(mainwin_keypress), NULL); | |
3165
8775dfc57ead
Remove mainwin_set_info_text() craq. Still some work to do.
William Pitcock <nenolod@atheme-project.org>
parents:
3157
diff
changeset
|
2553 |
8775dfc57ead
Remove mainwin_set_info_text() craq. Still some work to do.
William Pitcock <nenolod@atheme-project.org>
parents:
3157
diff
changeset
|
2554 ui_main_evlistener_init(); |
2313 | 2555 } |
2556 | |
2557 void | |
2558 mainwin_create(void) | |
2559 { | |
2560 mainwin_create_window(); | |
2561 | |
2562 gtk_window_add_accel_group( GTK_WINDOW(mainwin) , ui_manager_get_accel_group() ); | |
2563 | |
2564 mainwin_create_widgets(); | |
2565 } | |
2566 | |
2567 void | |
2568 mainwin_attach_idle_func(void) | |
2569 { | |
2570 mainwin_timeout_id = g_timeout_add(MAINWIN_UPDATE_INTERVAL, | |
2571 mainwin_idle_func, NULL); | |
2572 } | |
2573 | |
3018
6a9fdd5aee3a
Move timer updates out of the 100hz giant loop.
Daniel Drake <dsd@gentoo.org>
parents:
3006
diff
changeset
|
2574 gboolean |
6a9fdd5aee3a
Move timer updates out of the 100hz giant loop.
Daniel Drake <dsd@gentoo.org>
parents:
3006
diff
changeset
|
2575 mainwin_update_song_info(void) |
2313 | 2576 { |
3018
6a9fdd5aee3a
Move timer updates out of the 100hz giant loop.
Daniel Drake <dsd@gentoo.org>
parents:
3006
diff
changeset
|
2577 gint time = playback_get_time(); |
2313 | 2578 gint length, t; |
2579 gchar stime_prefix; | |
2580 | |
3192
9f9b46506892
mainwin_update_song_info() should not return FALSE when time < 0 otherwise neither playtime display nor hide seekbar on streaming work.
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3191
diff
changeset
|
2581 if (!playback_get_playing()) |
3018
6a9fdd5aee3a
Move timer updates out of the 100hz giant loop.
Daniel Drake <dsd@gentoo.org>
parents:
3006
diff
changeset
|
2582 return FALSE; |
6a9fdd5aee3a
Move timer updates out of the 100hz giant loop.
Daniel Drake <dsd@gentoo.org>
parents:
3006
diff
changeset
|
2583 |
2313 | 2584 if (ab_position_a != -1 && ab_position_b != -1 && time > ab_position_b) |
2585 playback_seek(ab_position_a/1000); | |
2586 | |
2587 length = playlist_get_current_length(playlist_get_active()); | |
3018
6a9fdd5aee3a
Move timer updates out of the 100hz giant loop.
Daniel Drake <dsd@gentoo.org>
parents:
3006
diff
changeset
|
2588 playlistwin_set_time(time, length, cfg.timer_mode); |
2313 | 2589 |
2590 if (cfg.timer_mode == TIMER_REMAINING) { | |
2591 if (length != -1) { | |
3001
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
2592 ui_skinned_number_set_number(mainwin_minus_num, 11); |
2313 | 2593 t = length - time; |
2594 stime_prefix = '-'; | |
2595 } | |
2596 else { | |
3001
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
2597 ui_skinned_number_set_number(mainwin_minus_num, 10); |
2313 | 2598 t = time; |
2599 stime_prefix = ' '; | |
2600 } | |
2601 } | |
2602 else { | |
3001
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
2603 ui_skinned_number_set_number(mainwin_minus_num, 10); |
2313 | 2604 t = time; |
2605 stime_prefix = ' '; | |
2606 } | |
2607 t /= 1000; | |
2608 | |
2609 /* Show the time in the format HH:MM when we have more than 100 | |
2610 * minutes. */ | |
2611 if (t >= 100 * 60) | |
2612 t /= 60; | |
3001
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
2613 ui_skinned_number_set_number(mainwin_10min_num, t / 600); |
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
2614 ui_skinned_number_set_number(mainwin_min_num, (t / 60) % 10); |
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
2615 ui_skinned_number_set_number(mainwin_10sec_num, (t / 10) % 6); |
6d4b7b739232
fully implement UiSkinnedNumber, number.c no longer needed
Tomasz Mon <desowin@gmail.com>
parents:
3000
diff
changeset
|
2616 ui_skinned_number_set_number(mainwin_sec_num, t % 10); |
2313 | 2617 |
3042
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
2618 if (!UI_SKINNED_HORIZONTAL_SLIDER(mainwin_sposition)->pressed) { |
2313 | 2619 gchar *time_str; |
2620 | |
2621 time_str = g_strdup_printf("%c%2.2d", stime_prefix, t / 60); | |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
2622 ui_skinned_textbox_set_text(mainwin_stime_min, time_str); |
2313 | 2623 g_free(time_str); |
2624 | |
2625 time_str = g_strdup_printf("%2.2d", t % 60); | |
2942
1a59a0ced6a8
make scrolling stop for second when it reaches end, replace remaining mainwin TextBox with UiSkinnedTextbox
Tomasz Mon <desowin@gmail.com>
parents:
2911
diff
changeset
|
2626 ui_skinned_textbox_set_text(mainwin_stime_sec, time_str); |
2313 | 2627 g_free(time_str); |
2628 } | |
2629 | |
2630 time /= 1000; | |
2631 length /= 1000; | |
2632 if (length > 0) { | |
2633 if (time > length) { | |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
2634 ui_skinned_horizontal_slider_set_position(mainwin_position, 219); |
3042
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
2635 ui_skinned_horizontal_slider_set_position(mainwin_sposition, 13); |
2313 | 2636 } |
2637 /* update the slider position ONLY if there is not a seek in progress */ | |
2638 else if (seek_state == MAINWIN_SEEK_NIL) { | |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
2639 ui_skinned_horizontal_slider_set_position(mainwin_position, (time * 219) / length); |
3042
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
2640 ui_skinned_horizontal_slider_set_position(mainwin_sposition, |
2313 | 2641 ((time * 12) / length) + 1); |
2642 } | |
2643 } | |
2644 else { | |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
2645 ui_skinned_horizontal_slider_set_position(mainwin_position, 0); |
3042
01ae56759d15
mainwin_sposition is now UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3040
diff
changeset
|
2646 ui_skinned_horizontal_slider_set_position(mainwin_sposition, 1); |
2313 | 2647 } |
3018
6a9fdd5aee3a
Move timer updates out of the 100hz giant loop.
Daniel Drake <dsd@gentoo.org>
parents:
3006
diff
changeset
|
2648 |
6a9fdd5aee3a
Move timer updates out of the 100hz giant loop.
Daniel Drake <dsd@gentoo.org>
parents:
3006
diff
changeset
|
2649 return TRUE; |
2313 | 2650 } |
2651 | |
2652 static gboolean | |
2653 mainwin_idle_func(gpointer data) | |
2654 { | |
2655 static gint count = 0; | |
3177
a6299755b78a
Don't call playback_get_time() if not playing in mainwin_idle_func().
Christian Birchinger <joker@netswarm.net>
parents:
3172
diff
changeset
|
2656 |
a6299755b78a
Don't call playback_get_time() if not playing in mainwin_idle_func().
Christian Birchinger <joker@netswarm.net>
parents:
3172
diff
changeset
|
2657 if (playback_get_playing()) |
a6299755b78a
Don't call playback_get_time() if not playing in mainwin_idle_func().
Christian Birchinger <joker@netswarm.net>
parents:
3172
diff
changeset
|
2658 input_update_vis(playback_get_time()); |
2313 | 2659 |
2660 GDK_THREADS_ENTER(); | |
2661 | |
2662 if (!count) { | |
2663 read_volume(VOLSET_UPDATE); | |
2664 count = 10; | |
2665 } | |
2666 else | |
2667 count--; | |
2668 | |
2669 /* tristate buttons seek */ | |
2670 if ( seek_state != MAINWIN_SEEK_NIL ) | |
2671 { | |
2672 GTimeVal now_time; | |
2673 GTimeVal delta_time; | |
2674 gulong now_dur; | |
2675 g_get_current_time(&now_time); | |
2676 | |
2677 delta_time.tv_usec = now_time.tv_usec - cb_time.tv_usec; | |
2678 delta_time.tv_sec = now_time.tv_sec - cb_time.tv_sec; | |
2679 | |
2680 now_dur = labs((delta_time.tv_sec * 1000) + (glong) (delta_time.tv_usec / 1000)); | |
2681 | |
2682 if ( now_dur > TRISTATE_THRESHOLD ) | |
2683 { | |
2684 gint np; | |
2685 if (seek_state == MAINWIN_SEEK_REV) | |
2686 np = seek_initial_pos - labs((gulong)(now_dur/100)); /* seek back */ | |
2687 else | |
2688 np = seek_initial_pos + labs((gulong)(now_dur/100)); /* seek forward */ | |
2689 | |
2690 /* boundaries check */ | |
2691 if (np < 0 ) | |
2692 np = 0; | |
2693 else if ( np > 219 ) | |
2694 np = 219; | |
2695 | |
3040
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
2696 ui_skinned_horizontal_slider_set_position( mainwin_position , np ); |
067e0186623a
import UiSkinnedHorizontalSlider
Tomasz Mon <desowin@gmail.com>
parents:
3026
diff
changeset
|
2697 mainwin_position_motion_cb( mainwin_position, np ); |
2313 | 2698 } |
2699 } | |
2700 | |
2701 GDK_THREADS_LEAVE(); | |
2702 | |
2703 /* | |
2704 if (seek_state == MAINWIN_SEEK_REV) | |
2705 playback_seek(CLAMP(playback_get_time() - 1000, 0, | |
2706 playlist_get_current_length()) / 1000); | |
2707 else if (seek_state == MAINWIN_SEEK_FWD) | |
2708 playback_seek(CLAMP(playback_get_time() + 1000, 0, | |
2709 playlist_get_current_length()) / 1000); | |
2710 */ | |
2711 | |
2712 return TRUE; | |
2713 } | |
2714 | |
2715 | |
2353
0fb258122933
[svn] - added audacious_menu_main_show(x,y,button,time) in util.h, convenience function to display the audacious main popup menu
giacomo
parents:
2345
diff
changeset
|
2716 void |
0fb258122933
[svn] - added audacious_menu_main_show(x,y,button,time) in util.h, convenience function to display the audacious main popup menu
giacomo
parents:
2345
diff
changeset
|
2717 audacious_menu_main_show( gint x , gint y , guint button , guint time ) |
0fb258122933
[svn] - added audacious_menu_main_show(x,y,button,time) in util.h, convenience function to display the audacious main popup menu
giacomo
parents:
2345
diff
changeset
|
2718 { |
0fb258122933
[svn] - added audacious_menu_main_show(x,y,button,time) in util.h, convenience function to display the audacious main popup menu
giacomo
parents:
2345
diff
changeset
|
2719 /* convenience function that shows the main popup menu wherever requested */ |
0fb258122933
[svn] - added audacious_menu_main_show(x,y,button,time) in util.h, convenience function to display the audacious main popup menu
giacomo
parents:
2345
diff
changeset
|
2720 ui_manager_popup_menu_show( GTK_MENU(mainwin_general_menu), |
0fb258122933
[svn] - added audacious_menu_main_show(x,y,button,time) in util.h, convenience function to display the audacious main popup menu
giacomo
parents:
2345
diff
changeset
|
2721 x , y , button , time ); |
0fb258122933
[svn] - added audacious_menu_main_show(x,y,button,time) in util.h, convenience function to display the audacious main popup menu
giacomo
parents:
2345
diff
changeset
|
2722 return; |
0fb258122933
[svn] - added audacious_menu_main_show(x,y,button,time) in util.h, convenience function to display the audacious main popup menu
giacomo
parents:
2345
diff
changeset
|
2723 } |
0fb258122933
[svn] - added audacious_menu_main_show(x,y,button,time) in util.h, convenience function to display the audacious main popup menu
giacomo
parents:
2345
diff
changeset
|
2724 |
0fb258122933
[svn] - added audacious_menu_main_show(x,y,button,time) in util.h, convenience function to display the audacious main popup menu
giacomo
parents:
2345
diff
changeset
|
2725 |
2313 | 2726 /* toggleactionentries actions */ |
2727 | |
2728 void | |
2729 action_anamode_peaks( GtkToggleAction * action ) | |
2730 { | |
2731 cfg.analyzer_peaks = gtk_toggle_action_get_active( action ); | |
2732 } | |
2733 | |
2734 void | |
2735 action_autoscroll_songname( GtkToggleAction * action ) | |
2736 { | |
2737 mainwin_set_title_scroll(gtk_toggle_action_get_active(action)); | |
2738 playlistwin_set_sinfo_scroll(cfg.autoscroll); /* propagate scroll setting to playlistwin_sinfo */ | |
2739 } | |
2740 | |
2741 void | |
2742 action_playback_noplaylistadvance( GtkToggleAction * action ) | |
2743 { | |
2744 cfg.no_playlist_advance = gtk_toggle_action_get_active( action ); | |
2745 } | |
2746 | |
2747 void | |
2748 action_playback_repeat( GtkToggleAction * action ) | |
2749 { | |
2750 cfg.repeat = gtk_toggle_action_get_active( action ); | |
2843
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
2751 UI_SKINNED_BUTTON(mainwin_repeat)->inside = cfg.repeat; |
3406
3dc6ef418ec9
redraw mainwin_repeat and mainwin_shuffle when using hotkeys
Tomasz Mon <desowin@gmail.com>
parents:
3367
diff
changeset
|
2752 gtk_widget_queue_draw(mainwin_repeat); |
2313 | 2753 } |
2754 | |
2755 void | |
2756 action_playback_shuffle( GtkToggleAction * action ) | |
2757 { | |
2758 cfg.shuffle = gtk_toggle_action_get_active( action ); | |
2759 playlist_set_shuffle(cfg.shuffle); | |
2843
91ef09fe7936
UiSkinnedButton can now work as TButton
Tomasz Mon <desowin@gmail.com>
parents:
2842
diff
changeset
|
2760 UI_SKINNED_BUTTON(mainwin_shuffle)->inside = cfg.shuffle; |
3406
3dc6ef418ec9
redraw mainwin_repeat and mainwin_shuffle when using hotkeys
Tomasz Mon <desowin@gmail.com>
parents:
3367
diff
changeset
|
2761 gtk_widget_queue_draw(mainwin_shuffle); |
2313 | 2762 } |
2763 | |
2764 void | |
2765 action_stop_after_current_song( GtkToggleAction * action ) | |
2766 { | |
2767 cfg.stopaftersong = gtk_toggle_action_get_active( action ); | |
2768 } | |
2769 | |
2770 void | |
2771 action_view_always_on_top( GtkToggleAction * action ) | |
2772 { | |
3069
093759970e44
replace Menurow with UiSkinnedMenurow
Tomasz Mon <desowin@gmail.com>
parents:
3057
diff
changeset
|
2773 UI_SKINNED_MENUROW(mainwin_menurow)->always_selected = gtk_toggle_action_get_active( action ); |
093759970e44
replace Menurow with UiSkinnedMenurow
Tomasz Mon <desowin@gmail.com>
parents:
3057
diff
changeset
|
2774 cfg.always_on_top = UI_SKINNED_MENUROW(mainwin_menurow)->always_selected; |
093759970e44
replace Menurow with UiSkinnedMenurow
Tomasz Mon <desowin@gmail.com>
parents:
3057
diff
changeset
|
2775 gtk_widget_queue_draw(mainwin_menurow); |
2907
21b27e97bfb9
Remove pointless starting_up variable.
William Pitcock <nenolod@atheme.org>
parents:
2906
diff
changeset
|
2776 hint_set_always(cfg.always_on_top); |
2313 | 2777 } |
2778 | |
2779 void | |
2780 action_view_doublesize( GtkToggleAction * action ) | |
2781 { | |
3069
093759970e44
replace Menurow with UiSkinnedMenurow
Tomasz Mon <desowin@gmail.com>
parents:
3057
diff
changeset
|
2782 UI_SKINNED_MENUROW(mainwin_menurow)->doublesize_selected = gtk_toggle_action_get_active( action ); |
093759970e44
replace Menurow with UiSkinnedMenurow
Tomasz Mon <desowin@gmail.com>
parents:
3057
diff
changeset
|
2783 gtk_widget_queue_draw(mainwin_menurow); |
093759970e44
replace Menurow with UiSkinnedMenurow
Tomasz Mon <desowin@gmail.com>
parents:
3057
diff
changeset
|
2784 set_doublesize(UI_SKINNED_MENUROW(mainwin_menurow)->doublesize_selected); |
2313 | 2785 gdk_flush(); |
2786 } | |
2787 | |
2788 void | |
2789 action_view_easymove( GtkToggleAction * action ) | |
2790 { | |
2791 cfg.easy_move = gtk_toggle_action_get_active( action ); | |
2792 } | |
2793 | |
2794 void | |
2795 action_view_on_all_workspaces( GtkToggleAction * action ) | |
2796 { | |
2797 cfg.sticky = gtk_toggle_action_get_active( action ); | |
2798 hint_set_sticky(cfg.sticky); | |
2799 } | |
2800 | |
2801 void | |
2802 action_roll_up_equalizer( GtkToggleAction * action ) | |
2803 { | |
2804 equalizerwin_set_shade_menu_cb(gtk_toggle_action_get_active(action)); | |
2805 } | |
2806 | |
2807 void | |
2808 action_roll_up_player( GtkToggleAction * action ) | |
2809 { | |
2810 mainwin_set_shade_menu_cb(gtk_toggle_action_get_active(action)); | |
2811 } | |
2812 | |
2813 void | |
2814 action_roll_up_playlist_editor( GtkToggleAction * action ) | |
2815 { | |
2816 playlistwin_set_shade(gtk_toggle_action_get_active(action)); | |
2817 } | |
2818 | |
2819 void | |
2820 action_show_equalizer( GtkToggleAction * action ) | |
2821 { | |
2822 if (gtk_toggle_action_get_active(action)) | |
2823 equalizerwin_real_show(); | |
2824 else | |
2825 equalizerwin_real_hide(); | |
2826 } | |
2827 | |
2828 void | |
2829 action_show_playlist_editor( GtkToggleAction * action ) | |
2830 { | |
2831 if (gtk_toggle_action_get_active(action)) | |
2832 playlistwin_show(); | |
2833 else | |
2834 playlistwin_hide(); | |
2835 } | |
2836 | |
2837 void | |
2838 action_show_player( GtkToggleAction * action ) | |
2839 { | |
2840 mainwin_show(gtk_toggle_action_get_active(action)); | |
2841 } | |
2842 | |
2843 | |
2844 /* radioactionentries actions (one callback for each radio group) */ | |
2845 | |
2846 void | |
2847 action_anafoff( GtkAction *action, GtkRadioAction *current ) | |
2848 { | |
2849 mainwin_vis_set_afalloff(gtk_radio_action_get_current_value(current)); | |
2850 } | |
2851 | |
2852 void | |
2853 action_anamode( GtkAction *action, GtkRadioAction *current ) | |
2854 { | |
2855 mainwin_vis_set_analyzer_mode(gtk_radio_action_get_current_value(current)); | |
2856 } | |
2857 | |
2858 void | |
2859 action_anatype( GtkAction *action, GtkRadioAction *current ) | |
2860 { | |
2861 mainwin_vis_set_analyzer_type(gtk_radio_action_get_current_value(current)); | |
2862 } | |
2863 | |
2864 void | |
2865 action_peafoff( GtkAction *action, GtkRadioAction *current ) | |
2866 { | |
2867 mainwin_vis_set_pfalloff(gtk_radio_action_get_current_value(current)); | |
2868 } | |
2869 | |
2870 void | |
2871 action_refrate( GtkAction *action, GtkRadioAction *current ) | |
2872 { | |
2873 mainwin_vis_set_refresh(gtk_radio_action_get_current_value(current)); | |
2874 } | |
2875 | |
2876 void | |
2877 action_scomode( GtkAction *action, GtkRadioAction *current ) | |
2878 { | |
2879 cfg.scope_mode = gtk_radio_action_get_current_value(current); | |
2880 } | |
2881 | |
2882 void | |
2883 action_vismode( GtkAction *action, GtkRadioAction *current ) | |
2884 { | |
2885 mainwin_vis_set_type_menu_cb(gtk_radio_action_get_current_value(current)); | |
2886 } | |
2887 | |
2888 void | |
2889 action_vprmode( GtkAction *action, GtkRadioAction *current ) | |
2890 { | |
2891 cfg.voiceprint_mode = gtk_radio_action_get_current_value(current); | |
2892 } | |
2893 | |
2894 void | |
2895 action_wshmode( GtkAction *action, GtkRadioAction *current ) | |
2896 { | |
2897 cfg.vu_mode = gtk_radio_action_get_current_value(current); | |
2898 } | |
2899 | |
2900 void | |
2901 action_viewtime( GtkAction *action, GtkRadioAction *current ) | |
2902 { | |
2903 set_timer_mode_menu_cb(gtk_radio_action_get_current_value(current)); | |
2904 } | |
2905 | |
2906 | |
2907 /* actionentries actions */ | |
2908 | |
2909 void | |
2910 action_about_audacious( void ) | |
2911 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2912 show_about_window(); |
2313 | 2913 } |
2914 | |
2915 void | |
2916 action_play_file( void ) | |
2917 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2918 run_filebrowser(PLAY_BUTTON); |
2313 | 2919 } |
2920 | |
2921 void | |
2922 action_play_location( void ) | |
2923 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2924 mainwin_show_add_url_window(); |
2313 | 2925 } |
2926 | |
2927 void | |
2928 action_ab_set( void ) | |
2929 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2930 Playlist *playlist = playlist_get_active(); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2931 if (playlist_get_current_length(playlist) != -1) |
2313 | 2932 { |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2933 if (ab_position_a == -1) |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2934 { |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2935 ab_position_a = playback_get_time(); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2936 ab_position_b = -1; |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2937 mainwin_lock_info_text("LOOP-POINT A POSITION SET."); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2938 } |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2939 else if (ab_position_b == -1) |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2940 { |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2941 int time = playback_get_time(); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2942 if (time > ab_position_a) |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2943 ab_position_b = time; |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2944 mainwin_release_info_text(); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2945 } |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2946 else |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2947 { |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2948 ab_position_a = playback_get_time(); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2949 ab_position_b = -1; |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2950 mainwin_lock_info_text("LOOP-POINT A POSITION RESET."); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2951 } |
2313 | 2952 } |
2953 } | |
2954 | |
2955 void | |
2956 action_ab_clear( void ) | |
2957 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2958 Playlist *playlist = playlist_get_active(); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2959 if (playlist_get_current_length(playlist) != -1) |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2960 { |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2961 ab_position_a = ab_position_b = -1; |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2962 mainwin_release_info_text(); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2963 } |
2313 | 2964 } |
2965 | |
2966 void | |
2967 action_current_track_info( void ) | |
2968 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2969 playlist_fileinfo_current(playlist_get_active()); |
2313 | 2970 } |
2971 | |
2972 void | |
2973 action_jump_to_file( void ) | |
2974 { | |
2500 | 2975 ui_jump_to_track(); |
2313 | 2976 } |
2977 | |
2978 void | |
2979 action_jump_to_playlist_start( void ) | |
2980 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2981 Playlist *playlist = playlist_get_active(); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2982 playlist_set_position(playlist, 0); |
2313 | 2983 } |
2984 | |
2985 void | |
2986 action_jump_to_time( void ) | |
2987 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2988 mainwin_jump_to_time(); |
2313 | 2989 } |
2990 | |
2991 void | |
2992 action_playback_next( void ) | |
2993 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2994 Playlist *playlist = playlist_get_active(); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
2995 playlist_next(playlist); |
2313 | 2996 } |
2997 | |
2998 void | |
2999 action_playback_previous( void ) | |
3000 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
3001 Playlist *playlist = playlist_get_active(); |
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
3002 playlist_prev(playlist); |
2313 | 3003 } |
3004 | |
3005 void | |
3006 action_playback_play( void ) | |
3007 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
3008 mainwin_play_pushed(); |
2313 | 3009 } |
3010 | |
3011 void | |
3012 action_playback_pause( void ) | |
3013 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
3014 playback_pause(); |
2313 | 3015 } |
3016 | |
3017 void | |
3018 action_playback_stop( void ) | |
3019 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
3020 mainwin_stop_pushed(); |
2313 | 3021 } |
3022 | |
3023 void | |
3024 action_preferences( void ) | |
3025 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
3026 show_prefs_window(); |
2313 | 3027 } |
3028 | |
3029 void | |
3030 action_quit( void ) | |
3031 { | |
2416
0fd7f4f969ad
[svn] integrated urldecode.* from libaudacious into audacious directory, made separate ui_fileopener.*
mf0102
parents:
2373
diff
changeset
|
3032 mainwin_quit_cb(); |
2313 | 3033 } |