vlc: pass ncvisual to callback

dankamongmen/libvlc
nick black 3 years ago
parent 4208956af0
commit bd97eb8819
No known key found for this signature in database
GPG Key ID: 5F43400C21CBFACC

@ -23,9 +23,16 @@ auto ncvisual_subtitle(const ncvisual* ncv) -> char* {
return nullptr;
}
static void
media_callback(const struct libvlc_event_t* p_event, void* p_data) {
ncvisual* nc = static_cast<ncvisual*>(p_data);
fprintf(stderr, "CALLBACK! %p\n", nc);
libvlc_media_player_stop(nc->details.player);
}
int ncvisual_decode(ncvisual* nc){
(void)nc; // FIXME
return -1;
libvlc_media_player_play(nc->details.player); // FIXME retcode
return 0;
}
// resize frame to oframe, converting to RGBA (if necessary) along the way
@ -36,11 +43,6 @@ int ncvisual_resize(ncvisual* nc, int rows, int cols) {
return -1;
}
static void
media_callback(const struct libvlc_event_t* p_event, void* p_data) {
fprintf(stderr, "CALLBACK!\n");
}
ncvisual* ncvisual_from_file(const char* filename) {
ncvisual* ret = ncvisual_create();
if(ret == nullptr){
@ -57,7 +59,7 @@ ncvisual* ncvisual_from_file(const char* filename) {
return nullptr;
}
if(libvlc_event_attach(ret->details.manager, libvlc_MediaPlayerOpening,
media_callback, nullptr)){
media_callback, ret)){
ncvisual_destroy(ret);
return nullptr;
}
@ -66,7 +68,10 @@ ncvisual* ncvisual_from_file(const char* filename) {
ncvisual_destroy(ret);
return nullptr;
}
libvlc_media_player_play(ret->details.player);
if(ncvisual_decode(ret)){
ncvisual_destroy(ret);
return nullptr;
}
return ret;
}

Loading…
Cancel
Save