Mercurial > libdvdnav.hg
annotate dvdnav.h @ 384:9991d074349a src
remove unused #define
author | rathann |
---|---|
date | Sun, 13 Jul 2008 13:17:35 +0000 |
parents | 5a28a534ecf9 |
children | 2f1fd852da24 |
rev | line source |
---|---|
0 | 1 /* |
2 * Copyright (C) 2001 Rich Wareham <richwareham@users.sourceforge.net> | |
3 * | |
4 * This file is part of libdvdnav, a DVD navigation library. | |
5 * | |
6 * libdvdnav 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 * libdvdnav 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 * $Id$ | |
21 * | |
22 */ | |
23 | |
147 | 24 /* |
25 * This is the main header file applications should include if they want | |
26 * to access dvdnav functionality. | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
27 */ |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
28 |
0 | 29 #ifndef DVDNAV_H_INCLUDED |
30 #define DVDNAV_H_INCLUDED | |
31 | |
5
c1b55dc1bfed
Add API call to get number of programmes in current title.
richwareham
parents:
4
diff
changeset
|
32 #ifdef __cplusplus |
c1b55dc1bfed
Add API call to get number of programmes in current title.
richwareham
parents:
4
diff
changeset
|
33 extern "C" { |
c1b55dc1bfed
Add API call to get number of programmes in current title.
richwareham
parents:
4
diff
changeset
|
34 #endif |
c1b55dc1bfed
Add API call to get number of programmes in current title.
richwareham
parents:
4
diff
changeset
|
35 |
285
52877d182e96
moved all header inclusions from .h to .c files; my word, I've never seen such a horrible entanglement as in this mess
nicodvb
parents:
272
diff
changeset
|
36 #ifndef DVDNAV_COMPILE |
139
f7a26cd00c93
* only install the headers that really are intended for public use
mroi
parents:
132
diff
changeset
|
37 # include <dvdnav/dvd_types.h> |
368
62dd6af82d7b
adapted the tree to the dvdread->libdvdread transition
nicodvb
parents:
315
diff
changeset
|
38 # include <libdvdread/dvd_reader.h> |
62dd6af82d7b
adapted the tree to the dvdread->libdvdread transition
nicodvb
parents:
315
diff
changeset
|
39 # include <libdvdread/nav_types.h> |
62dd6af82d7b
adapted the tree to the dvdread->libdvdread transition
nicodvb
parents:
315
diff
changeset
|
40 # include <libdvdread/ifo_types.h> /* For vm_cmd_t */ |
285
52877d182e96
moved all header inclusions from .h to .c files; my word, I've never seen such a horrible entanglement as in this mess
nicodvb
parents:
272
diff
changeset
|
41 # include <dvdnav/dvdnav_events.h> |
139
f7a26cd00c93
* only install the headers that really are intended for public use
mroi
parents:
132
diff
changeset
|
42 #endif |
0 | 43 |
44 | |
147 | 45 |
46 /********************************************************************* | |
47 * dvdnav data types * | |
48 *********************************************************************/ | |
49 | |
50 /* | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
51 * Opaque data-type can be viewed as a 'DVD handle'. You should get |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
52 * a pointer to a dvdnav_t from the dvdnav_open() function. |
147 | 53 * Never call free() on the pointer, you have to give it back with |
54 * dvdnav_close(). | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
55 */ |
0 | 56 typedef struct dvdnav_s dvdnav_t; |
57 | |
147 | 58 /* Status as reported by most of libdvdnav's functions */ |
195 | 59 typedef int32_t dvdnav_status_t; |
0 | 60 |
147 | 61 /* |
62 * Unless otherwise stated, all functions return DVDNAV_STATUS_OK if | |
63 * they succeeded, otherwise DVDNAV_STATUS_ERR is returned and the error may | |
64 * be obtained by calling dvdnav_err_to_string(). | |
65 */ | |
193 | 66 #define DVDNAV_STATUS_ERR 0 |
67 #define DVDNAV_STATUS_OK 1 | |
0 | 68 |
266 | 69 #define DVDNAV_FORMAT_AC3 0 |
70 #define DVDNAV_FORMAT_MPEGAUDIO 3 | |
71 #define DVDNAV_FORMAT_LPCM 4 | |
72 #define DVDNAV_FORMAT_DTS 5 | |
73 #define DVDNAV_FORMAT_SDDS 6 | |
147 | 74 |
75 /********************************************************************* | |
76 * initialisation & housekeeping functions * | |
77 *********************************************************************/ | |
78 | |
79 /* | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
80 * These functions allow you to open a DVD device and associate it |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
81 * with a dvdnav_t. |
0 | 82 */ |
83 | |
147 | 84 /* |
85 * Attempts to open the DVD drive at the specified path and pre-cache | |
86 * the CSS-keys. libdvdread is used to access the DVD, so any source | |
87 * supported by libdvdread can be given with "path". Currently, | |
88 * libdvdread can access: DVD drives, DVD image files, DVD file-by-file | |
89 * copies. | |
0 | 90 * |
147 | 91 * The resulting dvdnav_t handle will be written to *dest. |
0 | 92 */ |
147 | 93 dvdnav_status_t dvdnav_open(dvdnav_t **dest, const char *path); |
0 | 94 |
147 | 95 /* |
0 | 96 * Closes a dvdnav_t previously opened with dvdnav_open(), freeing any |
97 * memory associated with it. | |
98 */ | |
99 dvdnav_status_t dvdnav_close(dvdnav_t *self); | |
100 | |
147 | 101 /* |
102 * Resets the DVD virtual machine and cache buffers. | |
4
99bed5d6db2f
Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents:
0
diff
changeset
|
103 */ |
99bed5d6db2f
Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents:
0
diff
changeset
|
104 dvdnav_status_t dvdnav_reset(dvdnav_t *self); |
99bed5d6db2f
Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents:
0
diff
changeset
|
105 |
147 | 106 /* |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
107 * Fills a pointer with a value pointing to a string describing |
147 | 108 * the path associated with an open dvdnav_t. It assigns *path to NULL |
0 | 109 * on error. |
110 */ | |
147 | 111 dvdnav_status_t dvdnav_path(dvdnav_t *self, const char **path); |
0 | 112 |
147 | 113 /* |
0 | 114 * Returns a human-readable string describing the last error. |
115 */ | |
114 | 116 const char* dvdnav_err_to_string(dvdnav_t *self); |
0 | 117 |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
118 |
147 | 119 /********************************************************************* |
120 * changing and reading DVD player characteristics * | |
121 *********************************************************************/ | |
122 | |
123 /* | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
124 * These functions allow you to manipulate the various global characteristics |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
125 * of the DVD playback engine. |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
126 */ |
0 | 127 |
147 | 128 /* |
129 * Sets the region mask (bit 0 set implies region 1, bit 1 set implies | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
130 * region 2, etc) of the virtual machine. Generally you will only need to set |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
131 * this if you are playing RCE discs which query the virtual machine as to its |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
132 * region setting. |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
133 * |
147 | 134 * This has _nothing_ to do with the region setting of the DVD drive. |
0 | 135 */ |
195 | 136 dvdnav_status_t dvdnav_set_region_mask(dvdnav_t *self, int32_t region_mask); |
0 | 137 |
147 | 138 /* |
139 * Returns the region mask (bit 0 set implies region 1, bit 1 set implies | |
140 * region 2, etc) of the virtual machine. | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
141 * |
147 | 142 * This has _nothing_ to do with the region setting of the DVD drive. |
0 | 143 */ |
195 | 144 dvdnav_status_t dvdnav_get_region_mask(dvdnav_t *self, int32_t *region_mask); |
0 | 145 |
147 | 146 /* |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
147 * Specify whether read-ahead caching should be used. You may not want this if your |
114 | 148 * decoding engine does its own buffering. |
147 | 149 * |
150 * The default read-ahead cache does not use an additional thread for the reading | |
151 * (see read_cache.c for a threaded cache, but note that this code is currently | |
152 * unmaintained). It prebuffers on VOBU level by reading ahead several buffers | |
153 * on every read request. The speed of this prebuffering has been optimized to | |
154 * also work on slow DVD drives. | |
0 | 155 * |
147 | 156 * If in addition you want to prevent memcpy's to improve performance, have a look |
157 * at dvdnav_get_next_cache_block(). | |
0 | 158 */ |
195 | 159 dvdnav_status_t dvdnav_set_readahead_flag(dvdnav_t *self, int32_t read_ahead_flag); |
0 | 160 |
147 | 161 /* |
162 * Query whether read-ahead caching/buffering will be used. | |
163 */ | |
195 | 164 dvdnav_status_t dvdnav_get_readahead_flag(dvdnav_t *self, int32_t *read_ahead_flag); |
147 | 165 |
166 /* | |
132 | 167 * Specify whether the positioning works PGC or PG based. |
147 | 168 * Programs (PGs) on DVDs are similar to Chapters and a program chain (PGC) |
132 | 169 * usually covers a whole feature. This affects the behaviour of the |
147 | 170 * functions dvdnav_get_position() and dvdnav_sector_search(). See there. |
132 | 171 * Default is PG based positioning. |
172 */ | |
195 | 173 dvdnav_status_t dvdnav_set_PGC_positioning_flag(dvdnav_t *self, int32_t pgc_based_flag); |
132 | 174 |
147 | 175 /* |
132 | 176 * Query whether positioning is PG or PGC based. |
177 */ | |
195 | 178 dvdnav_status_t dvdnav_get_PGC_positioning_flag(dvdnav_t *self, int32_t *pgc_based_flag); |
147 | 179 |
132 | 180 |
147 | 181 /********************************************************************* |
182 * reading data * | |
183 *********************************************************************/ | |
184 | |
185 /* | |
186 * These functions are used to poll the playback enginge and actually get data | |
187 * off the DVD. | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
188 */ |
0 | 189 |
147 | 190 /* |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
191 * Attempts to get the next block off the DVD and copies it into the buffer 'buf'. |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
192 * If there is any special actions that may need to be performed, the value |
147 | 193 * pointed to by 'event' gets set accordingly. |
0 | 194 * |
195 * If 'event' is DVDNAV_BLOCK_OK then 'buf' is filled with the next block | |
196 * (note that means it has to be at /least/ 2048 bytes big). 'len' is | |
197 * then set to 2048. | |
198 * | |
199 * Otherwise, buf is filled with an appropriate event structure and | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
200 * len is set to the length of that structure. |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
201 * |
147 | 202 * See the dvdnav_events.h header for information on the various events. |
0 | 203 */ |
195 | 204 dvdnav_status_t dvdnav_get_next_block(dvdnav_t *self, uint8_t *buf, |
205 int32_t *event, int32_t *len); | |
0 | 206 |
147 | 207 /* |
60 | 208 * This basically does the same as dvdnav_get_next_block. The only difference is |
209 * that it avoids a memcopy, when the requested block was found in the cache. | |
210 * I such a case (cache hit) this function will return a different pointer than | |
211 * the one handed in, pointing directly into the relevant block in the cache. | |
147 | 212 * Those pointers must _never_ be freed but instead returned to the library via |
114 | 213 * dvdnav_free_cache_block(). |
60 | 214 */ |
195 | 215 dvdnav_status_t dvdnav_get_next_cache_block(dvdnav_t *self, uint8_t **buf, |
216 int32_t *event, int32_t *len); | |
60 | 217 |
147 | 218 /* |
114 | 219 * All buffers which came from the internal cache (when dvdnav_get_next_cache_block() |
60 | 220 * returned a buffer different from the one handed in) have to be freed with this |
221 * function. Although handing in other buffers not from the cache doesn't cause any harm. | |
222 */ | |
223 dvdnav_status_t dvdnav_free_cache_block(dvdnav_t *self, unsigned char *buf); | |
224 | |
147 | 225 /* |
226 * If we are currently in a still-frame this function skips it. | |
55
5674fbd44f26
report all spu types (widescreen, letterbox and pan&scan), not widescreen
mroi
parents:
44
diff
changeset
|
227 * |
147 | 228 * See also the DVDNAV_STILL_FRAME event. |
0 | 229 */ |
230 dvdnav_status_t dvdnav_still_skip(dvdnav_t *self); | |
231 | |
147 | 232 /* |
116 | 233 * If we are currently in WAIT state, that is: the application is required to |
234 * wait for its fifos to become empty, calling this signals libdvdnav that this | |
235 * is achieved and that it can continue. | |
236 * | |
147 | 237 * See also the DVDNAV_WAIT event. |
116 | 238 */ |
239 dvdnav_status_t dvdnav_wait_skip(dvdnav_t *self); | |
240 | |
147 | 241 /* |
242 * Returns the still time from the currently playing cell. | |
243 * The still time is given in seconds with 0xff meaning an indefinite still. | |
114 | 244 * |
147 | 245 * This function can be used to detect still frames before they are reached. |
246 * Some players might need this to prepare for a frame to be shown for a | |
247 * longer time than usual. | |
114 | 248 */ |
249 uint32_t dvdnav_get_next_still_flag(dvdnav_t *self); | |
250 | |
147 | 251 /* |
252 * Stops playback. The next event obtained with one of the get_next_block | |
253 * functions will be a DVDNAV_STOP event. | |
0 | 254 * |
147 | 255 * It is not required to call this before dvdnav_close(). |
256 */ | |
257 dvdnav_status_t dvdnav_stop(dvdnav_t *self); | |
258 | |
259 | |
260 /********************************************************************* | |
261 * title/part navigation * | |
262 *********************************************************************/ | |
263 | |
264 /* | |
265 * Returns the number of titles on the disk. | |
266 */ | |
195 | 267 dvdnav_status_t dvdnav_get_number_of_titles(dvdnav_t *self, int32_t *titles); |
147 | 268 |
269 /* | |
270 * Returns the number of parts within the given title. | |
271 */ | |
195 | 272 dvdnav_status_t dvdnav_get_number_of_parts(dvdnav_t *self, int32_t title, int32_t *parts); |
147 | 273 |
274 /* | |
275 * Plays the specified title of the DVD from its beginning (that is: part 1). | |
0 | 276 */ |
195 | 277 dvdnav_status_t dvdnav_title_play(dvdnav_t *self, int32_t title); |
0 | 278 |
147 | 279 /* |
280 * Plays the specified title, starting from the specified part. | |
0 | 281 */ |
195 | 282 dvdnav_status_t dvdnav_part_play(dvdnav_t *self, int32_t title, int32_t part); |
0 | 283 |
147 | 284 /* |
313 | 285 * Stores in *times an array (that the application *must* free) of |
286 * dvdtimes corresponding to the chapter times for the chosen title. | |
315
9abc06e356ff
now dvdnav_describe_title_chapters() also returns the duration of the title
nicodvb
parents:
313
diff
changeset
|
287 * *duration will have the duration of the title |
313 | 288 * The number of entries in *times is the result of the function. |
289 * On error *times is NULL and the output is 0 | |
290 */ | |
382
5a28a534ecf9
change the prototype of dvdnav_describe_title_chapters() to use 'self' instead of 'this' for compatibility with c++ compilers
nicodvb
parents:
368
diff
changeset
|
291 uint32_t dvdnav_describe_title_chapters(dvdnav_t *self, int32_t title, uint64_t **times, uint64_t *duration); |
313 | 292 |
293 /* | |
0 | 294 * Play the specified amount of parts of the specified title of |
295 * the DVD then STOP. | |
296 * | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
297 * Currently unimplemented! |
0 | 298 */ |
195 | 299 dvdnav_status_t dvdnav_part_play_auto_stop(dvdnav_t *self, int32_t title, |
300 int32_t part, int32_t parts_to_play); | |
0 | 301 |
147 | 302 /* |
303 * Play the specified title starting from the specified time. | |
0 | 304 * |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
305 * Currently unimplemented! |
0 | 306 */ |
195 | 307 dvdnav_status_t dvdnav_time_play(dvdnav_t *self, int32_t title, |
308 uint64_t time); | |
0 | 309 |
147 | 310 /* |
123 | 311 * Stop playing the current position and jump to the specified menu. |
114 | 312 * |
147 | 313 * See also DVDMenuID_t from libdvdread |
114 | 314 */ |
315 dvdnav_status_t dvdnav_menu_call(dvdnav_t *self, DVDMenuID_t menu); | |
316 | |
147 | 317 /* |
164 | 318 * Return the title number and part currently being played. |
319 * A title of 0 indicates, we are in a menu. In this case, part | |
320 * is set to the current menu's ID. | |
114 | 321 */ |
195 | 322 dvdnav_status_t dvdnav_current_title_info(dvdnav_t *self, int32_t *title, |
323 int32_t *part); | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
324 |
147 | 325 /* |
326 * Return the current position (in blocks) within the current | |
327 * title and the length (in blocks) of said title. | |
328 * | |
329 * Current implementation is wrong and likely to behave unpredictably! | |
330 * Use is discouraged! | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
331 */ |
147 | 332 dvdnav_status_t dvdnav_get_position_in_title(dvdnav_t *self, |
195 | 333 uint32_t *pos, |
334 uint32_t *len); | |
0 | 335 |
147 | 336 /* |
337 * This function is only available for compatibility reasons. | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
338 * |
147 | 339 * Stop playing the current position and start playback of the current title |
340 * from the specified part. | |
0 | 341 */ |
195 | 342 dvdnav_status_t dvdnav_part_search(dvdnav_t *self, int32_t part); |
147 | 343 |
0 | 344 |
147 | 345 /********************************************************************* |
346 * program chain/program navigation * | |
347 *********************************************************************/ | |
348 | |
349 /* | |
123 | 350 * Stop playing the current position and start playback from the last |
351 * VOBU boundary before the given sector. The sector number is not | |
352 * meant to be an absolute physical DVD sector, but a relative sector | |
353 * in the current program. This function cannot leave the current | |
354 * program and will fail, if asked to do so. | |
0 | 355 * |
147 | 356 * If program chain based positioning is enabled |
357 * (see dvdnav_set_PGC_positioning_flag()), this will seek to the relative | |
358 * sector inside the current program chain. | |
359 * | |
360 * 'origin' can be one of SEEK_SET, SEEK_CUR, SEEK_END as defined in | |
361 * fcntl.h. | |
0 | 362 */ |
363 dvdnav_status_t dvdnav_sector_search(dvdnav_t *self, | |
195 | 364 uint64_t offset, int32_t origin); |
0 | 365 |
147 | 366 /* |
269
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
268
diff
changeset
|
367 returns the current stream time in PTS ticks as reported by the IFO structures |
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
268
diff
changeset
|
368 divide it by 90000 to get the current play time in seconds |
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
268
diff
changeset
|
369 */ |
308
494842974e55
- fix compilation of C++ code using dvdnav.h (this is a reserved C++ keyword)
rathann
parents:
307
diff
changeset
|
370 int64_t dvdnav_get_current_time(dvdnav_t *self); |
269
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
268
diff
changeset
|
371 |
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
268
diff
changeset
|
372 /* |
147 | 373 * Stop playing the current position and start playback of the title |
374 * from the specified timecode. | |
0 | 375 * |
147 | 376 * Currently unimplemented! |
0 | 377 */ |
147 | 378 dvdnav_status_t dvdnav_time_search(dvdnav_t *self, |
195 | 379 uint64_t time); |
0 | 380 |
147 | 381 /* |
382 * Stop playing current position and play the "GoUp"-program chain. | |
383 * (which generally leads to the title menu or a higer-level menu). | |
384 */ | |
385 dvdnav_status_t dvdnav_go_up(dvdnav_t *self); | |
386 | |
387 /* | |
123 | 388 * Stop playing the current position and start playback at the |
389 * previous program (if it exists). | |
0 | 390 */ |
391 dvdnav_status_t dvdnav_prev_pg_search(dvdnav_t *self); | |
392 | |
147 | 393 /* |
123 | 394 * Stop playing the current position and start playback at the |
395 * first program. | |
0 | 396 */ |
397 dvdnav_status_t dvdnav_top_pg_search(dvdnav_t *self); | |
398 | |
147 | 399 /* |
123 | 400 * Stop playing the current position and start playback at the |
401 * next program (if it exists). | |
0 | 402 */ |
403 dvdnav_status_t dvdnav_next_pg_search(dvdnav_t *self); | |
404 | |
147 | 405 /* |
0 | 406 * Return the current position (in blocks) within the current |
123 | 407 * program and the length (in blocks) of current program. |
147 | 408 * |
409 * If program chain based positioning is enabled | |
410 * (see dvdnav_set_PGC_positioning_flag()), this will return the | |
411 * relative position in and the length of the current program chain. | |
0 | 412 */ |
195 | 413 dvdnav_status_t dvdnav_get_position(dvdnav_t *self, uint32_t *pos, |
414 uint32_t *len); | |
8
66708b4a1b5e
Stop C++ bitching about some things and extend the menus example
richwareham
parents:
5
diff
changeset
|
415 |
0 | 416 |
147 | 417 /********************************************************************* |
418 * menu highlights * | |
419 *********************************************************************/ | |
0 | 420 |
147 | 421 /* |
114 | 422 * Most functions related to highlights take a NAV PCI packet as a parameter. |
423 * While you can get the such a packet from libdvdnav, for players with internal | |
424 * FIFOs, this will result in errors, because due to the FIFO length, libdvdnav will | |
425 * be ahead in the stream compared to what the user is seeing on screen. | |
426 * Therefore, player applications who have a NAV packet available, which is | |
427 * better in sync with the actual playback should always pass this one to these | |
428 * functions. | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
429 */ |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
430 |
147 | 431 /* |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
432 * Get the currently highlighted button |
147 | 433 * number (1..36) or 0 if no button is highlighted. |
0 | 434 */ |
195 | 435 dvdnav_status_t dvdnav_get_current_highlight(dvdnav_t *self, int32_t *button); |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
436 |
147 | 437 /* |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
438 * Returns the Presentation Control Information (PCI) structure associated |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
439 * with the current position. |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
440 * |
147 | 441 * Read the general notes above. |
442 * See also libdvdreads nav_types.h for definition of pci_t. | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
443 */ |
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
444 pci_t* dvdnav_get_current_nav_pci(dvdnav_t *self); |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
445 |
147 | 446 /* |
447 * Returns the DSI (data search information) structure associated | |
66
2bd4a78eefce
Patch from aschultz@cs.uni-magdeburg.de to allow for still-frame 'peek-ahead'
richwareham
parents:
60
diff
changeset
|
448 * with the current position. |
2bd4a78eefce
Patch from aschultz@cs.uni-magdeburg.de to allow for still-frame 'peek-ahead'
richwareham
parents:
60
diff
changeset
|
449 * |
147 | 450 * Read the general notes above. |
451 * See also libdvdreads nav_types.h for definition of dsi_t. | |
66
2bd4a78eefce
Patch from aschultz@cs.uni-magdeburg.de to allow for still-frame 'peek-ahead'
richwareham
parents:
60
diff
changeset
|
452 */ |
2bd4a78eefce
Patch from aschultz@cs.uni-magdeburg.de to allow for still-frame 'peek-ahead'
richwareham
parents:
60
diff
changeset
|
453 dsi_t* dvdnav_get_current_nav_dsi(dvdnav_t *self); |
2bd4a78eefce
Patch from aschultz@cs.uni-magdeburg.de to allow for still-frame 'peek-ahead'
richwareham
parents:
60
diff
changeset
|
454 |
147 | 455 /* |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
456 * Get the area associated with a certain button. |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
457 */ |
147 | 458 dvdnav_status_t dvdnav_get_highlight_area(pci_t *nav_pci , int32_t button, int32_t mode, |
459 dvdnav_highlight_area_t *highlight); | |
0 | 460 |
147 | 461 /* |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
462 * Move button highlight around as suggested by function name (e.g. with arrow keys). |
0 | 463 */ |
98 | 464 dvdnav_status_t dvdnav_upper_button_select(dvdnav_t *self, pci_t *pci); |
465 dvdnav_status_t dvdnav_lower_button_select(dvdnav_t *self, pci_t *pci); | |
466 dvdnav_status_t dvdnav_right_button_select(dvdnav_t *self, pci_t *pci); | |
467 dvdnav_status_t dvdnav_left_button_select(dvdnav_t *self, pci_t *pci); | |
0 | 468 |
147 | 469 /* |
470 * Activate ("press") the currently highlighted button. | |
0 | 471 */ |
98 | 472 dvdnav_status_t dvdnav_button_activate(dvdnav_t *self, pci_t *pci); |
0 | 473 |
147 | 474 /* |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
475 * Highlight a specific button. |
0 | 476 */ |
195 | 477 dvdnav_status_t dvdnav_button_select(dvdnav_t *self, pci_t *pci, int32_t button); |
0 | 478 |
147 | 479 /* |
480 * Activate ("press") specified button. | |
0 | 481 */ |
195 | 482 dvdnav_status_t dvdnav_button_select_and_activate(dvdnav_t *self, pci_t *pci, int32_t button); |
0 | 483 |
147 | 484 /* |
91
df9712507b30
Add a new API function, to allow for more flexible menu button control.
jcdutton
parents:
90
diff
changeset
|
485 * Activate (press) a button and execute specified command. |
df9712507b30
Add a new API function, to allow for more flexible menu button control.
jcdutton
parents:
90
diff
changeset
|
486 */ |
df9712507b30
Add a new API function, to allow for more flexible menu button control.
jcdutton
parents:
90
diff
changeset
|
487 dvdnav_status_t dvdnav_button_activate_cmd(dvdnav_t *self, int32_t button, vm_cmd_t *cmd); |
df9712507b30
Add a new API function, to allow for more flexible menu button control.
jcdutton
parents:
90
diff
changeset
|
488 |
147 | 489 /* |
490 * Select button at specified video frame coordinates. | |
0 | 491 */ |
195 | 492 dvdnav_status_t dvdnav_mouse_select(dvdnav_t *self, pci_t *pci, int32_t x, int32_t y); |
0 | 493 |
147 | 494 /* |
495 * Activate ("press") button at specified video frame coordinates. | |
0 | 496 */ |
195 | 497 dvdnav_status_t dvdnav_mouse_activate(dvdnav_t *self, pci_t *pci, int32_t x, int32_t y); |
0 | 498 |
147 | 499 |
500 /********************************************************************* | |
501 * languages * | |
502 *********************************************************************/ | |
503 | |
504 /* | |
505 * The language codes expected by these functions are two character | |
506 * codes as defined in ISO639. | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
507 */ |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
508 |
147 | 509 /* |
207 | 510 * Set which menu language we should use per default. |
0 | 511 */ |
44 | 512 dvdnav_status_t dvdnav_menu_language_select(dvdnav_t *self, |
513 char *code); | |
514 | |
147 | 515 /* |
207 | 516 * Set which audio language we should use per default. |
44 | 517 */ |
518 dvdnav_status_t dvdnav_audio_language_select(dvdnav_t *self, | |
519 char *code); | |
520 | |
147 | 521 /* |
207 | 522 * Set which spu language we should use per default. |
44 | 523 */ |
524 dvdnav_status_t dvdnav_spu_language_select(dvdnav_t *self, | |
0 | 525 char *code); |
526 | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
527 |
147 | 528 /********************************************************************* |
529 * obtaining stream attributes * | |
530 *********************************************************************/ | |
0 | 531 |
147 | 532 /* |
533 * Return a string describing the title of the DVD. | |
534 * This is an ID string encoded on the disc by the author. In many cases | |
535 * this is a descriptive string such as `THE_MATRIX' but sometimes is sigularly | |
536 * uninformative such as `PDVD-011421'. Some DVD authors even forget to set this, | |
537 * so you may also read the default of the authoring software they used, like | |
538 * `DVDVolume'. | |
0 | 539 */ |
147 | 540 dvdnav_status_t dvdnav_get_title_string(dvdnav_t *self, const char **title_str); |
0 | 541 |
147 | 542 /* |
543 * Get video aspect code. | |
544 * The aspect code does only change on VTS boundaries. | |
545 * See the DVDNAV_VTS_CHANGE event. | |
546 * | |
547 * 0 -- 4:3, 2 -- 16:9 | |
0 | 548 */ |
147 | 549 uint8_t dvdnav_get_video_aspect(dvdnav_t *self); |
0 | 550 |
147 | 551 /* |
552 * Get video scaling permissions. | |
553 * The scaling permission does only change on VTS boundaries. | |
554 * See the DVDNAV_VTS_CHANGE event. | |
0 | 555 * |
147 | 556 * bit0 set = deny letterboxing, bit1 set = deny pan&scan |
0 | 557 */ |
147 | 558 uint8_t dvdnav_get_video_scale_permission(dvdnav_t *self); |
0 | 559 |
147 | 560 /* |
561 * Converts a *logical* audio stream id into language code | |
562 * (returns 0xffff if no such stream). | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
563 */ |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
564 uint16_t dvdnav_audio_stream_to_lang(dvdnav_t *self, uint8_t stream); |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
565 |
147 | 566 /* |
266 | 567 * Returns the format of *logical* audio stream 'stream' |
568 * (returns 0xffff if no such stream). | |
569 */ | |
271
814e79060099
renamed dvdnav_audio_stream_to_format() as dvdnav_audio_stream_format() as implemeted in dvdnav.c; patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
269
diff
changeset
|
570 uint16_t dvdnav_audio_stream_format(dvdnav_t *self, uint8_t stream); |
266 | 571 |
572 /* | |
272
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
271
diff
changeset
|
573 * Returns number of channelsn in *logical* audio stream 'stream' |
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
271
diff
changeset
|
574 * (returns 0xffff if no such stream). |
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
271
diff
changeset
|
575 */ |
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
271
diff
changeset
|
576 uint16_t dvdnav_audio_stream_channels(dvdnav_t *self, uint8_t stream); |
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
271
diff
changeset
|
577 |
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
271
diff
changeset
|
578 /* |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
579 * Converts a *logical* subpicture stream id into country code |
147 | 580 * (returns 0xffff if no such stream). |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
581 */ |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
582 uint16_t dvdnav_spu_stream_to_lang(dvdnav_t *self, uint8_t stream); |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
583 |
147 | 584 /* |
585 * Converts a *physical* (MPEG) audio stream id into a logical stream number. | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
586 */ |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
587 int8_t dvdnav_get_audio_logical_stream(dvdnav_t *self, uint8_t audio_num); |
0 | 588 |
300
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
295
diff
changeset
|
589 #define HAVE_GET_AUDIO_ATTR |
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
295
diff
changeset
|
590 /* |
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
295
diff
changeset
|
591 * Get audio attr |
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
295
diff
changeset
|
592 */ |
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
295
diff
changeset
|
593 dvdnav_status_t dvdnav_get_audio_attr(dvdnav_t *self, uint8_t audio_mum, audio_attr_t *audio_attr); |
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
295
diff
changeset
|
594 |
147 | 595 /* |
596 * Converts a *physical* (MPEG) subpicture stream id into a logical stream number. | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
597 */ |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
598 int8_t dvdnav_get_spu_logical_stream(dvdnav_t *self, uint8_t subp_num); |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
599 |
300
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
295
diff
changeset
|
600 #define HAVE_GET_SPU_ATTR |
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
295
diff
changeset
|
601 /* |
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
295
diff
changeset
|
602 * Get spu attr |
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
295
diff
changeset
|
603 */ |
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
295
diff
changeset
|
604 dvdnav_status_t dvdnav_get_spu_attr(dvdnav_t *self, uint8_t audio_mum, subp_attr_t *subp_attr); |
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
295
diff
changeset
|
605 |
147 | 606 /* |
114 | 607 * Get active audio stream. |
608 */ | |
609 int8_t dvdnav_get_active_audio_stream(dvdnav_t *self); | |
610 | |
147 | 611 /* |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
612 * Get active spu stream. |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
613 */ |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
614 int8_t dvdnav_get_active_spu_stream(dvdnav_t *self); |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
615 |
262 | 616 /* |
617 * Get the set of user operations that are currently prohibited. | |
618 * There are potentially new restrictions right after | |
619 * DVDNAV_CHANNEL_HOP and DVDNAV_NAV_PACKET. | |
620 */ | |
621 user_ops_t dvdnav_get_restrictions(dvdnav_t *self); | |
147 | 622 |
264 | 623 |
147 | 624 /********************************************************************* |
625 * multiple angles * | |
626 *********************************************************************/ | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
627 |
147 | 628 /* |
629 * The libdvdnav library abstracts away the difference between seamless and | |
630 * non-seamless angles. From the point of view of the programmer you just set the | |
631 * angle number and all is well in the world. You will always see only the | |
632 * selected angle coming from the get_next_block functions. | |
0 | 633 * |
147 | 634 * Note: |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
635 * It is quite possible that some tremendously strange DVD feature might change the |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
636 * angle number from under you. Generally you should always view the results from |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
637 * dvdnav_get_angle_info() as definitive only up to the next time you call |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
638 * dvdnav_get_next_block(). |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
639 */ |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
640 |
147 | 641 /* |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
642 * Sets the current angle. If you try to follow a non existant angle |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
643 * the call fails. |
0 | 644 */ |
195 | 645 dvdnav_status_t dvdnav_angle_change(dvdnav_t *self, int32_t angle); |
0 | 646 |
147 | 647 /* |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
648 * Returns the current angle and number of angles present. |
0 | 649 */ |
195 | 650 dvdnav_status_t dvdnav_get_angle_info(dvdnav_t *self, int32_t *current_angle, |
651 int32_t *number_of_angles); | |
66
2bd4a78eefce
Patch from aschultz@cs.uni-magdeburg.de to allow for still-frame 'peek-ahead'
richwareham
parents:
60
diff
changeset
|
652 |
147 | 653 /********************************************************************* |
654 * domain queries * | |
655 *********************************************************************/ | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
656 |
147 | 657 /* |
658 * Are we in the First Play domain? | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
659 */ |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
660 int8_t dvdnav_is_domain_fp(dvdnav_t *self); |
114 | 661 |
147 | 662 /* |
663 * Are we in the Video management Menu domain? | |
0 | 664 */ |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
665 int8_t dvdnav_is_domain_vmgm(dvdnav_t *self); |
114 | 666 |
147 | 667 /* |
668 * Are we in the Video Title Menu domain? | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
669 */ |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
670 int8_t dvdnav_is_domain_vtsm(dvdnav_t *self); |
114 | 671 |
147 | 672 /* |
673 * Are we in the Video Title Set domain? | |
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
674 */ |
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
22
diff
changeset
|
675 int8_t dvdnav_is_domain_vts(dvdnav_t *self); |
0 | 676 |
677 | |
5
c1b55dc1bfed
Add API call to get number of programmes in current title.
richwareham
parents:
4
diff
changeset
|
678 #ifdef __cplusplus |
c1b55dc1bfed
Add API call to get number of programmes in current title.
richwareham
parents:
4
diff
changeset
|
679 } |
c1b55dc1bfed
Add API call to get number of programmes in current title.
richwareham
parents:
4
diff
changeset
|
680 #endif |
c1b55dc1bfed
Add API call to get number of programmes in current title.
richwareham
parents:
4
diff
changeset
|
681 |
0 | 682 #endif /* DVDNAV_H_INCLUDED */ |