add size numeric format in bcfilebox
[goodguy/history.git] / cinelerra-5.1 / guicast / bcresources.h
1
2 /*
3  * CINELERRA
4  * Copyright (C) 2008 Adam Williams <broadcast at earthling dot net>
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19  *
20  */
21
22 #ifndef BCRESOURCES_H
23 #define BCRESOURCES_H
24
25
26
27 // Global objects for the user interface
28
29
30
31
32 #include "bcdisplayinfo.inc"
33 #include "bcfilebox.h"
34 #include "bcfontentry.inc"
35 #include "bcresources.inc"
36 #include "bcsignals.inc"
37 #include "bcsynchronous.inc"
38 #include "bcwindowbase.inc"
39 #include "vframe.inc"
40
41 #include <X11/Xlib.h>
42
43 typedef struct
44 {
45         const char *suffix;
46         int icon_type;
47 } suffix_to_type_t;
48
49 typedef struct
50 {
51         char path[BCTEXTLEN];
52         int id;
53 } filebox_history_t;
54
55 class BC_Resources
56 {
57 public:
58         BC_Resources(); // The window parameter is used to get the display information initially
59         ~BC_Resources();
60
61         friend class BC_WindowBase;
62
63         int initialize_display(BC_WindowBase *window);
64
65 // Get unique ID
66         int get_id();
67 // Get ID for filebox history.  Persistent.
68         int get_filebox_id();
69         int get_bg_color();          // window backgrounds
70         int get_bg_shadow1();        // border for windows
71         int get_bg_shadow2();
72         int get_bg_light1();
73         int get_bg_light2();
74 // Get synchronous thread for OpenGL
75         BC_Synchronous* get_synchronous();
76 // Called by user after synchronous thread is created.
77         void set_synchronous(BC_Synchronous *synchronous);
78 // Set signal handler
79         static void set_signals(BC_Signals *signal_handler);
80         static BC_Signals* get_signals();
81
82
83 // These values should be changed before the first window is created.
84 // colors
85         int bg_color;          // window backgrounds
86         int border_light1;
87         int border_light2;
88         int border_shadow1;
89         int border_shadow2;
90
91         int bg_shadow1;        // border for windows
92         int bg_shadow2;
93         int bg_light1;
94         int bg_light2;
95         int default_text_color;
96         int disabled_text_color;
97
98
99 // beveled box colors
100         int button_light;
101         int button_highlighted;
102         int button_down;
103         int button_up;
104         int button_shadow;
105         int button_uphighlighted;
106
107 // highlighting
108         int highlight_inverse;
109
110 // 3D box colors for menus
111         int menu_light;
112         int menu_highlighted;
113         int menu_down;
114         int menu_up;
115         int menu_shadow;
116 // If these are nonzero, they override the menu backgrounds.
117         VFrame *menu_popup_bg;
118         VFrame **menu_title_bg;
119         VFrame *menu_bar_bg;
120         VFrame **popupmenu_images;
121
122 // Minimum menu width
123         int min_menu_w;
124 // Menu bar text color
125         int menu_title_text;
126 // color of popup title
127         int popup_title_text;
128 // Right and left margin for text not including triangle space.
129         int popupmenu_margin;
130 // post popup on button release event
131         int popupmenu_btnup;
132 // Right margin for triangle not including text margin.
133         int popupmenu_triangle_margin;
134 // color for item text
135         int menu_item_text;
136 // Override the menu item background if nonzero.
137         VFrame **menu_item_bg;
138
139
140 // color for progress text
141         int progress_text;
142 // set focus on enter
143         int grab_input_focus;
144
145         int menu_highlighted_fontcolor;
146
147 // ms for double click
148         long double_click;
149 // ms for cursor flash
150         int blink_rate;
151 // ms for scroll repeats
152         int scroll_repeat;
153 // ms before tooltip
154         int tooltip_delay;
155         int tooltip_bg_color;
156         int tooltips_enabled;
157         int textbox_focus_policy;
158
159         int audiovideo_color;
160
161 // default color of text
162         int text_default;
163 // background color of textboxes and list boxes
164         int text_border1;
165         int text_border2;
166         int text_border2_hi;
167         int text_background;
168         int text_background_hi;
169         int text_background_noborder_hi;
170         int text_border3;
171         int text_border3_hi;
172         int text_border4;
173         int text_highlight;
174         int text_inactive_highlight;
175         int text_selected_highlight;
176 // Not used
177         int text_background_noborder;
178
179 // Optional background for highlighted text in toggle
180         VFrame *toggle_highlight_bg;
181         int toggle_text_margin;
182
183 // Background images
184         static VFrame *bg_image;
185         static VFrame *menu_bg;
186
187 // Buttons
188         VFrame **ok_images;
189         VFrame **cancel_images;
190         VFrame **filebox_text_images;
191         VFrame **filebox_icons_images;
192         VFrame **filebox_updir_images;
193         VFrame **filebox_newfolder_images;
194         VFrame **filebox_rename_images;
195         VFrame **filebox_descend_images;
196         VFrame **filebox_delete_images;
197         VFrame **filebox_reload_images;
198         VFrame **filebox_szfmt_images;
199
200 // Generic button images
201         VFrame **generic_button_images;
202 // Generic button text margin
203         int generic_button_margin;
204         VFrame **usethis_button_images;
205
206 // Toggles
207         VFrame **checkbox_images;
208         VFrame **radial_images;
209         VFrame **label_images;
210 // menu check
211         VFrame *check;
212
213         VFrame **tumble_data;
214         int tumble_duration;
215
216 // Horizontal bar
217         VFrame *bar_data;
218
219 // Listbox
220         VFrame *listbox_bg;
221         VFrame **listbox_button;
222         VFrame **listbox_expand;
223         VFrame **listbox_column;
224         VFrame *listbox_up;
225         VFrame *listbox_dn;
226         int listbox_title_overlap;
227 // Margin for titles in addition to listbox border
228         int listbox_title_margin;
229         int listbox_title_color;
230         int listbox_title_hotspot;
231         int listbox_border1;
232         int listbox_border2_hi;
233         int listbox_border2;
234         int listbox_border3_hi;
235         int listbox_border3;
236         int listbox_border4;
237 // Selected row color
238         int listbox_selected;
239 // Highlighted row color
240         int listbox_highlighted;
241 // Inactive row color
242         int listbox_inactive;
243 // Default text color
244         int listbox_text;
245
246
247 // Sliders
248         VFrame **horizontal_slider_data;
249         VFrame **vertical_slider_data;
250         VFrame **hscroll_data;
251
252         VFrame **vscroll_data;
253 // Minimum pixels in handle
254         int scroll_minhandle;
255
256 // Pans
257         VFrame **pan_data;
258         int pan_text_color;
259
260 // Pots
261         VFrame **pot_images;
262         int pot_x1, pot_y1, pot_r;
263 // Amount of deflection of pot when down
264         int pot_offset;
265         int pot_needle_color;
266
267 // Meters
268         VFrame **xmeter_images, **ymeter_images;
269         int meter_font;
270         int meter_font_color;
271         int meter_title_w;
272         int meter_3d;
273
274 // Progress bar
275         VFrame **progress_images;
276
277 // Motion required to start a drag
278         int drag_radius;
279
280 // Filebox
281         static suffix_to_type_t suffix_to_type[];
282         VFrame **type_to_icon;
283 // Display mode for fileboxes
284         int filebox_mode;
285 // Filter currently used in filebox
286         char filebox_filter[BCTEXTLEN];
287 // History of submitted files
288         filebox_history_t filebox_history[FILEBOX_HISTORY_SIZE];
289 // filebox size
290         int filebox_w;
291         int filebox_h;
292 // Column types for filebox
293         int filebox_columntype[FILEBOX_COLUMNS];
294         int filebox_columnwidth[FILEBOX_COLUMNS];
295         int filebox_sortcolumn;
296         int filebox_sortorder;
297 // Column types for filebox in directory mode
298         int dirbox_columntype[FILEBOX_COLUMNS];
299         int dirbox_columnwidth[FILEBOX_COLUMNS];
300         int dirbox_sortcolumn;
301         int dirbox_sortorder;
302 // Bottom margin between list and window
303         int filebox_margin;
304         int dirbox_margin;
305         int directory_color;
306         int file_color;
307         double font_scale, icon_scale;
308 // fonts
309         static const char *small_font, *small_font2;
310         static const char *medium_font, *medium_font2;
311         static const char *large_font, *large_font2;
312         static const char *big_font, *big_font2;
313         static const char *clock_font, *clock_font2;
314
315         static const char *small_fontset;
316         static const char *medium_fontset;
317         static const char *large_fontset;
318         static const char *big_fontset;
319         static const char *clock_fontset;
320
321         static const char *small_font_xft, *small_b_font_xft;
322         static const char *medium_font_xft, *medium_b_font_xft;
323         static const char *large_font_xft, *large_b_font_xft;
324         static const char *big_font_xft, *big_b_font_xft;
325         static const char *clock_font_xft, *clock_b_font_xft;
326
327 // Backup of fonts in case the first choices don't exist
328         static const char *small_font_xft2;
329         static const char *medium_font_xft2;
330         static const char *large_font_xft2;
331         static const char *big_font_xft2;
332         static const char *clock_font_xft2;
333
334         void init_font_defs(double scale);
335         void finit_font_defs();
336
337         VFrame **medium_7segment;
338
339 //clock
340         int draw_clock_background;
341
342         int use_fontset;
343         int use_xft;
344
345 // Current locale uses utf8
346         static int locale_utf8;
347 // Byte order is little_endian
348         static int little_endian;
349 // Language and region
350         static char language[LEN_LANG];
351         static char region[LEN_LANG];
352         static char encoding[LEN_ENCOD];
353         static const char *wide_encoding;
354         static ArrayList<BC_FontEntry*> *fontlist;
355         static int init_fontconfig(const char *search_path);
356         static BC_FontEntry *find_fontentry(const char *displayname, int style,
357                 int mask, int preferred_style = 0);
358         static void encode_to_utf8(char *buffer, int buflen);
359         static FcPattern* find_similar_font(FT_ULong char_code, FcPattern *oldfont);
360         static size_t encode(const char *from_enc, const char *to_enc,
361                 char *input, int input_length, char *output, int output_length);
362         static int find_font_by_char(FT_ULong char_code, char *path_new, const FT_Face oldface);
363         static int font_debug;
364         static void dump_fonts(FILE *fp = stdout);
365         static void dump_font_entry(FILE *fp, const char *cp,  BC_FontEntry *ep);
366
367         static void new_vframes(int n, VFrame *vframes[], ...);
368         static void del_vframes(VFrame *vframes[], int n);
369 // default images
370         static VFrame *default_type_to_icon[6];
371         static VFrame *default_bar;
372         static VFrame *default_cancel_images[3];
373         static VFrame *default_ok_images[3];
374         static VFrame *default_usethis_images[3];
375 #if 0
376         static VFrame *default_checkbox_images[5];
377         static VFrame *default_radial_images[5];
378         static VFrame *default_label_images[5];
379 #endif
380         static VFrame *default_menuitem_data[3];
381         static VFrame *default_menubar_data[3];
382         static VFrame *default_menu_popup_bg;
383         static VFrame *default_menu_bar_bg;
384         static VFrame *default_check_image;
385         static VFrame *default_filebox_text_images[3];
386         static VFrame *default_filebox_icons_images[3];
387         static VFrame *default_filebox_updir_images[3];
388         static VFrame *default_filebox_newfolder_images[3];
389         static VFrame *default_filebox_rename_images[3];
390         static VFrame *default_filebox_delete_images[3];
391         static VFrame *default_filebox_reload_images[3];
392         static VFrame *default_filebox_szfmt_images[3];
393         static VFrame *default_listbox_button[4];
394         static VFrame *default_listbox_bg;
395         static VFrame *default_listbox_expand[5];
396         static VFrame *default_listbox_column[3];
397         static VFrame *default_listbox_up;
398         static VFrame *default_listbox_dn;
399         static VFrame *default_pot_images[3];
400         static VFrame *default_progress_images[2];
401         static VFrame *default_medium_7segment[20];
402
403 // Make VFrame use shm
404         int vframe_shm;
405         int use_vframe_shm() { return use_shm && vframe_shm ? 1 : 0; }
406
407         static int get_machine_cpus();
408         static int machine_cpus;
409 // Available display extensions
410         int use_shm;
411         int shm_reply;
412         static int error;
413 // If the program uses recursive_resizing
414         int recursive_resizing;
415 // Work around X server bugs
416         int use_xvideo;
417 // Seems to help if only 1 window is created at a time.
418         Mutex *create_window_lock;
419 // size raw, 1000, 1024, thou
420         int filebox_size_format;
421 private:
422 // Test for availability of shared memory pixmaps
423         void init_shm(BC_WindowBase *window);
424         void init_sizes(BC_WindowBase *window);
425         static int x_error_handler(Display *display, XErrorEvent *event);
426         VFrame **list_pointers[100];
427         int list_lengths[100];
428         int list_total;
429         static const char *fc_properties[];
430
431
432         Mutex *id_lock;
433         static Mutex fontconfig_lock;
434
435 // Pointer to signal handler class to run after ipc
436         static BC_Signals *signal_handler;
437         BC_Synchronous *synchronous;
438
439         int id;
440         int filebox_id;
441 };
442
443
444 #endif