OBS 插件推流以及日志模块

obs 推流

了解rtmp地址

Rtmp地址是直播数据上传地址,唯一指向单个的直播活动。它由rtmp://开头。
例如湖南卫视,rtmp://58.200.131.2:1935/livetv/hunantv

obs软件的使用

  1. 参数设置
    OBS 插件推流以及日志模块_第1张图片
    如上图,设置的话。服务器:rtmp://58.200.131.2:1935/livetv 串流密钥:hunantv

  2. Ui 按钮分析以及函数查找
    OBS 插件推流以及日志模块_第2张图片
    上图的开始推流按钮,就是源码当中如下图的ui
    OBS 插件推流以及日志模块_第3张图片
    OBSBasic::on_streamButton_clicked()函数
    OBS 插件推流以及日志模块_第4张图片

  3. 推流核心函数 StartStreaming();其中设计的是对流相关的创建
    OBS 插件推流以及日志模块_第5张图片

  4. 相关流信息之后,是开始推流
    OBS 插件推流以及日志模块_第6张图片

  5. SimpleOutput::StartStreaming(obs_service_t *service) 设置合适的参数
    OBS 插件推流以及日志模块_第7张图片

OBS日志

  1. 在主界面点击—帮助 – 日志文件—显示日志文件
    弹出文件夹 例如:C:\Users\健健\AppData\Roaming\obs-studio\logs
    OBS 插件推流以及日志模块_第8张图片

  2. 其命名规则按照时间来命名的
    OBS 插件推流以及日志模块_第9张图片
    相关函数

    参数一:格式。例如”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);
    }
    
    
    
  3. 源码分析
    在源码中,经常见到

    blog(LOG_INFO, "Audio monitoring device:\n\tname: %s\n\tid: %s",
    	     device_name, device_id);
    
  • 使用blog的函数类似的代码。
    深入研究下,发现其本质上是log_handler函数的调用
    OBS 插件推流以及日志模块_第10张图片
  • 那么obs内部是怎么使用的呢。它提供了接口 base_set_log_handler函数,提供给我们使用。
    OBS 插件推流以及日志模块_第11张图片
  • 日志模块的使用主要在 obs-app.cpp和obs-app.hpp中体现的
    涉及函数 create_log_file
    OBS 插件推流以及日志模块_第12张图片
  • 根据上图找到前面讲到的 base_set_log_handler函数,查看下其传入的参数do_log函数;
    OBS 插件推流以及日志模块_第13张图片
  • do_log函数 核心在于写文件,就是LogStringChunk 函数
    OBS 插件推流以及日志模块_第14张图片

OBS的多开处理

OBS 插件推流以及日志模块_第15张图片

  1. 对于程序的多开,一般处理方式就是找到程序的名字或者pid。但是obs的处理比较有意思,主要用的是以下这两个函数: OpenMutexW和CreateMutexW函数

  2. 头文件:Windows.h ;库文件:Kernel32.lib

  3. 函数介绍

    OpenMutex函数为现有的一个已命名互斥体对象创建一个新句柄。
    返回值:如执行成功,返回对象的句柄;零表示失败
    
    CreateMutex()函数可用来创建一个有名或无名的互斥量对象。
    如执行成功,就返回互斥体对象的句柄;零表示出错
    
    

    OBS 插件推流以及日志模块_第16张图片
    可以这么去理解,第一次没找到改名字的互斥量,创建。第二次开始一旦找到,更改标志位,在外层去加入判断逻辑

你可能感兴趣的:(obs录屏,obs推流,obs日志,obs多开)