Mercurial > mplayer.hg
annotate libmenu/menu.c @ 35320:2ea8746871f2
cpuinfo binary needs to be compiled with host compiler.
author | reimar |
---|---|
date | Sat, 10 Nov 2012 15:51:19 +0000 |
parents | aad2bda4f65f |
children | 389d43c448b3 |
rev | line source |
---|---|
28113 | 1 /* |
2 * This file is part of MPlayer. | |
3 * | |
4 * MPlayer is free software; you can redistribute it and/or modify | |
5 * it under the terms of the GNU General Public License as published by | |
6 * the Free Software Foundation; either version 2 of the License, or | |
7 * (at your option) any later version. | |
8 * | |
9 * MPlayer is distributed in the hope that it will be useful, | |
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
12 * GNU General Public License for more details. | |
13 * | |
14 * You should have received a copy of the GNU General Public License along | |
15 * with MPlayer; if not, write to the Free Software Foundation, Inc., | |
16 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | |
17 */ | |
8197 | 18 |
16862 | 19 #include "config.h" |
17994
6927fabaef92
Part1 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu
reynaldo
parents:
17993
diff
changeset
|
20 #include "mp_msg.h" |
6927fabaef92
Part1 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu
reynaldo
parents:
17993
diff
changeset
|
21 #include "help_mp.h" |
8197 | 22 |
23 #include <stdlib.h> | |
24 #include <stdio.h> | |
25 #include <string.h> | |
8604
41a1e5dbb552
This patch fixes the reading of the menu.conf, because stream_open()
arpi
parents:
8251
diff
changeset
|
26 #include <fcntl.h> |
41a1e5dbb552
This patch fixes the reading of the menu.conf, because stream_open()
arpi
parents:
8251
diff
changeset
|
27 #include <unistd.h> |
8197 | 28 |
32469
3fef2e17a03f
Move osd.[ch] and osd_template.c from libvo to sub.
cigaes
parents:
32467
diff
changeset
|
29 #include "sub/osd.h" |
32466
9e627a1793b1
Move font_load.[ch], font_load_ft.c and osd_font.h from libvo to sub.
cigaes
parents:
32135
diff
changeset
|
30 #include "sub/font_load.h" |
32467 | 31 #include "sub/sub.h" |
16862 | 32 #include "osdep/keycodes.h" |
33 #include "asxparser.h" | |
19271
64d82a45a05d
introduce new 'stream' directory for all stream layer related components and split them from libmpdemux
ben
parents:
18194
diff
changeset
|
34 #include "stream/stream.h" |
25263
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
35 #include "input/input.h" |
8197 | 36 |
19431
ac69ba536915
Explicitly include libmpcodecs/img_format.h and libvo/fastmemcpy.h.
diego
parents:
19271
diff
changeset
|
37 #include "libmpcodecs/img_format.h" |
ac69ba536915
Explicitly include libmpcodecs/img_format.h and libvo/fastmemcpy.h.
diego
parents:
19271
diff
changeset
|
38 #include "libmpcodecs/mp_image.h" |
16862 | 39 #include "m_option.h" |
40 #include "m_struct.h" | |
8197 | 41 #include "menu.h" |
42 | |
32135
1e86e91fec5d
const-correctness for the menu_info_t OSD menu info declarations
diego
parents:
31661
diff
changeset
|
43 extern const menu_info_t menu_info_cmdlist; |
1e86e91fec5d
const-correctness for the menu_info_t OSD menu info declarations
diego
parents:
31661
diff
changeset
|
44 extern const menu_info_t menu_info_chapsel; |
1e86e91fec5d
const-correctness for the menu_info_t OSD menu info declarations
diego
parents:
31661
diff
changeset
|
45 extern const menu_info_t menu_info_pt; |
1e86e91fec5d
const-correctness for the menu_info_t OSD menu info declarations
diego
parents:
31661
diff
changeset
|
46 extern const menu_info_t menu_info_filesel; |
1e86e91fec5d
const-correctness for the menu_info_t OSD menu info declarations
diego
parents:
31661
diff
changeset
|
47 extern const menu_info_t menu_info_txt; |
1e86e91fec5d
const-correctness for the menu_info_t OSD menu info declarations
diego
parents:
31661
diff
changeset
|
48 extern const menu_info_t menu_info_console; |
1e86e91fec5d
const-correctness for the menu_info_t OSD menu info declarations
diego
parents:
31661
diff
changeset
|
49 extern const menu_info_t menu_info_pref; |
1e86e91fec5d
const-correctness for the menu_info_t OSD menu info declarations
diego
parents:
31661
diff
changeset
|
50 extern const menu_info_t menu_info_dvbsel; |
10626
fd97f3727f15
Finnaly commit Nico's dvb menu. Sorry for committing this
albeu
parents:
10397
diff
changeset
|
51 |
8197 | 52 |
32135
1e86e91fec5d
const-correctness for the menu_info_t OSD menu info declarations
diego
parents:
31661
diff
changeset
|
53 const menu_info_t * const menu_info_list[] = { |
8197 | 54 &menu_info_pt, |
55 &menu_info_cmdlist, | |
25364 | 56 &menu_info_chapsel, |
8197 | 57 &menu_info_filesel, |
58 &menu_info_txt, | |
59 &menu_info_console, | |
27370
14c5017f40d2
Change a bunch of video/audio-output-specific preprocessor directives from
diego
parents:
27359
diff
changeset
|
60 #ifdef CONFIG_DVBIN |
10626
fd97f3727f15
Finnaly commit Nico's dvb menu. Sorry for committing this
albeu
parents:
10397
diff
changeset
|
61 &menu_info_dvbsel, |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28113
diff
changeset
|
62 #endif |
8197 | 63 &menu_info_pref, |
64 NULL | |
65 }; | |
66 | |
25263
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
67 typedef struct key_cmd_s { |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
68 int key; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
69 char *cmd; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
70 } key_cmd_t; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
71 |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
72 typedef struct menu_cmd_bindings_s { |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
73 char *name; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
74 key_cmd_t *bindings; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
75 int binding_num; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
76 struct menu_cmd_bindings_s *parent; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
77 } menu_cmd_bindings_t; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
78 |
25208
1b3dabc8c2b8
Add type info to menu_t, now we can get the menu name and the type name of menu.
ulion
parents:
24940
diff
changeset
|
79 struct menu_def_st { |
8197 | 80 char* name; |
35303 | 81 const menu_info_t* type; |
8197 | 82 void* cfg; |
83 char* args; | |
25208
1b3dabc8c2b8
Add type info to menu_t, now we can get the menu name and the type name of menu.
ulion
parents:
24940
diff
changeset
|
84 }; |
8197 | 85 |
25461 | 86 double menu_mouse_x = -1.0; |
87 double menu_mouse_y = -1.0; | |
88 int menu_mouse_pos_updated = 0; | |
89 | |
22284 | 90 static struct MPContext *menu_ctx = NULL; |
8197 | 91 static menu_def_t* menu_list = NULL; |
21797
14061bc22cb3
fix gprof support (aka work around gprof's brain dead design)
gpoirier
parents:
20507
diff
changeset
|
92 static int menu_count = 0; |
25263
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
93 static menu_cmd_bindings_t *cmd_bindings = NULL; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
94 static int cmd_bindings_num = 0; |
8197 | 95 |
96 | |
30590
d218228dc74d
Mark some more functions that are not used outside of their files as static.
diego
parents:
29263
diff
changeset
|
97 static menu_cmd_bindings_t *get_cmd_bindings(const char *name) |
d218228dc74d
Mark some more functions that are not used outside of their files as static.
diego
parents:
29263
diff
changeset
|
98 { |
25263
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
99 int i; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
100 for (i = 0; i < cmd_bindings_num; ++i) |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
101 if (!strcasecmp(cmd_bindings[i].name, name)) |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
102 return &cmd_bindings[i]; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
103 return NULL; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
104 } |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
105 |
8197 | 106 static int menu_parse_config(char* buffer) { |
107 char *element,*body, **attribs, *name; | |
32135
1e86e91fec5d
const-correctness for the menu_info_t OSD menu info declarations
diego
parents:
31661
diff
changeset
|
108 const menu_info_t* minfo = NULL; |
8197 | 109 int r,i; |
110 ASX_Parser_t* parser = asx_parser_new(); | |
111 | |
112 while(1) { | |
113 r = asx_get_element(parser,&buffer,&element,&body,&attribs); | |
114 if(r < 0) { | |
17994
6927fabaef92
Part1 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu
reynaldo
parents:
17993
diff
changeset
|
115 mp_msg(MSGT_GLOBAL,MSGL_WARN,MSGTR_LIBMENU_SyntaxErrorAtLine,parser->line); |
8197 | 116 asx_parser_free(parser); |
117 return 0; | |
118 } else if(r == 0) { | |
119 asx_parser_free(parser); | |
120 return 1; | |
121 } | |
122 // Has it a name ? | |
123 name = asx_get_attrib("name",attribs); | |
124 if(!name) { | |
17994
6927fabaef92
Part1 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu
reynaldo
parents:
17993
diff
changeset
|
125 mp_msg(MSGT_GLOBAL,MSGL_WARN,MSGTR_LIBMENU_MenuDefinitionsNeedANameAttrib,parser->line); |
8197 | 126 free(element); |
32537
8fa2f43cb760
Remove most of the NULL pointer check before free all over the code
cboesch
parents:
32469
diff
changeset
|
127 free(body); |
8197 | 128 asx_free_attribs(attribs); |
129 continue; | |
130 } | |
131 | |
25263
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
132 if (!strcasecmp(element, "keybindings")) { |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
133 menu_cmd_bindings_t *bindings = cmd_bindings; |
25347
22e5eb039c83
Fix memory leak. I thought asx_get_attrib() return a const char *,
ulion
parents:
25320
diff
changeset
|
134 char *parent_bindings; |
25263
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
135 cmd_bindings = realloc(cmd_bindings, |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
136 (cmd_bindings_num+1)*sizeof(menu_cmd_bindings_t)); |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
137 for (i = 0; i < cmd_bindings_num; ++i) |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
138 if (cmd_bindings[i].parent) |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
139 cmd_bindings[i].parent = cmd_bindings[i].parent-bindings+cmd_bindings; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
140 bindings = &cmd_bindings[cmd_bindings_num]; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
141 memset(bindings, 0, sizeof(menu_cmd_bindings_t)); |
25347
22e5eb039c83
Fix memory leak. I thought asx_get_attrib() return a const char *,
ulion
parents:
25320
diff
changeset
|
142 bindings->name = name; |
25263
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
143 parent_bindings = asx_get_attrib("parent",attribs); |
25347
22e5eb039c83
Fix memory leak. I thought asx_get_attrib() return a const char *,
ulion
parents:
25320
diff
changeset
|
144 if (parent_bindings) { |
25263
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
145 bindings->parent = get_cmd_bindings(parent_bindings); |
25347
22e5eb039c83
Fix memory leak. I thought asx_get_attrib() return a const char *,
ulion
parents:
25320
diff
changeset
|
146 free(parent_bindings); |
22e5eb039c83
Fix memory leak. I thought asx_get_attrib() return a const char *,
ulion
parents:
25320
diff
changeset
|
147 } |
25263
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
148 free(element); |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
149 asx_free_attribs(attribs); |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
150 if (body) { |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
151 char *bd = body; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
152 char *b, *key, *cmd; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
153 int keycode; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
154 for(;;) { |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
155 r = asx_get_element(parser,&bd,&element,&b,&attribs); |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
156 if(r < 0) { |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
157 mp_msg(MSGT_GLOBAL,MSGL_WARN,MSGTR_LIBMENU_SyntaxErrorAtLine, |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
158 parser->line); |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
159 free(body); |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
160 asx_parser_free(parser); |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
161 return 0; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
162 } |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
163 if(r == 0) |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
164 break; |
25408
f73887cc6b45
Ignore elements of keybindings other than 'binding'.
ulion
parents:
25407
diff
changeset
|
165 if (!strcasecmp(element, "binding")) { |
25409 | 166 key = asx_get_attrib("key",attribs); |
167 cmd = asx_get_attrib("cmd",attribs); | |
168 if (key && (keycode = mp_input_get_key_from_name(key)) >= 0) { | |
169 keycode &= ~MP_NO_REPEAT_KEY; | |
170 mp_msg(MSGT_GLOBAL,MSGL_V, | |
171 "[libmenu] got keybinding element %d %s=>[%s].\n", | |
172 keycode, key, cmd ? cmd : ""); | |
173 bindings->bindings = realloc(bindings->bindings, | |
25263
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
174 (bindings->binding_num+1)*sizeof(key_cmd_t)); |
25409 | 175 bindings->bindings[bindings->binding_num].key = keycode; |
176 bindings->bindings[bindings->binding_num].cmd = cmd; | |
177 ++bindings->binding_num; | |
178 } | |
179 else | |
180 free(cmd); | |
181 free(key); | |
25408
f73887cc6b45
Ignore elements of keybindings other than 'binding'.
ulion
parents:
25407
diff
changeset
|
182 } |
25263
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
183 free(element); |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
184 asx_free_attribs(attribs); |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
185 free(b); |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
186 } |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
187 free(body); |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
188 } |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
189 ++cmd_bindings_num; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
190 continue; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
191 } |
8197 | 192 // Try to find this menu type in our list |
193 for(i = 0, minfo = NULL ; menu_info_list[i] ; i++) { | |
194 if(strcasecmp(element,menu_info_list[i]->name) == 0) { | |
195 minfo = menu_info_list[i]; | |
196 break; | |
197 } | |
198 } | |
199 // Got it : add this to our list | |
200 if(minfo) { | |
21797
14061bc22cb3
fix gprof support (aka work around gprof's brain dead design)
gpoirier
parents:
20507
diff
changeset
|
201 menu_list = realloc(menu_list,(menu_count+2)*sizeof(menu_def_t)); |
14061bc22cb3
fix gprof support (aka work around gprof's brain dead design)
gpoirier
parents:
20507
diff
changeset
|
202 menu_list[menu_count].name = name; |
14061bc22cb3
fix gprof support (aka work around gprof's brain dead design)
gpoirier
parents:
20507
diff
changeset
|
203 menu_list[menu_count].type = minfo; |
14061bc22cb3
fix gprof support (aka work around gprof's brain dead design)
gpoirier
parents:
20507
diff
changeset
|
204 menu_list[menu_count].cfg = m_struct_alloc(&minfo->priv_st); |
14061bc22cb3
fix gprof support (aka work around gprof's brain dead design)
gpoirier
parents:
20507
diff
changeset
|
205 menu_list[menu_count].args = body; |
8197 | 206 // Setup the attribs |
207 for(i = 0 ; attribs[2*i] ; i++) { | |
208 if(strcasecmp(attribs[2*i],"name") == 0) continue; | |
21797
14061bc22cb3
fix gprof support (aka work around gprof's brain dead design)
gpoirier
parents:
20507
diff
changeset
|
209 if(!m_struct_set(&minfo->priv_st,menu_list[menu_count].cfg,attribs[2*i], attribs[2*i+1])) |
17994
6927fabaef92
Part1 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu
reynaldo
parents:
17993
diff
changeset
|
210 mp_msg(MSGT_GLOBAL,MSGL_WARN,MSGTR_LIBMENU_BadAttrib,attribs[2*i],attribs[2*i+1], |
8197 | 211 name,parser->line); |
212 } | |
21797
14061bc22cb3
fix gprof support (aka work around gprof's brain dead design)
gpoirier
parents:
20507
diff
changeset
|
213 menu_count++; |
14061bc22cb3
fix gprof support (aka work around gprof's brain dead design)
gpoirier
parents:
20507
diff
changeset
|
214 memset(&menu_list[menu_count],0,sizeof(menu_def_t)); |
8197 | 215 } else { |
17994
6927fabaef92
Part1 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu
reynaldo
parents:
17993
diff
changeset
|
216 mp_msg(MSGT_GLOBAL,MSGL_WARN,MSGTR_LIBMENU_UnknownMenuType,element,parser->line); |
8197 | 217 free(name); |
32537
8fa2f43cb760
Remove most of the NULL pointer check before free all over the code
cboesch
parents:
32469
diff
changeset
|
218 free(body); |
8197 | 219 } |
220 | |
221 free(element); | |
222 asx_free_attribs(attribs); | |
223 } | |
224 | |
225 } | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28113
diff
changeset
|
226 |
8197 | 227 |
228 /// This will build the menu_defs list from the cfg file | |
229 #define BUF_STEP 1024 | |
230 #define BUF_MIN 128 | |
231 #define BUF_MAX BUF_STEP*1024 | |
22284 | 232 int menu_init(struct MPContext *mpctx, char* cfg_file) { |
8197 | 233 char* buffer = NULL; |
234 int bl = BUF_STEP, br = 0; | |
35302 | 235 int f = 0, fd = -1; |
27393 | 236 #ifndef CONFIG_FREETYPE |
9103
6c2c74adaebe
mplayer crashes if one tries to use osd menu without having a font
arpi
parents:
8604
diff
changeset
|
237 if(vo_font == NULL) |
35302 | 238 goto out; |
9212
24b102dbd0fe
Fixes a problem where the menu won't work, if you just use freetype fonts
arpi
parents:
9103
diff
changeset
|
239 #endif |
9103
6c2c74adaebe
mplayer crashes if one tries to use osd menu without having a font
arpi
parents:
8604
diff
changeset
|
240 fd = open(cfg_file, O_RDONLY); |
8604
41a1e5dbb552
This patch fixes the reading of the menu.conf, because stream_open()
arpi
parents:
8251
diff
changeset
|
241 if(fd < 0) { |
17994
6927fabaef92
Part1 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu
reynaldo
parents:
17993
diff
changeset
|
242 mp_msg(MSGT_GLOBAL,MSGL_WARN,MSGTR_LIBMENU_CantOpenConfigFile,cfg_file); |
35302 | 243 goto out; |
8197 | 244 } |
245 buffer = malloc(bl); | |
246 while(1) { | |
247 int r; | |
248 if(bl - br < BUF_MIN) { | |
249 if(bl >= BUF_MAX) { | |
17994
6927fabaef92
Part1 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu
reynaldo
parents:
17993
diff
changeset
|
250 mp_msg(MSGT_GLOBAL,MSGL_WARN,MSGTR_LIBMENU_ConfigFileIsTooBig,BUF_MAX/1024); |
35302 | 251 goto out; |
8197 | 252 } |
253 bl += BUF_STEP; | |
254 buffer = realloc(buffer,bl); | |
255 } | |
8604
41a1e5dbb552
This patch fixes the reading of the menu.conf, because stream_open()
arpi
parents:
8251
diff
changeset
|
256 r = read(fd,buffer+br,bl-br); |
8197 | 257 if(r == 0) break; |
258 br += r; | |
259 } | |
260 if(!br) { | |
17994
6927fabaef92
Part1 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu
reynaldo
parents:
17993
diff
changeset
|
261 mp_msg(MSGT_GLOBAL,MSGL_WARN,MSGTR_LIBMENU_ConfigFileIsEmpty); |
35302 | 262 goto out; |
8197 | 263 } |
264 buffer[br-1] = '\0'; | |
265 | |
22284 | 266 menu_ctx = mpctx; |
8197 | 267 f = menu_parse_config(buffer); |
35302 | 268 |
269 out: | |
270 if (fd != -1) close(fd); | |
8197 | 271 free(buffer); |
272 return f; | |
273 } | |
274 | |
275 // Destroy all this stuff | |
25420 | 276 void menu_uninit(void) { |
8197 | 277 int i; |
278 for(i = 0 ; menu_list && menu_list[i].name ; i++) { | |
279 free(menu_list[i].name); | |
280 m_struct_free(&menu_list[i].type->priv_st,menu_list[i].cfg); | |
32537
8fa2f43cb760
Remove most of the NULL pointer check before free all over the code
cboesch
parents:
32469
diff
changeset
|
281 free(menu_list[i].args); |
8197 | 282 } |
283 free(menu_list); | |
21797
14061bc22cb3
fix gprof support (aka work around gprof's brain dead design)
gpoirier
parents:
20507
diff
changeset
|
284 menu_count = 0; |
25263
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
285 for (i = 0; i < cmd_bindings_num; ++i) { |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
286 free(cmd_bindings[i].name); |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
287 while(cmd_bindings[i].binding_num > 0) |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
288 free(cmd_bindings[i].bindings[--cmd_bindings[i].binding_num].cmd); |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
289 free(cmd_bindings[i].bindings); |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
290 } |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
291 free(cmd_bindings); |
8197 | 292 } |
293 | |
294 /// Default read_key function | |
25263
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
295 int menu_dflt_read_key(menu_t* menu,int cmd) { |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
296 int i; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
297 menu_cmd_bindings_t *bindings = get_cmd_bindings(menu->type->name); |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
298 if (!bindings) |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
299 bindings = get_cmd_bindings(menu->type->type->name); |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
300 if (!bindings) |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
301 bindings = get_cmd_bindings("default"); |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
302 while (bindings) { |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
303 for (i = 0; i < bindings->binding_num; ++i) { |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
304 if (bindings->bindings[i].key == cmd) { |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
305 if (bindings->bindings[i].cmd) |
25320
4fbf536cc033
Support to run multiple mplayer commands set in menu.conf
ulion
parents:
25263
diff
changeset
|
306 mp_input_parse_and_queue_cmds(bindings->bindings[i].cmd); |
25263
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
307 return 1; |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
308 } |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
309 } |
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
310 bindings = bindings->parent; |
8197 | 311 } |
25263
96d0992c7920
Remove hardcoded key->cmd bindings in libmenu, support custom key bindings
ulion
parents:
25208
diff
changeset
|
312 return 0; |
8197 | 313 } |
314 | |
315 menu_t* menu_open(char *name) { | |
316 menu_t* m; | |
317 int i; | |
318 | |
319 for(i = 0 ; menu_list[i].name != NULL ; i++) { | |
320 if(strcmp(name,menu_list[i].name) == 0) | |
321 break; | |
322 } | |
323 if(menu_list[i].name == NULL) { | |
17994
6927fabaef92
Part1 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu
reynaldo
parents:
17993
diff
changeset
|
324 mp_msg(MSGT_GLOBAL,MSGL_WARN,MSGTR_LIBMENU_MenuNotFound,name); |
8197 | 325 return NULL; |
326 } | |
327 m = calloc(1,sizeof(menu_t)); | |
328 m->priv_st = &(menu_list[i].type->priv_st); | |
329 m->priv = m_struct_copy(m->priv_st,menu_list[i].cfg); | |
22284 | 330 m->ctx = menu_ctx; |
25208
1b3dabc8c2b8
Add type info to menu_t, now we can get the menu name and the type name of menu.
ulion
parents:
24940
diff
changeset
|
331 m->type = &menu_list[i]; |
8197 | 332 if(menu_list[i].type->open(m,menu_list[i].args)) |
333 return m; | |
334 if(m->priv) | |
335 m_struct_free(m->priv_st,m->priv); | |
336 free(m); | |
17994
6927fabaef92
Part1 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu
reynaldo
parents:
17993
diff
changeset
|
337 mp_msg(MSGT_GLOBAL,MSGL_WARN,MSGTR_LIBMENU_MenuInitFailed,name); |
8197 | 338 return NULL; |
339 } | |
340 | |
341 void menu_draw(menu_t* menu,mp_image_t* mpi) { | |
342 if(menu->show && menu->draw) | |
343 menu->draw(menu,mpi); | |
344 } | |
345 | |
25461 | 346 void menu_update_mouse_pos(double x, double y) { |
347 menu_mouse_x = x; | |
348 menu_mouse_y = y; | |
349 menu_mouse_pos_updated = 1; | |
350 } | |
351 | |
8197 | 352 void menu_read_cmd(menu_t* menu,int cmd) { |
353 if(menu->read_cmd) | |
354 menu->read_cmd(menu,cmd); | |
355 } | |
356 | |
357 void menu_close(menu_t* menu) { | |
358 if(menu->close) | |
359 menu->close(menu); | |
360 if(menu->priv) | |
361 m_struct_free(menu->priv_st,menu->priv); | |
362 free(menu); | |
363 } | |
364 | |
25502
605d4e3e403f
From now on, libmenu does not steal all input keys from input modules.
ulion
parents:
25461
diff
changeset
|
365 int menu_read_key(menu_t* menu,int cmd) { |
8197 | 366 if(menu->read_key) |
25502
605d4e3e403f
From now on, libmenu does not steal all input keys from input modules.
ulion
parents:
25461
diff
changeset
|
367 return menu->read_key(menu,cmd); |
8197 | 368 else |
25502
605d4e3e403f
From now on, libmenu does not steal all input keys from input modules.
ulion
parents:
25461
diff
changeset
|
369 return menu_dflt_read_key(menu,cmd); |
8197 | 370 } |
371 | |
372 ///////////////////////////// Helpers //////////////////////////////////// | |
373 | |
374 typedef void (*draw_alpha_f)(int w,int h, unsigned char* src, unsigned char *srca, int srcstride, unsigned char* dstbase,int dststride); | |
375 | |
34492
1495455e6d22
Move static keyword to the beginning of function declarations.
diego
parents:
33353
diff
changeset
|
376 static inline draw_alpha_f get_draw_alpha(uint32_t fmt) { |
8197 | 377 switch(fmt) { |
31082
92f88bb315c5
Add support for 12-bit color mode on framebuffer devices.
cehoyos
parents:
30590
diff
changeset
|
378 case IMGFMT_BGR12: |
92f88bb315c5
Add support for 12-bit color mode on framebuffer devices.
cehoyos
parents:
30590
diff
changeset
|
379 case IMGFMT_RGB12: |
92f88bb315c5
Add support for 12-bit color mode on framebuffer devices.
cehoyos
parents:
30590
diff
changeset
|
380 return vo_draw_alpha_rgb12; |
8197 | 381 case IMGFMT_BGR15: |
382 case IMGFMT_RGB15: | |
383 return vo_draw_alpha_rgb15; | |
384 case IMGFMT_BGR16: | |
385 case IMGFMT_RGB16: | |
386 return vo_draw_alpha_rgb16; | |
387 case IMGFMT_BGR24: | |
388 case IMGFMT_RGB24: | |
389 return vo_draw_alpha_rgb24; | |
390 case IMGFMT_BGR32: | |
391 case IMGFMT_RGB32: | |
392 return vo_draw_alpha_rgb32; | |
393 case IMGFMT_YV12: | |
394 case IMGFMT_I420: | |
395 case IMGFMT_IYUV: | |
396 case IMGFMT_YVU9: | |
397 case IMGFMT_IF09: | |
398 case IMGFMT_Y800: | |
399 case IMGFMT_Y8: | |
400 return vo_draw_alpha_yv12; | |
401 case IMGFMT_YUY2: | |
402 return vo_draw_alpha_yuy2; | |
18194 | 403 case IMGFMT_UYVY: |
404 return vo_draw_alpha_uyvy; | |
8197 | 405 } |
406 | |
407 return NULL; | |
408 } | |
409 | |
8224
fefc56153615
Fix freetype. Freetype is highly recommended for a nice output ;)
albeu
parents:
8197
diff
changeset
|
410 // return the real height of a char: |
fefc56153615
Fix freetype. Freetype is highly recommended for a nice output ;)
albeu
parents:
8197
diff
changeset
|
411 static inline int get_height(int c,int h){ |
fefc56153615
Fix freetype. Freetype is highly recommended for a nice output ;)
albeu
parents:
8197
diff
changeset
|
412 int font; |
fefc56153615
Fix freetype. Freetype is highly recommended for a nice output ;)
albeu
parents:
8197
diff
changeset
|
413 if ((font=vo_font->font[c])>=0) |
fefc56153615
Fix freetype. Freetype is highly recommended for a nice output ;)
albeu
parents:
8197
diff
changeset
|
414 if(h<vo_font->pic_a[font]->h) h=vo_font->pic_a[font]->h; |
fefc56153615
Fix freetype. Freetype is highly recommended for a nice output ;)
albeu
parents:
8197
diff
changeset
|
415 return h; |
fefc56153615
Fix freetype. Freetype is highly recommended for a nice output ;)
albeu
parents:
8197
diff
changeset
|
416 } |
fefc56153615
Fix freetype. Freetype is highly recommended for a nice output ;)
albeu
parents:
8197
diff
changeset
|
417 |
23227
a142b048c65e
support for unicode/utf8 in libmenu (geexbox patch #545)
ben
parents:
22284
diff
changeset
|
418 static void render_txt(char *txt) |
a142b048c65e
support for unicode/utf8 in libmenu (geexbox patch #545)
ben
parents:
22284
diff
changeset
|
419 { |
a142b048c65e
support for unicode/utf8 in libmenu (geexbox patch #545)
ben
parents:
22284
diff
changeset
|
420 while (*txt) { |
24940 | 421 int c = utf8_get_char((const char**)&txt); |
23227
a142b048c65e
support for unicode/utf8 in libmenu (geexbox patch #545)
ben
parents:
22284
diff
changeset
|
422 render_one_glyph(vo_font, c); |
a142b048c65e
support for unicode/utf8 in libmenu (geexbox patch #545)
ben
parents:
22284
diff
changeset
|
423 } |
a142b048c65e
support for unicode/utf8 in libmenu (geexbox patch #545)
ben
parents:
22284
diff
changeset
|
424 } |
8197 | 425 |
27393 | 426 #ifdef CONFIG_FRIBIDI |
23228
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
427 #include <fribidi/fribidi.h> |
23231 | 428 #include "libavutil/common.h" |
23238 | 429 char *menu_fribidi_charset = NULL; |
430 int menu_flip_hebrew = 0; | |
431 int menu_fribidi_flip_commas = 0; | |
23228
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
432 |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
433 static char *menu_fribidi(char *txt) |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
434 { |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
435 static int char_set_num = -1; |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
436 static FriBidiChar *logical, *visual; |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
437 static size_t buffer_size = 1024; |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
438 static char *outputstr; |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
439 |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
440 size_t len; |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
441 |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
442 if (menu_flip_hebrew) { |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
443 len = strlen(txt); |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
444 if (char_set_num == -1) { |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
445 fribidi_set_mirroring (1); |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
446 fribidi_set_reorder_nsm (0); |
23337
10a7279b8e56
get rid of -menu-utf8 and -menu-unicode once for all, patch by Guillaume Lecerf
ben
parents:
23238
diff
changeset
|
447 char_set_num = fribidi_parse_charset("UTF-8"); |
23231 | 448 buffer_size = FFMAX(1024,len+1); |
23230 | 449 logical = malloc(buffer_size); |
450 visual = malloc(buffer_size); | |
451 outputstr = malloc(buffer_size); | |
23228
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
452 } else if (len+1 > buffer_size) { |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
453 buffer_size = len+1; |
23230 | 454 logical = realloc(logical, buffer_size); |
455 visual = realloc(visual, buffer_size); | |
456 outputstr = realloc(outputstr, buffer_size); | |
23228
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
457 } |
33353
63dbf59fa312
Move some common fribidi code into a shared function.
reimar
parents:
33316
diff
changeset
|
458 len = do_fribid_log2vis(char_set_num, txt, logical, visual, menu_fribidi_flip_commas); |
63dbf59fa312
Move some common fribidi code into a shared function.
reimar
parents:
33316
diff
changeset
|
459 if (len > 0) { |
23228
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
460 fribidi_unicode_to_charset (char_set_num, visual, len, outputstr); |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
461 return outputstr; |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
462 } |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
463 } |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
464 return txt; |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
465 } |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
466 #endif |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
467 |
8197 | 468 void menu_draw_text(mp_image_t* mpi,char* txt, int x, int y) { |
469 draw_alpha_f draw_alpha = get_draw_alpha(mpi->imgfmt); | |
470 int font; | |
471 | |
472 if(!draw_alpha) { | |
17994
6927fabaef92
Part1 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu
reynaldo
parents:
17993
diff
changeset
|
473 mp_msg(MSGT_GLOBAL,MSGL_WARN,MSGTR_LIBMENU_UnsupportedOutformat); |
8197 | 474 return; |
475 } | |
476 | |
27393 | 477 #ifdef CONFIG_FRIBIDI |
23228
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
478 txt = menu_fribidi(txt); |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
479 #endif |
8224
fefc56153615
Fix freetype. Freetype is highly recommended for a nice output ;)
albeu
parents:
8197
diff
changeset
|
480 render_txt(txt); |
fefc56153615
Fix freetype. Freetype is highly recommended for a nice output ;)
albeu
parents:
8197
diff
changeset
|
481 |
8197 | 482 while (*txt) { |
24940 | 483 int c=utf8_get_char((const char**)&txt); |
8197 | 484 if ((font=vo_font->font[c])>=0 && (x + vo_font->width[c] <= mpi->w) && (y + vo_font->pic_a[font]->h <= mpi->h)) |
485 draw_alpha(vo_font->width[c], vo_font->pic_a[font]->h, | |
486 vo_font->pic_b[font]->bmp+vo_font->start[c], | |
487 vo_font->pic_a[font]->bmp+vo_font->start[c], | |
488 vo_font->pic_a[font]->w, | |
489 mpi->planes[0] + y * mpi->stride[0] + x * (mpi->bpp>>3), | |
490 mpi->stride[0]); | |
491 x+=vo_font->width[c]+vo_font->charspace; | |
492 } | |
493 | |
494 } | |
495 | |
496 void menu_draw_text_full(mp_image_t* mpi,char* txt, | |
497 int x, int y,int w, int h, | |
498 int vspace, int warp, int align, int anchor) { | |
499 int need_w,need_h; | |
500 int sy, ymin, ymax; | |
501 int sx, xmin, xmax, xmid, xrmin; | |
502 int ll = 0; | |
503 int font; | |
504 draw_alpha_f draw_alpha = get_draw_alpha(mpi->imgfmt); | |
505 | |
506 if(!draw_alpha) { | |
17994
6927fabaef92
Part1 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu
reynaldo
parents:
17993
diff
changeset
|
507 mp_msg(MSGT_GLOBAL,MSGL_WARN,MSGTR_LIBMENU_UnsupportedOutformat); |
8197 | 508 return; |
509 } | |
510 | |
27393 | 511 #ifdef CONFIG_FRIBIDI |
23228
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
512 txt = menu_fribidi(txt); |
2e95dcd49946
support for hebrew through fribidi in libmenu (geexbox patch #580)
ben
parents:
23227
diff
changeset
|
513 #endif |
8224
fefc56153615
Fix freetype. Freetype is highly recommended for a nice output ;)
albeu
parents:
8197
diff
changeset
|
514 render_txt(txt); |
fefc56153615
Fix freetype. Freetype is highly recommended for a nice output ;)
albeu
parents:
8197
diff
changeset
|
515 |
8197 | 516 if(x > mpi->w || y > mpi->h) |
517 return; | |
518 | |
519 if(anchor & MENU_TEXT_VCENTER) { | |
520 if(h <= 0) h = mpi->h; | |
521 ymin = y - h/2; | |
522 ymax = y + h/2; | |
523 } else if(anchor & MENU_TEXT_BOT) { | |
524 if(h <= 0) h = mpi->h - y; | |
525 ymin = y - h; | |
526 ymax = y; | |
527 } else { | |
528 if(h <= 0) h = mpi->h - y; | |
529 ymin = y; | |
530 ymax = y + h; | |
531 } | |
532 | |
533 if(anchor & MENU_TEXT_HCENTER) { | |
534 if(w <= 0) w = mpi->w; | |
535 xmin = x - w/2; | |
536 xmax = x + w/2; | |
537 } else if(anchor & MENU_TEXT_RIGHT) { | |
538 if(w <= 0) w = mpi->w -x; | |
539 xmin = x - w; | |
540 xmax = x; | |
541 } else { | |
542 if(w <= 0) w = mpi->w -x; | |
543 xmin = x; | |
544 xmax = x + w; | |
545 } | |
546 | |
547 // How many space do we need to draw this ? | |
548 menu_text_size(txt,w,vspace,warp,&need_w,&need_h); | |
549 | |
550 // Find the first line | |
551 if(align & MENU_TEXT_VCENTER) | |
552 sy = ymin + ((h - need_h)/2); | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28113
diff
changeset
|
553 else if(align & MENU_TEXT_BOT) |
8232 | 554 sy = ymax - need_h - 1; |
8197 | 555 else |
556 sy = y; | |
557 | |
558 #if 0 | |
559 // Find the first col | |
560 if(align & MENU_TEXT_HCENTER) | |
561 sx = xmin + ((w - need_w)/2); | |
562 else if(align & MENU_TEXT_RIGHT) | |
563 sx = xmax - need_w; | |
564 #endif | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28113
diff
changeset
|
565 |
8197 | 566 xmid = xmin + (xmax - xmin) / 2; |
567 xrmin = xmin; | |
568 // Clamp the bb to the mpi size | |
569 if(ymin < 0) ymin = 0; | |
570 if(xmin < 0) xmin = 0; | |
571 if(ymax > mpi->h) ymax = mpi->h; | |
572 if(xmax > mpi->w) xmax = mpi->w; | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28113
diff
changeset
|
573 |
8197 | 574 // Jump some the beginnig text if needed |
575 while(sy < ymin && *txt) { | |
24940 | 576 int c=utf8_get_char((const char**)&txt); |
8197 | 577 if(c == '\n' || (warp && ll + vo_font->width[c] > w)) { |
578 ll = 0; | |
579 sy += vo_font->height + vspace; | |
580 if(c == '\n') continue; | |
581 } | |
582 ll += vo_font->width[c]+vo_font->charspace; | |
583 } | |
584 if(*txt == '\0') // Nothing left to draw | |
585 return; | |
586 | |
587 while(sy < ymax && *txt) { | |
588 char* line_end = NULL; | |
589 int n; | |
590 | |
591 if(txt[0] == '\n') { // New line | |
592 sy += vo_font->height + vspace; | |
593 txt++; | |
594 continue; | |
595 } | |
596 | |
597 // Get the length and end of this line | |
598 for(n = 0, ll = 0 ; txt[n] != '\0' && txt[n] != '\n' ; n++) { | |
599 unsigned char c = txt[n]; | |
600 if(warp && ll + vo_font->width[c] > w) break; | |
601 ll += vo_font->width[c]+vo_font->charspace; | |
602 } | |
603 line_end = &txt[n]; | |
604 ll -= vo_font->charspace; | |
605 | |
606 | |
607 if(align & (MENU_TEXT_HCENTER|MENU_TEXT_RIGHT)) { | |
608 // Too long line | |
609 if(ll > xmax-xmin) { | |
610 if(align & MENU_TEXT_HCENTER) { | |
611 int mid = ll/2; | |
612 // Find the middle point | |
613 for(n--, ll = 0 ; n <= 0 ; n--) { | |
614 ll += vo_font->width[(int)txt[n]]+vo_font->charspace; | |
615 if(ll - vo_font->charspace > mid) break; | |
616 } | |
617 ll -= vo_font->charspace; | |
618 sx = xmid + mid - ll; | |
619 } else// MENU_TEXT_RIGHT) | |
620 sx = xmax + vo_font->charspace; | |
621 | |
622 // We are after the start point -> go back | |
623 if(sx > xmin) { | |
624 for(n-- ; n <= 0 ; n--) { | |
625 unsigned char c = txt[n]; | |
626 if(sx - vo_font->width[c] - vo_font->charspace < xmin) break; | |
627 sx -= vo_font->width[c]+vo_font->charspace; | |
628 } | |
629 } else { // We are before the start point -> go forward | |
630 for( ; sx < xmin && (&txt[n]) != line_end ; n++) { | |
631 unsigned char c = txt[n]; | |
632 sx += vo_font->width[c]+vo_font->charspace; | |
633 } | |
634 } | |
635 txt = &txt[n]; // Jump to the new start char | |
636 } else { | |
637 if(align & MENU_TEXT_HCENTER) | |
638 sx = xmid - ll/2; | |
639 else | |
8232 | 640 sx = xmax - 1 - ll; |
8197 | 641 } |
642 } else { | |
643 for(sx = xrmin ; sx < xmin && txt != line_end ; txt++) { | |
644 unsigned char c = txt[n]; | |
645 sx += vo_font->width[c]+vo_font->charspace; | |
646 } | |
647 } | |
648 | |
649 while(sx < xmax && txt != line_end) { | |
24940 | 650 int c=utf8_get_char((const char**)&txt); |
8197 | 651 font = vo_font->font[c]; |
8232 | 652 if(font >= 0) { |
653 int cs = (vo_font->pic_a[font]->h - vo_font->height) / 2; | |
25434 | 654 if ((sx + vo_font->width[c] <= xmax) && (sy + vo_font->height <= ymax) ) |
8232 | 655 draw_alpha(vo_font->width[c], vo_font->height, |
656 vo_font->pic_b[font]->bmp+vo_font->start[c] + | |
657 cs * vo_font->pic_a[font]->w, | |
658 vo_font->pic_a[font]->bmp+vo_font->start[c] + | |
659 cs * vo_font->pic_a[font]->w, | |
660 vo_font->pic_a[font]->w, | |
661 mpi->planes[0] + sy * mpi->stride[0] + sx * (mpi->bpp>>3), | |
662 mpi->stride[0]); | |
663 // else | |
664 //printf("Can't draw '%c'\n",c); | |
665 } | |
8197 | 666 sx+=vo_font->width[c]+vo_font->charspace; |
667 } | |
668 txt = line_end; | |
669 if(txt[0] == '\0') break; | |
670 sy += vo_font->height + vspace; | |
671 } | |
672 } | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28113
diff
changeset
|
673 |
8197 | 674 int menu_text_length(char* txt) { |
675 int l = 0; | |
8224
fefc56153615
Fix freetype. Freetype is highly recommended for a nice output ;)
albeu
parents:
8197
diff
changeset
|
676 render_txt(txt); |
8197 | 677 while (*txt) { |
24940 | 678 int c=utf8_get_char((const char**)&txt); |
8197 | 679 l += vo_font->width[c]+vo_font->charspace; |
680 } | |
681 return l - vo_font->charspace; | |
682 } | |
683 | |
684 void menu_text_size(char* txt,int max_width, int vspace, int warp, int* _w, int* _h) { | |
685 int l = 1, i = 0; | |
686 int w = 0; | |
8224
fefc56153615
Fix freetype. Freetype is highly recommended for a nice output ;)
albeu
parents:
8197
diff
changeset
|
687 |
fefc56153615
Fix freetype. Freetype is highly recommended for a nice output ;)
albeu
parents:
8197
diff
changeset
|
688 render_txt(txt); |
8197 | 689 while (*txt) { |
24940 | 690 int c=utf8_get_char((const char**)&txt); |
8197 | 691 if(c == '\n' || (warp && i + vo_font->width[c] >= max_width)) { |
25434 | 692 i -= vo_font->charspace; |
693 if (i > w) w = i; | |
8197 | 694 if(*txt) |
695 l++; | |
696 i = 0; | |
697 if(c == '\n') continue; | |
698 } | |
699 i += vo_font->width[c]+vo_font->charspace; | |
25434 | 700 } |
701 if (i > 0) { | |
702 i -= vo_font->charspace; | |
703 if (i > w) w = i; | |
8197 | 704 } |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28113
diff
changeset
|
705 |
8197 | 706 *_w = w; |
707 *_h = (l-1) * (vo_font->height + vspace) + vo_font->height; | |
708 } | |
709 | |
710 | |
711 int menu_text_num_lines(char* txt, int max_width) { | |
712 int l = 1, i = 0; | |
8224
fefc56153615
Fix freetype. Freetype is highly recommended for a nice output ;)
albeu
parents:
8197
diff
changeset
|
713 render_txt(txt); |
8197 | 714 while (*txt) { |
24940 | 715 int c=utf8_get_char((const char**)&txt); |
8197 | 716 if(c == '\n' || i + vo_font->width[c] > max_width) { |
717 l++; | |
718 i = 0; | |
719 if(c == '\n') continue; | |
720 } | |
721 i += vo_font->width[c]+vo_font->charspace; | |
722 } | |
723 return l; | |
724 } | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28113
diff
changeset
|
725 |
17993
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
726 |
18193 | 727 void menu_draw_box(mp_image_t* mpi,unsigned char grey,unsigned char alpha, int x, int y, int w, int h) { |
17993
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
728 draw_alpha_f draw_alpha = get_draw_alpha(mpi->imgfmt); |
18193 | 729 int g; |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28113
diff
changeset
|
730 |
17993
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
731 if(!draw_alpha) { |
18193 | 732 mp_msg(MSGT_GLOBAL,MSGL_WARN,MSGTR_LIBMENU_UnsupportedOutformat); |
17993
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
733 return; |
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
734 } |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28113
diff
changeset
|
735 |
17993
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
736 if(x > mpi->w || y > mpi->h) return; |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28113
diff
changeset
|
737 |
17993
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
738 if(x < 0) w += x, x = 0; |
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
739 if(x+w > mpi->w) w = mpi->w-x; |
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
740 if(y < 0) h += y, y = 0; |
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
741 if(y+h > mpi->h) h = mpi->h-y; |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28113
diff
changeset
|
742 |
18193 | 743 g = ((256-alpha)*grey)>>8; |
744 if(g < 1) g = 1; | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28113
diff
changeset
|
745 |
17993
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
746 { |
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
747 int stride = (w+7)&(~7); // round to 8 |
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
748 char pic[stride*h],pic_alpha[stride*h]; |
18193 | 749 memset(pic,g,stride*h); |
17993
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
750 memset(pic_alpha,alpha,stride*h); |
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
751 draw_alpha(w,h,pic,pic_alpha,stride, |
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
752 mpi->planes[0] + y * mpi->stride[0] + x * (mpi->bpp>>3), |
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
753 mpi->stride[0]); |
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
754 } |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28113
diff
changeset
|
755 |
17993
98eb966a4024
Add a function to draw flat boxes and use it to make the list
albeu
parents:
17945
diff
changeset
|
756 } |