mirror of
https://github.com/ZLMediaKit/ZLMediaKit.git
synced 2024-11-24 19:50:38 +08:00
112 lines
4.5 KiB
C++
112 lines
4.5 KiB
C++
/*
|
|
* Copyright (c) 2016-present The ZLMediaKit project authors. All Rights Reserved.
|
|
*
|
|
* This file is part of ZLMediaKit(https://github.com/ZLMediaKit/ZLMediaKit).
|
|
*
|
|
* Use of this source code is governed by MIT-like license that can be found in the
|
|
* LICENSE file in the root of the source tree. All contributing project authors
|
|
* may be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
#include "mk_proxyplayer.h"
|
|
#include "Player/PlayerProxy.h"
|
|
#include "mk_util.h"
|
|
|
|
using namespace toolkit;
|
|
using namespace mediakit;
|
|
|
|
API_EXPORT mk_proxy_player API_CALL mk_proxy_player_create(const char *vhost, const char *app, const char *stream, int hls_enabled, int mp4_enabled) {
|
|
return mk_proxy_player_create3(vhost, app, stream, hls_enabled, mp4_enabled,-1);
|
|
}
|
|
|
|
API_EXPORT mk_proxy_player API_CALL mk_proxy_player_create2(const char *vhost, const char *app, const char *stream, mk_ini ini) {
|
|
return mk_proxy_player_create4(vhost, app, stream, ini, -1);
|
|
}
|
|
|
|
API_EXPORT mk_proxy_player API_CALL mk_proxy_player_create3(const char *vhost, const char *app, const char *stream, int hls_enabled, int mp4_enabled, int retry_count) {
|
|
assert(vhost && app && stream);
|
|
ProtocolOption option;
|
|
option.enable_hls = hls_enabled;
|
|
option.enable_mp4 = mp4_enabled;
|
|
MediaTuple tuple = {vhost, app, stream, ""};
|
|
PlayerProxy::Ptr *obj(new PlayerProxy::Ptr(new PlayerProxy(tuple, option, retry_count)));
|
|
return (mk_proxy_player)obj;
|
|
}
|
|
|
|
|
|
API_EXPORT mk_proxy_player API_CALL mk_proxy_player_create4(const char *vhost, const char *app, const char *stream, mk_ini ini, int retry_count) {
|
|
assert(vhost && app && stream);
|
|
ProtocolOption option(*((mINI *)ini));
|
|
MediaTuple tuple = {vhost, app, stream, ""};
|
|
PlayerProxy::Ptr *obj(new PlayerProxy::Ptr(new PlayerProxy(tuple, option, retry_count)));
|
|
return (mk_proxy_player)obj;
|
|
}
|
|
|
|
API_EXPORT void API_CALL mk_proxy_player_release(mk_proxy_player ctx) {
|
|
assert(ctx);
|
|
PlayerProxy::Ptr *obj = (PlayerProxy::Ptr *) ctx;
|
|
delete obj;
|
|
}
|
|
|
|
API_EXPORT void API_CALL mk_proxy_player_set_option(mk_proxy_player ctx, const char *key, const char *val){
|
|
assert(ctx && key && val);
|
|
PlayerProxy::Ptr &obj = *((PlayerProxy::Ptr *) ctx);
|
|
std::string key_str(key), val_str(val);
|
|
obj->getPoller()->async([obj,key_str,val_str](){
|
|
// 切换线程再操作 [AUTO-TRANSLATED:b78259f9]
|
|
// Switch threads and then operate
|
|
(*obj)[key_str] = val_str;
|
|
});
|
|
}
|
|
|
|
API_EXPORT void API_CALL mk_proxy_player_play(mk_proxy_player ctx, const char *url) {
|
|
assert(ctx && url);
|
|
PlayerProxy::Ptr &obj = *((PlayerProxy::Ptr *) ctx);
|
|
std::string url_str(url);
|
|
obj->getPoller()->async([obj,url_str](){
|
|
// 切换线程再操作 [AUTO-TRANSLATED:b78259f9]
|
|
// Switch threads and then operate
|
|
obj->play(url_str);
|
|
});
|
|
}
|
|
|
|
API_EXPORT void API_CALL mk_proxy_player_set_on_close(mk_proxy_player ctx, on_mk_proxy_player_close cb, void *user_data){
|
|
mk_proxy_player_set_on_close2(ctx, cb, user_data, nullptr);
|
|
}
|
|
|
|
API_EXPORT void API_CALL mk_proxy_player_set_on_close2(mk_proxy_player ctx, on_mk_proxy_player_close cb, void *user_data, on_user_data_free user_data_free) {
|
|
assert(ctx);
|
|
PlayerProxy::Ptr &obj = *((PlayerProxy::Ptr *)ctx);
|
|
std::shared_ptr<void> ptr(user_data, user_data_free ? user_data_free : [](void *) {});
|
|
obj->getPoller()->async([obj, cb, ptr]() {
|
|
// 切换线程再操作 [AUTO-TRANSLATED:bae49fee]
|
|
// Switch threads and then operate
|
|
obj->setOnClose([cb, ptr](const SockException &ex) {
|
|
if (cb) {
|
|
cb(ptr.get(), ex.getErrCode(), ex.what(), ex.getCustomCode());
|
|
}
|
|
});
|
|
});
|
|
}
|
|
|
|
API_EXPORT void API_CALL mk_proxy_player_set_on_play_result(mk_proxy_player ctx, on_mk_proxy_player_close cb, void *user_data, on_user_data_free user_data_free) {
|
|
assert(ctx);
|
|
PlayerProxy::Ptr &obj = *((PlayerProxy::Ptr *)ctx);
|
|
std::shared_ptr<void> ptr(user_data, user_data_free ? user_data_free : [](void *) {});
|
|
obj->getPoller()->async([obj, cb, ptr]() {
|
|
// 切换线程再操作 [AUTO-TRANSLATED:bae49fee]
|
|
// Switch threads and then operate
|
|
obj->setPlayCallbackOnce([cb, ptr](const SockException &ex) {
|
|
if (cb) {
|
|
cb(ptr.get(), ex.getErrCode(), ex.what(), ex.getCustomCode());
|
|
}
|
|
});
|
|
});
|
|
}
|
|
|
|
API_EXPORT int API_CALL mk_proxy_player_total_reader_count(mk_proxy_player ctx){
|
|
assert(ctx);
|
|
PlayerProxy::Ptr &obj = *((PlayerProxy::Ptr *) ctx);
|
|
return obj->totalReaderCount();
|
|
}
|