obs 推流
了解rtmp地址
Rtmp地址是直播数据上传地址,唯一指向单个的直播活动。它由rtmp://开头。
例如湖南卫视,rtmp://58.200.131.2:1935/livetv/hunantv
obs软件的使用
-
参数设置
如上图,设置的话。服务器:rtmp://58.200.131.2:1935/livetv 串流密钥:hunantv -
Ui 按钮分析以及函数查找
上图的开始推流按钮,就是源码当中如下图的ui
OBSBasic::on_streamButton_clicked()函数
-
推流核心函数 StartStreaming();其中设计的是对流相关的创建
-
相关流信息之后,是开始推流
-
SimpleOutput::StartStreaming(obs_service_t *service) 设置合适的参数
OBS日志
-
在主界面点击—帮助 – 日志文件—显示日志文件
弹出文件夹 例如:C:\Users\健健\AppData\Roaming\obs-studio\logs
-
其命名规则按照时间来命名的
相关函数参数一:格式。例如”txt”; 参数二:默认false string GenerateTimeDateFilename(const char *extension, bool noSpace) { time_t now = time(0); char file[256] = {}; struct tm *cur_time; cur_time = localtime(&now); snprintf(file, sizeof(file), "%d-%02d-%02d%c%02d-%02d-%02d.%s", cur_time->tm_year + 1900, cur_time->tm_mon + 1, cur_time->tm_mday, noSpace ? '_' : ' ', cur_time->tm_hour, cur_time->tm_min, cur_time->tm_sec, extension); return string(file); }
-
源码分析
在源码中,经常见到blog(LOG_INFO, "Audio monitoring device:\n\tname: %s\n\tid: %s", device_name, device_id);
- 使用blog的函数类似的代码。
深入研究下,发现其本质上是log_handler函数的调用
- 那么obs内部是怎么使用的呢。它提供了接口 base_set_log_handler函数,提供给我们使用。
- 日志模块的使用主要在 obs-app.cpp和obs-app.hpp中体现的
涉及函数 create_log_file
- 根据上图找到前面讲到的 base_set_log_handler函数,查看下其传入的参数do_log函数;
- do_log函数 核心在于写文件,就是LogStringChunk 函数
OBS的多开处理
-
对于程序的多开,一般处理方式就是找到程序的名字或者pid。但是obs的处理比较有意思,主要用的是以下这两个函数: OpenMutexW和CreateMutexW函数
-
头文件:Windows.h ;库文件:Kernel32.lib
-
函数介绍
OpenMutex函数为现有的一个已命名互斥体对象创建一个新句柄。 返回值:如执行成功,返回对象的句柄;零表示失败 CreateMutex()函数可用来创建一个有名或无名的互斥量对象。 如执行成功,就返回互斥体对象的句柄;零表示出错
可以这么去理解,第一次没找到改名字的互斥量,创建。第二次开始一旦找到,更改标志位,在外层去加入判断逻辑