2013-09-30 19:37:13 -07:00
|
|
|
/******************************************************************************
|
|
|
|
Copyright (C) 2013 by Hugh Bailey <obs.jim@gmail.com>
|
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
2013-12-02 22:24:38 -07:00
|
|
|
the Free Software Foundation, either version 2 of the License, or
|
2013-09-30 19:37:13 -07:00
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
******************************************************************************/
|
|
|
|
|
2013-10-14 13:21:15 +02:00
|
|
|
#pragma once
|
2013-09-30 19:37:13 -07:00
|
|
|
|
|
|
|
#include "util/c99defs.h"
|
2013-12-30 10:14:28 -07:00
|
|
|
#include "util/bmem.h"
|
2013-09-30 19:37:13 -07:00
|
|
|
#include "graphics/graphics.h"
|
|
|
|
#include "graphics/vec2.h"
|
Simplify media i/o interfaces
Completely revamped the entire media i/o data and handlers. The
original idea was to have a system that would have connecting media
inputs and outputs, but at a certain point I realized that this was an
unnecessary complexity for what we wanted to do. (Also, it reminded me
of directshow filters, and I HATE directshow with a passion, and
wouldn't wish it upon my greatest enemy)
Now, audio/video outputs are connected to directly, with better callback
handlers, and will eventually have the ability to automatically handle
conversions such as 4:4:4 to 4:2:0 when connecting to an input that uses
them. Doing this will allow the video/audio i/o handlers to also
prevent duplicate conversion, as well as make it easier/simple to use.
My true goal for this is to make output and encoder plugins as simple to
create as possible. I want to be able to be able to create an output
plugin with almost no real hassle of having to worry about image
conversions, media inputs/outputs, etc. A plugin developer shouldn't
have to handle that sort of stuff when he/she doesn't really need to.
Plugins will be able to simply create a callback via obs_video() and/or
obs_audio(), and they will automatically receive the audio/video data in
the formats requested via a simple callback, without needing to do
almost anything else at all.
2014-01-14 01:58:47 -07:00
|
|
|
#include "media-io/audio-io.h"
|
|
|
|
#include "media-io/video-io.h"
|
2013-12-26 23:10:15 -07:00
|
|
|
#include "callback/signal.h"
|
|
|
|
#include "callback/proc.h"
|
2013-09-30 19:37:13 -07:00
|
|
|
|
|
|
|
#include "obs-defs.h"
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Main libobs header used by applications.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2013-11-13 06:24:20 -07:00
|
|
|
/* LIBOBS_API_VER must be returned by module_version in each module */
|
|
|
|
|
|
|
|
#define LIBOBS_API_MAJOR_VER 0 /* increment if major breaking changes */
|
|
|
|
#define LIBOBS_API_MINOR_VER 1 /* increment if minor non-breaking additions */
|
|
|
|
#define LIBOBS_API_VER ((LIBOBS_API_MAJOR_VER << 16) | \
|
|
|
|
LIBOBS_API_MINOR_VER)
|
|
|
|
|
2013-10-14 12:37:52 -07:00
|
|
|
enum obs_source_type {
|
2013-09-30 19:37:13 -07:00
|
|
|
SOURCE_INPUT,
|
|
|
|
SOURCE_FILTER,
|
|
|
|
SOURCE_TRANSITION,
|
|
|
|
SOURCE_SCENE
|
|
|
|
};
|
|
|
|
|
Add preliminary output/encoder interface
- First, I redid the output interface for libobs. I feel like it's
going in a pretty good direction in terms of design.
Right now, the design is so that outputs and encoders are separate.
One or more outputs can connect to a specific encoder to receive its
data, or the output can connect directly to raw data from libobs
output itself, if the output doesn't want to use a designated encoder.
Data is received via callbacks set when you connect to the encoder or
raw output. Multiple outputs can receive the data from a single
encoder context if need be (such as for streaming to multiple channels
at once, and/or recording with the same data).
When an encoder is first connected to, it will connect to raw output,
and start encoding. Additional connections will receive that same
data being encoded as well after that. When the last encoder has
disconnected, it will stop encoding. If for some reason the encoder
needs to stop, it will use the callback with NULL to signal that
encoding has stopped. Some of these things may be subject to change
in the future, though it feels pretty good with this design so far.
Will have to see how well it works out in practice versus theory.
- Second, Started adding preliminary RTMP/x264 output plugin code.
To speed things up, I might just make a direct raw->FFmpeg output to
create a quick output plugin that we can start using for testing all
the subsystems.
2014-01-16 22:34:51 -07:00
|
|
|
enum obs_encoder_type {
|
|
|
|
ENCODER_VIDEO,
|
|
|
|
ENCODER_AUDIO
|
|
|
|
};
|
|
|
|
|
2013-11-20 15:00:16 -07:00
|
|
|
enum obs_video_type {
|
|
|
|
OBS_VIDEO_YUV,
|
|
|
|
OBS_VIDEO_RGB
|
|
|
|
};
|
|
|
|
|
2013-10-24 00:57:55 -07:00
|
|
|
/* used for changing the order of items (for example, filters in a source,
|
2013-10-24 01:03:45 -07:00
|
|
|
* or items in a scene) */
|
2013-09-30 19:37:13 -07:00
|
|
|
enum order_movement {
|
|
|
|
ORDER_MOVE_UP,
|
|
|
|
ORDER_MOVE_DOWN,
|
|
|
|
ORDER_MOVE_TOP,
|
|
|
|
ORDER_MOVE_BOTTOM
|
|
|
|
};
|
|
|
|
|
2013-12-22 02:03:40 -07:00
|
|
|
enum allow_direct_render {
|
|
|
|
NO_DIRECT_RENDERING,
|
|
|
|
ALLOW_DIRECT_RENDERING,
|
|
|
|
};
|
|
|
|
|
2013-11-20 15:00:16 -07:00
|
|
|
struct obs_video_info {
|
2013-11-26 22:20:11 -07:00
|
|
|
/* graphics module to use (usually "libobs-opengl" or "libobs-d3d11") */
|
2013-11-20 15:00:16 -07:00
|
|
|
const char *graphics_module;
|
2013-11-26 22:20:11 -07:00
|
|
|
|
|
|
|
/* output fps numerator and denominator */
|
2013-11-20 15:00:16 -07:00
|
|
|
uint32_t fps_num;
|
|
|
|
uint32_t fps_den;
|
2013-11-26 22:20:11 -07:00
|
|
|
|
|
|
|
/* window dimensions for what's drawn on screen */
|
|
|
|
uint32_t window_width;
|
|
|
|
uint32_t window_height;
|
|
|
|
|
|
|
|
/* base compositing dimensions */
|
2013-11-20 15:00:16 -07:00
|
|
|
uint32_t base_width;
|
|
|
|
uint32_t base_height;
|
2013-11-26 22:20:11 -07:00
|
|
|
|
|
|
|
/* output dimensions and format */
|
2013-11-20 15:00:16 -07:00
|
|
|
uint32_t output_width;
|
|
|
|
uint32_t output_height;
|
|
|
|
enum video_format output_format;
|
2013-11-26 22:20:11 -07:00
|
|
|
|
|
|
|
/* video adapter ID to use (NOTE: do not use for optimus laptops) */
|
2013-11-20 15:00:16 -07:00
|
|
|
uint32_t adapter;
|
2013-11-26 22:20:11 -07:00
|
|
|
|
|
|
|
/* window to render */
|
2013-11-20 15:00:16 -07:00
|
|
|
struct gs_window window;
|
|
|
|
};
|
|
|
|
|
2013-10-31 10:28:47 -07:00
|
|
|
struct filtered_audio {
|
|
|
|
void *data;
|
|
|
|
uint32_t frames;
|
|
|
|
uint64_t timestamp;
|
|
|
|
};
|
|
|
|
|
2013-10-24 00:57:55 -07:00
|
|
|
struct source_audio {
|
2013-10-30 17:07:01 -07:00
|
|
|
const void *data;
|
|
|
|
uint32_t frames;
|
2013-10-24 00:57:55 -07:00
|
|
|
|
|
|
|
/* audio will be automatically resampled/upmixed/downmixed */
|
2013-10-30 17:07:01 -07:00
|
|
|
enum speaker_layout speakers;
|
2013-10-31 10:28:47 -07:00
|
|
|
enum audio_format format;
|
2013-10-30 17:07:01 -07:00
|
|
|
uint32_t samples_per_sec;
|
2013-10-24 00:57:55 -07:00
|
|
|
|
|
|
|
/* can be 0 if 'immediate' */
|
2013-10-30 17:07:01 -07:00
|
|
|
uint64_t timestamp;
|
2013-10-24 00:57:55 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
struct source_frame {
|
2013-10-30 17:07:01 -07:00
|
|
|
void *data;
|
|
|
|
uint32_t width;
|
|
|
|
uint32_t height;
|
|
|
|
uint32_t row_bytes;
|
|
|
|
uint64_t timestamp;
|
|
|
|
|
2013-10-31 10:28:47 -07:00
|
|
|
enum video_format format;
|
2013-10-30 17:07:01 -07:00
|
|
|
float yuv_matrix[16];
|
|
|
|
bool flip;
|
2013-10-24 00:57:55 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
static inline void source_frame_destroy(struct source_frame *frame)
|
|
|
|
{
|
|
|
|
if (frame) {
|
|
|
|
bfree(frame->data);
|
|
|
|
bfree(frame);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
Add preliminary output/encoder interface
- First, I redid the output interface for libobs. I feel like it's
going in a pretty good direction in terms of design.
Right now, the design is so that outputs and encoders are separate.
One or more outputs can connect to a specific encoder to receive its
data, or the output can connect directly to raw data from libobs
output itself, if the output doesn't want to use a designated encoder.
Data is received via callbacks set when you connect to the encoder or
raw output. Multiple outputs can receive the data from a single
encoder context if need be (such as for streaming to multiple channels
at once, and/or recording with the same data).
When an encoder is first connected to, it will connect to raw output,
and start encoding. Additional connections will receive that same
data being encoded as well after that. When the last encoder has
disconnected, it will stop encoding. If for some reason the encoder
needs to stop, it will use the callback with NULL to signal that
encoding has stopped. Some of these things may be subject to change
in the future, though it feels pretty good with this design so far.
Will have to see how well it works out in practice versus theory.
- Second, Started adding preliminary RTMP/x264 output plugin code.
To speed things up, I might just make a direct raw->FFmpeg output to
create a quick output plugin that we can start using for testing all
the subsystems.
2014-01-16 22:34:51 -07:00
|
|
|
enum packet_priority {
|
|
|
|
PACKET_PRIORITY_DISPOSABLE,
|
|
|
|
PACKET_PRIORITY_LOW,
|
|
|
|
PACKET_PRIORITY_PFRAME,
|
|
|
|
PACKET_PRIORITY_IFRAME,
|
|
|
|
PACKET_PRIORITY_OTHER /* audio usually */
|
|
|
|
};
|
|
|
|
|
|
|
|
struct encoder_packet {
|
|
|
|
int64_t dts;
|
|
|
|
int64_t pts;
|
|
|
|
void *data;
|
|
|
|
size_t size;
|
|
|
|
enum packet_priority priority;
|
|
|
|
};
|
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/* opaque types */
|
|
|
|
struct obs_display;
|
|
|
|
struct obs_source;
|
|
|
|
struct obs_scene;
|
|
|
|
struct obs_scene_item;
|
|
|
|
struct obs_output;
|
Add preliminary output/encoder interface
- First, I redid the output interface for libobs. I feel like it's
going in a pretty good direction in terms of design.
Right now, the design is so that outputs and encoders are separate.
One or more outputs can connect to a specific encoder to receive its
data, or the output can connect directly to raw data from libobs
output itself, if the output doesn't want to use a designated encoder.
Data is received via callbacks set when you connect to the encoder or
raw output. Multiple outputs can receive the data from a single
encoder context if need be (such as for streaming to multiple channels
at once, and/or recording with the same data).
When an encoder is first connected to, it will connect to raw output,
and start encoding. Additional connections will receive that same
data being encoded as well after that. When the last encoder has
disconnected, it will stop encoding. If for some reason the encoder
needs to stop, it will use the callback with NULL to signal that
encoding has stopped. Some of these things may be subject to change
in the future, though it feels pretty good with this design so far.
Will have to see how well it works out in practice versus theory.
- Second, Started adding preliminary RTMP/x264 output plugin code.
To speed things up, I might just make a direct raw->FFmpeg output to
create a quick output plugin that we can start using for testing all
the subsystems.
2014-01-16 22:34:51 -07:00
|
|
|
struct obs_encoder;
|
2013-11-20 15:00:16 -07:00
|
|
|
struct obs_service;
|
2013-09-30 19:37:13 -07:00
|
|
|
|
2013-10-14 12:37:52 -07:00
|
|
|
typedef struct obs_display *obs_display_t;
|
|
|
|
typedef struct obs_source *obs_source_t;
|
|
|
|
typedef struct obs_scene *obs_scene_t;
|
|
|
|
typedef struct obs_scene_item *obs_sceneitem_t;
|
|
|
|
typedef struct obs_output *obs_output_t;
|
Add preliminary output/encoder interface
- First, I redid the output interface for libobs. I feel like it's
going in a pretty good direction in terms of design.
Right now, the design is so that outputs and encoders are separate.
One or more outputs can connect to a specific encoder to receive its
data, or the output can connect directly to raw data from libobs
output itself, if the output doesn't want to use a designated encoder.
Data is received via callbacks set when you connect to the encoder or
raw output. Multiple outputs can receive the data from a single
encoder context if need be (such as for streaming to multiple channels
at once, and/or recording with the same data).
When an encoder is first connected to, it will connect to raw output,
and start encoding. Additional connections will receive that same
data being encoded as well after that. When the last encoder has
disconnected, it will stop encoding. If for some reason the encoder
needs to stop, it will use the callback with NULL to signal that
encoding has stopped. Some of these things may be subject to change
in the future, though it feels pretty good with this design so far.
Will have to see how well it works out in practice versus theory.
- Second, Started adding preliminary RTMP/x264 output plugin code.
To speed things up, I might just make a direct raw->FFmpeg output to
create a quick output plugin that we can start using for testing all
the subsystems.
2014-01-16 22:34:51 -07:00
|
|
|
typedef struct obs_encoder *obs_encoder_t;
|
2013-11-20 15:00:16 -07:00
|
|
|
typedef struct obs_service *obs_service_t;
|
2013-09-30 19:37:13 -07:00
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------- */
|
|
|
|
/* OBS context */
|
|
|
|
|
|
|
|
/**
|
2013-10-24 00:57:55 -07:00
|
|
|
* Starts up and shuts down OBS
|
2013-09-30 19:37:13 -07:00
|
|
|
*
|
2013-11-20 15:00:16 -07:00
|
|
|
* Creates the OBS context.
|
2013-09-30 19:37:13 -07:00
|
|
|
*/
|
2013-11-20 15:00:16 -07:00
|
|
|
EXPORT bool obs_startup(void);
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT void obs_shutdown(void);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets base video ouput base resolution/fps/format
|
|
|
|
*
|
2013-11-20 15:00:16 -07:00
|
|
|
* NOTE: Cannot set base video if currently streaming/recording.
|
2013-09-30 19:37:13 -07:00
|
|
|
*/
|
2013-11-20 15:00:16 -07:00
|
|
|
EXPORT bool obs_reset_video(struct obs_video_info *ovi);
|
2013-10-14 12:37:52 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/**
|
|
|
|
* Sets base audio output format/channels/samples/etc
|
|
|
|
*
|
|
|
|
* NOTE: Cannot reset base audio if currently streaming/recording.
|
|
|
|
*/
|
Simplify media i/o interfaces
Completely revamped the entire media i/o data and handlers. The
original idea was to have a system that would have connecting media
inputs and outputs, but at a certain point I realized that this was an
unnecessary complexity for what we wanted to do. (Also, it reminded me
of directshow filters, and I HATE directshow with a passion, and
wouldn't wish it upon my greatest enemy)
Now, audio/video outputs are connected to directly, with better callback
handlers, and will eventually have the ability to automatically handle
conversions such as 4:4:4 to 4:2:0 when connecting to an input that uses
them. Doing this will allow the video/audio i/o handlers to also
prevent duplicate conversion, as well as make it easier/simple to use.
My true goal for this is to make output and encoder plugins as simple to
create as possible. I want to be able to be able to create an output
plugin with almost no real hassle of having to worry about image
conversions, media inputs/outputs, etc. A plugin developer shouldn't
have to handle that sort of stuff when he/she doesn't really need to.
Plugins will be able to simply create a callback via obs_video() and/or
obs_audio(), and they will automatically receive the audio/video data in
the formats requested via a simple callback, without needing to do
almost anything else at all.
2014-01-14 01:58:47 -07:00
|
|
|
EXPORT bool obs_reset_audio(struct audio_output_info *ai);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
2013-12-06 06:38:19 -07:00
|
|
|
/** Gets the current video settings, returns false if none */
|
|
|
|
EXPORT bool obs_get_video_info(struct obs_video_info *ovi);
|
|
|
|
|
|
|
|
/** Gets the current audio settings, returns false if none */
|
Simplify media i/o interfaces
Completely revamped the entire media i/o data and handlers. The
original idea was to have a system that would have connecting media
inputs and outputs, but at a certain point I realized that this was an
unnecessary complexity for what we wanted to do. (Also, it reminded me
of directshow filters, and I HATE directshow with a passion, and
wouldn't wish it upon my greatest enemy)
Now, audio/video outputs are connected to directly, with better callback
handlers, and will eventually have the ability to automatically handle
conversions such as 4:4:4 to 4:2:0 when connecting to an input that uses
them. Doing this will allow the video/audio i/o handlers to also
prevent duplicate conversion, as well as make it easier/simple to use.
My true goal for this is to make output and encoder plugins as simple to
create as possible. I want to be able to be able to create an output
plugin with almost no real hassle of having to worry about image
conversions, media inputs/outputs, etc. A plugin developer shouldn't
have to handle that sort of stuff when he/she doesn't really need to.
Plugins will be able to simply create a callback via obs_video() and/or
obs_audio(), and they will automatically receive the audio/video data in
the formats requested via a simple callback, without needing to do
almost anything else at all.
2014-01-14 01:58:47 -07:00
|
|
|
EXPORT bool obs_get_audio_info(struct audio_output_info *ai);
|
2013-12-06 06:38:19 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/**
|
|
|
|
* Loads a plugin module
|
|
|
|
*
|
|
|
|
* A plugin module contains exports for inputs/fitlers/transitions/outputs.
|
|
|
|
* See obs-source.h and obs-output.h for more information on the exports to
|
|
|
|
* use.
|
|
|
|
*/
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT int obs_load_module(const char *path);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
|
|
|
/**
|
2013-11-22 16:18:31 -07:00
|
|
|
* Enumerates all available inputs source types.
|
2013-09-30 19:37:13 -07:00
|
|
|
*
|
|
|
|
* Inputs are general source inputs (such as capture sources, device sources,
|
|
|
|
* etc).
|
|
|
|
*/
|
2013-12-20 17:23:19 -07:00
|
|
|
EXPORT bool obs_enum_input_types(size_t idx, const char **id);
|
2013-10-14 12:37:52 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/**
|
2013-11-22 16:18:31 -07:00
|
|
|
* Enumerates all available filter source types.
|
2013-09-30 19:37:13 -07:00
|
|
|
*
|
|
|
|
* Filters are sources that are used to modify the video/audio output of
|
|
|
|
* other sources.
|
|
|
|
*/
|
2013-12-20 17:23:19 -07:00
|
|
|
EXPORT bool obs_enum_filter_types(size_t idx, const char **id);
|
2013-10-14 12:37:52 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/**
|
2013-11-22 16:18:31 -07:00
|
|
|
* Enumerates all available transition source types.
|
2013-09-30 19:37:13 -07:00
|
|
|
*
|
|
|
|
* Transitions are sources used to transition between two or more other
|
|
|
|
* sources.
|
|
|
|
*/
|
2013-12-20 17:23:19 -07:00
|
|
|
EXPORT bool obs_enum_transition_types(size_t idx, const char **id);
|
2013-10-14 12:37:52 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/**
|
2013-11-22 16:18:31 -07:00
|
|
|
* Enumerates all available ouput types.
|
2013-09-30 19:37:13 -07:00
|
|
|
*
|
|
|
|
* Outputs handle color space conversion, encoding, and output to file or
|
|
|
|
* streams.
|
|
|
|
*/
|
2013-12-20 17:23:19 -07:00
|
|
|
EXPORT bool obs_enum_output_types(size_t idx, const char **id);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
|
|
|
/** Gets the graphics context for this OBS context */
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT graphics_t obs_graphics(void);
|
|
|
|
|
Simplify media i/o interfaces
Completely revamped the entire media i/o data and handlers. The
original idea was to have a system that would have connecting media
inputs and outputs, but at a certain point I realized that this was an
unnecessary complexity for what we wanted to do. (Also, it reminded me
of directshow filters, and I HATE directshow with a passion, and
wouldn't wish it upon my greatest enemy)
Now, audio/video outputs are connected to directly, with better callback
handlers, and will eventually have the ability to automatically handle
conversions such as 4:4:4 to 4:2:0 when connecting to an input that uses
them. Doing this will allow the video/audio i/o handlers to also
prevent duplicate conversion, as well as make it easier/simple to use.
My true goal for this is to make output and encoder plugins as simple to
create as possible. I want to be able to be able to create an output
plugin with almost no real hassle of having to worry about image
conversions, media inputs/outputs, etc. A plugin developer shouldn't
have to handle that sort of stuff when he/she doesn't really need to.
Plugins will be able to simply create a callback via obs_video() and/or
obs_audio(), and they will automatically receive the audio/video data in
the formats requested via a simple callback, without needing to do
almost anything else at all.
2014-01-14 01:58:47 -07:00
|
|
|
EXPORT audio_t obs_audio(void);
|
|
|
|
EXPORT video_t obs_video(void);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
|
|
|
/**
|
2013-11-22 16:18:31 -07:00
|
|
|
* Adds a source to the user source list and increments the reference counter
|
|
|
|
* for that source.
|
2013-09-30 19:37:13 -07:00
|
|
|
*
|
2013-11-20 15:00:16 -07:00
|
|
|
* The user source list is the list of sources that are accessible by a user.
|
|
|
|
* Typically when a transition is active, it is not meant to be accessible by
|
|
|
|
* users, so there's no reason for a user to see such a source.
|
2013-09-30 19:37:13 -07:00
|
|
|
*/
|
2013-11-20 15:00:16 -07:00
|
|
|
EXPORT bool obs_add_source(obs_source_t source);
|
|
|
|
|
2013-11-22 16:18:31 -07:00
|
|
|
/** Sets the primary output source for a channel. */
|
2013-11-20 15:00:16 -07:00
|
|
|
EXPORT void obs_set_output_source(uint32_t channel, obs_source_t source);
|
2013-11-22 16:18:31 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the primary output source for a channel and increments the reference
|
|
|
|
* counter for that source. Use obs_source_release to release.
|
|
|
|
*/
|
2013-11-20 15:00:16 -07:00
|
|
|
EXPORT obs_source_t obs_get_output_source(uint32_t channel);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
2013-12-20 19:35:12 -07:00
|
|
|
/**
|
|
|
|
* Enumerates user sources
|
|
|
|
*
|
|
|
|
* Callback function returns true to continue enumeration, or false to end
|
|
|
|
* enumeration.
|
|
|
|
*/
|
Add preliminary output/encoder interface
- First, I redid the output interface for libobs. I feel like it's
going in a pretty good direction in terms of design.
Right now, the design is so that outputs and encoders are separate.
One or more outputs can connect to a specific encoder to receive its
data, or the output can connect directly to raw data from libobs
output itself, if the output doesn't want to use a designated encoder.
Data is received via callbacks set when you connect to the encoder or
raw output. Multiple outputs can receive the data from a single
encoder context if need be (such as for streaming to multiple channels
at once, and/or recording with the same data).
When an encoder is first connected to, it will connect to raw output,
and start encoding. Additional connections will receive that same
data being encoded as well after that. When the last encoder has
disconnected, it will stop encoding. If for some reason the encoder
needs to stop, it will use the callback with NULL to signal that
encoding has stopped. Some of these things may be subject to change
in the future, though it feels pretty good with this design so far.
Will have to see how well it works out in practice versus theory.
- Second, Started adding preliminary RTMP/x264 output plugin code.
To speed things up, I might just make a direct raw->FFmpeg output to
create a quick output plugin that we can start using for testing all
the subsystems.
2014-01-16 22:34:51 -07:00
|
|
|
EXPORT void obs_enum_sources(bool (*enum_proc)(void*, obs_source_t),
|
|
|
|
void *param);
|
|
|
|
|
|
|
|
/** Enumerates outputs */
|
|
|
|
EXPORT void obs_enum_outputs(bool (*enum_proc)(void*, obs_output_t),
|
|
|
|
void *param);
|
|
|
|
|
|
|
|
/** Enumerates encoders */
|
|
|
|
EXPORT void obs_enum_encoders(bool (*enum_proc)(void*, obs_encoder_t),
|
2013-12-20 19:35:12 -07:00
|
|
|
void *param);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets a source by its name.
|
|
|
|
*
|
|
|
|
* Increments the source reference counter, use obs_source_release to
|
|
|
|
* release it when complete.
|
|
|
|
*/
|
|
|
|
EXPORT obs_source_t obs_get_source_by_name(const char *name);
|
2013-11-22 16:18:31 -07:00
|
|
|
|
2013-11-01 14:33:00 -07:00
|
|
|
/**
|
|
|
|
* Returns the location of a plugin data file.
|
|
|
|
*
|
|
|
|
* file: Name of file to locate. For example, "myplugin/mydata.data"
|
2013-11-20 15:00:16 -07:00
|
|
|
* returns: Path string, or NULL if not found. Use bfree to free string.
|
2013-11-01 14:33:00 -07:00
|
|
|
*/
|
|
|
|
EXPORT char *obs_find_plugin_file(const char *file);
|
|
|
|
|
2013-12-22 01:30:18 -07:00
|
|
|
/** Returns the default effect for generic RGB/YUV drawing */
|
2013-12-24 17:06:19 +01:00
|
|
|
EXPORT effect_t obs_get_default_effect(void);
|
2013-12-22 01:30:18 -07:00
|
|
|
|
2013-12-26 23:10:15 -07:00
|
|
|
/** Returns the primary obs signal handler */
|
|
|
|
EXPORT signal_handler_t obs_signalhandler(void);
|
|
|
|
|
|
|
|
/** Returns the primary obs procedure handler */
|
|
|
|
EXPORT proc_handler_t obs_prochandler(void);
|
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------- */
|
|
|
|
/* Display context */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates an extra display context.
|
|
|
|
*
|
|
|
|
* An extra display can be used for things like separate previews,
|
|
|
|
* viewing sources independently, and other things. Creates a new swap chain
|
|
|
|
* linked to a specific window to display a source.
|
|
|
|
*/
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT obs_display_t obs_display_create(struct gs_init_data *graphics_data);
|
|
|
|
EXPORT void obs_display_destroy(obs_display_t display);
|
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/** Sets the source to be used for a display context. */
|
2013-11-20 15:00:16 -07:00
|
|
|
EXPORT void obs_display_setsource(obs_display_t display, uint32_t channel,
|
|
|
|
obs_source_t source);
|
|
|
|
EXPORT obs_source_t obs_display_getsource(obs_display_t display,
|
|
|
|
uint32_t channel);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------- */
|
|
|
|
/* Sources */
|
|
|
|
|
2013-11-13 06:24:20 -07:00
|
|
|
/**
|
|
|
|
* Gets the translated display name of a source
|
|
|
|
*/
|
|
|
|
EXPORT const char *obs_source_getdisplayname(enum obs_source_type type,
|
2013-12-20 17:23:19 -07:00
|
|
|
const char *id, const char *locale);
|
2013-11-13 06:24:20 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/**
|
|
|
|
* Creates a source of the specified type with the specified settings.
|
|
|
|
*
|
|
|
|
* The "source" context is used for anything related to presenting
|
2013-12-20 19:35:12 -07:00
|
|
|
* or modifying video/audio. Use obs_source_release to release it.
|
2013-09-30 19:37:13 -07:00
|
|
|
*/
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT obs_source_t obs_source_create(enum obs_source_type type,
|
2013-12-20 17:23:19 -07:00
|
|
|
const char *id, const char *name, const char *settings);
|
2013-11-20 18:36:46 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Adds/releases a reference to a source. When the last reference is
|
|
|
|
* released, the source is destroyed.
|
|
|
|
*/
|
|
|
|
EXPORT int obs_source_addref(obs_source_t source);
|
|
|
|
EXPORT int obs_source_release(obs_source_t source);
|
|
|
|
|
2013-12-16 01:41:35 +01:00
|
|
|
/** Notifies all references that the source should be released */
|
2013-11-20 18:36:46 -07:00
|
|
|
EXPORT void obs_source_remove(obs_source_t source);
|
2013-11-20 15:00:16 -07:00
|
|
|
|
|
|
|
/** Returns true if the source should be released */
|
|
|
|
EXPORT bool obs_source_removed(obs_source_t source);
|
2013-10-14 12:37:52 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/**
|
|
|
|
* Retrieves flags that specify what type of data the source presents/modifies.
|
|
|
|
*
|
|
|
|
* SOURCE_VIDEO if it presents/modifies video_frame
|
|
|
|
* SOURCE_ASYNC if the video is asynchronous.
|
|
|
|
* SOURCE_AUDIO if it presents/modifies audio (always async)
|
|
|
|
*/
|
2013-10-17 17:21:42 -07:00
|
|
|
EXPORT uint32_t obs_source_get_output_flags(obs_source_t source);
|
2013-10-14 12:37:52 -07:00
|
|
|
|
2014-01-17 06:24:34 -07:00
|
|
|
/** Updates settings for this source */
|
|
|
|
EXPORT void obs_source_update(obs_source_t source, const char *settings);
|
2013-10-14 12:37:52 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/** Renders a video source. */
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT void obs_source_video_render(obs_source_t source);
|
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/** Gets the width of a source (if it has video) */
|
2013-10-17 17:21:42 -07:00
|
|
|
EXPORT uint32_t obs_source_getwidth(obs_source_t source);
|
2013-10-14 12:37:52 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/** Gets the height of a source (if it has video) */
|
2013-10-17 17:21:42 -07:00
|
|
|
EXPORT uint32_t obs_source_getheight(obs_source_t source);
|
2013-10-14 12:37:52 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/**
|
|
|
|
* Gets a custom parameter from the source.
|
|
|
|
*
|
|
|
|
* Used for efficiently modifying source properties in real time.
|
|
|
|
*/
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT size_t obs_source_getparam(obs_source_t source, const char *param,
|
|
|
|
void *buf, size_t buf_size);
|
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/**
|
|
|
|
* Sets a custom parameter for the source.
|
|
|
|
*
|
|
|
|
* Used for efficiently modifying source properties in real time.
|
|
|
|
*/
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT void obs_source_setparam(obs_source_t source, const char *param,
|
|
|
|
const void *data, size_t size);
|
2013-10-24 00:57:55 -07:00
|
|
|
|
2013-12-22 01:30:18 -07:00
|
|
|
/** If the source is a filter, returns the parent source of the filter */
|
|
|
|
EXPORT obs_source_t obs_filter_getparent(obs_source_t filter);
|
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/** If the source is a filter, returns the target source of the filter */
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT obs_source_t obs_filter_gettarget(obs_source_t filter);
|
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/** Adds a filter to the source (which is used whenever the source is used) */
|
2013-11-20 15:00:16 -07:00
|
|
|
EXPORT void obs_source_filter_add(obs_source_t source, obs_source_t filter);
|
2013-10-14 12:37:52 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/** Removes a filter from the source */
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT void obs_source_filter_remove(obs_source_t source, obs_source_t filter);
|
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/** Modifies the order of a specific filter */
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT void obs_source_filter_setorder(obs_source_t source, obs_source_t filter,
|
|
|
|
enum order_movement movement);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
|
|
|
/** Gets the settings string for a source */
|
2013-12-20 19:35:12 -07:00
|
|
|
EXPORT const char *obs_source_getsettings(obs_source_t source);
|
|
|
|
|
|
|
|
/** Gets the name of a source */
|
|
|
|
EXPORT const char *obs_source_getname(obs_source_t source);
|
|
|
|
|
|
|
|
/** Sets the name of a source */
|
|
|
|
EXPORT void obs_source_setname(obs_source_t source, const char *name);
|
|
|
|
|
|
|
|
/** Gets the source type and identifier */
|
2013-12-28 05:33:16 -07:00
|
|
|
EXPORT void obs_source_gettype(obs_source_t source, enum obs_source_type *type,
|
2013-12-20 19:35:12 -07:00
|
|
|
const char **id);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
2013-12-26 23:10:15 -07:00
|
|
|
/** Returns the signal handler for a source */
|
|
|
|
EXPORT signal_handler_t obs_source_signalhandler(obs_source_t source);
|
|
|
|
|
|
|
|
/** Returns the procedure handler for a source */
|
|
|
|
EXPORT proc_handler_t obs_source_prochandler(obs_source_t source);
|
|
|
|
|
2014-01-07 11:03:15 -07:00
|
|
|
/** Sets the volume for a source that has audio output */
|
|
|
|
EXPORT void obs_source_setvolume(obs_source_t source, float volume);
|
|
|
|
|
|
|
|
/** Gets the volume for a source that has audio output */
|
|
|
|
EXPORT float obs_source_getvolume(obs_source_t source);
|
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/* ------------------------------------------------------------------------- */
|
|
|
|
/* Functions used by sources */
|
|
|
|
|
|
|
|
/** Saves the settings string for a source */
|
2013-12-20 19:35:12 -07:00
|
|
|
EXPORT void obs_source_savesettings(obs_source_t source, const char *settings);
|
2013-10-14 12:37:52 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/** Outputs asynchronous video data */
|
2013-12-17 22:30:22 -07:00
|
|
|
EXPORT void obs_source_output_video(obs_source_t source,
|
2013-10-26 14:32:06 -07:00
|
|
|
const struct source_frame *frame);
|
2013-10-14 12:37:52 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/** Outputs audio data (always asynchronous) */
|
2013-12-17 22:30:22 -07:00
|
|
|
EXPORT void obs_source_output_audio(obs_source_t source,
|
2013-10-24 00:57:55 -07:00
|
|
|
const struct source_audio *audio);
|
|
|
|
|
|
|
|
/** Gets the current async video frame */
|
|
|
|
EXPORT struct source_frame *obs_source_getframe(obs_source_t source);
|
|
|
|
|
2013-10-24 01:03:45 -07:00
|
|
|
/** Releases the current async video frame */
|
2013-10-24 00:57:55 -07:00
|
|
|
EXPORT void obs_source_releaseframe(obs_source_t source,
|
|
|
|
struct source_frame *frame);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
2013-12-22 01:30:18 -07:00
|
|
|
/** Default RGB filter handler for generic effect filters */
|
|
|
|
EXPORT void obs_source_process_filter(obs_source_t filter,
|
|
|
|
texrender_t texrender, effect_t effect,
|
2013-12-22 02:03:40 -07:00
|
|
|
uint32_t width, uint32_t height,
|
|
|
|
enum allow_direct_render allow_direct);
|
2013-12-22 01:30:18 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------- */
|
|
|
|
/* Scenes */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a scene.
|
|
|
|
*
|
|
|
|
* A scene is a source which is a container of other sources with specific
|
|
|
|
* display oriantations. Scenes can also be used like any other source.
|
|
|
|
*/
|
2013-12-28 05:33:16 -07:00
|
|
|
EXPORT obs_scene_t obs_scene_create(const char *name);
|
2013-12-30 06:56:39 -07:00
|
|
|
|
|
|
|
EXPORT int obs_scene_addref(obs_scene_t scene);
|
|
|
|
EXPORT int obs_scene_release(obs_scene_t scene);
|
2013-10-14 12:37:52 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/** Gets the scene's source context */
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT obs_source_t obs_scene_getsource(obs_scene_t scene);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
2013-12-28 05:33:16 -07:00
|
|
|
/** Gets the scene from its source, or NULL if not a scene */
|
|
|
|
EXPORT obs_scene_t obs_scene_fromsource(obs_source_t source);
|
|
|
|
|
2014-01-01 10:22:55 -07:00
|
|
|
/** Determines whether a source is within a scene */
|
|
|
|
EXPORT obs_sceneitem_t obs_scene_findsource(obs_scene_t scene,
|
|
|
|
const char *name);
|
|
|
|
|
|
|
|
/** Enumerates sources within a scene */
|
|
|
|
EXPORT void obs_scene_enum_items(obs_scene_t scene,
|
|
|
|
bool (*callback)(obs_scene_t, obs_sceneitem_t, void*),
|
|
|
|
void *param);
|
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/** Adds/creates a new scene item for a source */
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT obs_sceneitem_t obs_scene_add(obs_scene_t scene, obs_source_t source);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
2013-12-30 06:56:39 -07:00
|
|
|
/** Removes/destroys a scene item. Returns the source reference counter
|
|
|
|
* (if any) */
|
|
|
|
EXPORT int obs_sceneitem_destroy(obs_sceneitem_t item);
|
|
|
|
|
2014-01-04 13:38:56 -07:00
|
|
|
/** Gets the scene parent associated with the scene item */
|
|
|
|
EXPORT obs_scene_t obs_sceneitem_getscene(obs_sceneitem_t item);
|
|
|
|
|
2013-12-30 06:56:39 -07:00
|
|
|
/** Gets the source of a scene item */
|
|
|
|
EXPORT obs_source_t obs_sceneitem_getsource(obs_sceneitem_t item);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
|
|
|
/* Functions for gettings/setting specific oriantation of a scene item */
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT void obs_sceneitem_setpos(obs_sceneitem_t item, const struct vec2 *pos);
|
|
|
|
EXPORT void obs_sceneitem_setrot(obs_sceneitem_t item, float rot);
|
|
|
|
EXPORT void obs_sceneitem_setorigin(obs_sceneitem_t item,
|
2013-10-14 12:42:45 -07:00
|
|
|
const struct vec2 *origin);
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT void obs_sceneitem_setscale(obs_sceneitem_t item,
|
|
|
|
const struct vec2 *scale);
|
|
|
|
EXPORT void obs_sceneitem_setorder(obs_sceneitem_t item,
|
|
|
|
enum order_movement movement);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT void obs_sceneitem_getpos(obs_sceneitem_t item, struct vec2 *pos);
|
|
|
|
EXPORT float obs_sceneitem_getrot(obs_sceneitem_t item);
|
|
|
|
EXPORT void obs_sceneitem_getorigin(obs_sceneitem_t item, struct vec2 *center);
|
|
|
|
EXPORT void obs_sceneitem_getscale(obs_sceneitem_t item, struct vec2 *scale);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------- */
|
|
|
|
/* Outputs */
|
|
|
|
|
Add preliminary output/encoder interface
- First, I redid the output interface for libobs. I feel like it's
going in a pretty good direction in terms of design.
Right now, the design is so that outputs and encoders are separate.
One or more outputs can connect to a specific encoder to receive its
data, or the output can connect directly to raw data from libobs
output itself, if the output doesn't want to use a designated encoder.
Data is received via callbacks set when you connect to the encoder or
raw output. Multiple outputs can receive the data from a single
encoder context if need be (such as for streaming to multiple channels
at once, and/or recording with the same data).
When an encoder is first connected to, it will connect to raw output,
and start encoding. Additional connections will receive that same
data being encoded as well after that. When the last encoder has
disconnected, it will stop encoding. If for some reason the encoder
needs to stop, it will use the callback with NULL to signal that
encoding has stopped. Some of these things may be subject to change
in the future, though it feels pretty good with this design so far.
Will have to see how well it works out in practice versus theory.
- Second, Started adding preliminary RTMP/x264 output plugin code.
To speed things up, I might just make a direct raw->FFmpeg output to
create a quick output plugin that we can start using for testing all
the subsystems.
2014-01-16 22:34:51 -07:00
|
|
|
EXPORT const char *obs_output_getdisplayname(const char *id,
|
|
|
|
const char *locale);
|
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/**
|
|
|
|
* Creates an output.
|
|
|
|
*
|
|
|
|
* Outputs allow outputting to file, outputting to network, outputting to
|
|
|
|
* directshow, or other custom outputs.
|
|
|
|
*/
|
Add preliminary output/encoder interface
- First, I redid the output interface for libobs. I feel like it's
going in a pretty good direction in terms of design.
Right now, the design is so that outputs and encoders are separate.
One or more outputs can connect to a specific encoder to receive its
data, or the output can connect directly to raw data from libobs
output itself, if the output doesn't want to use a designated encoder.
Data is received via callbacks set when you connect to the encoder or
raw output. Multiple outputs can receive the data from a single
encoder context if need be (such as for streaming to multiple channels
at once, and/or recording with the same data).
When an encoder is first connected to, it will connect to raw output,
and start encoding. Additional connections will receive that same
data being encoded as well after that. When the last encoder has
disconnected, it will stop encoding. If for some reason the encoder
needs to stop, it will use the callback with NULL to signal that
encoding has stopped. Some of these things may be subject to change
in the future, though it feels pretty good with this design so far.
Will have to see how well it works out in practice versus theory.
- Second, Started adding preliminary RTMP/x264 output plugin code.
To speed things up, I might just make a direct raw->FFmpeg output to
create a quick output plugin that we can start using for testing all
the subsystems.
2014-01-16 22:34:51 -07:00
|
|
|
EXPORT obs_output_t obs_output_create(const char *id, const char *name,
|
|
|
|
const char *settings);
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT void obs_output_destroy(obs_output_t output);
|
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/** Starts the output. */
|
Add preliminary output/encoder interface
- First, I redid the output interface for libobs. I feel like it's
going in a pretty good direction in terms of design.
Right now, the design is so that outputs and encoders are separate.
One or more outputs can connect to a specific encoder to receive its
data, or the output can connect directly to raw data from libobs
output itself, if the output doesn't want to use a designated encoder.
Data is received via callbacks set when you connect to the encoder or
raw output. Multiple outputs can receive the data from a single
encoder context if need be (such as for streaming to multiple channels
at once, and/or recording with the same data).
When an encoder is first connected to, it will connect to raw output,
and start encoding. Additional connections will receive that same
data being encoded as well after that. When the last encoder has
disconnected, it will stop encoding. If for some reason the encoder
needs to stop, it will use the callback with NULL to signal that
encoding has stopped. Some of these things may be subject to change
in the future, though it feels pretty good with this design so far.
Will have to see how well it works out in practice versus theory.
- Second, Started adding preliminary RTMP/x264 output plugin code.
To speed things up, I might just make a direct raw->FFmpeg output to
create a quick output plugin that we can start using for testing all
the subsystems.
2014-01-16 22:34:51 -07:00
|
|
|
EXPORT bool obs_output_start(obs_output_t output);
|
2013-10-14 12:37:52 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/** Stops the output. */
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT void obs_output_stop(obs_output_t output);
|
|
|
|
|
Add preliminary output/encoder interface
- First, I redid the output interface for libobs. I feel like it's
going in a pretty good direction in terms of design.
Right now, the design is so that outputs and encoders are separate.
One or more outputs can connect to a specific encoder to receive its
data, or the output can connect directly to raw data from libobs
output itself, if the output doesn't want to use a designated encoder.
Data is received via callbacks set when you connect to the encoder or
raw output. Multiple outputs can receive the data from a single
encoder context if need be (such as for streaming to multiple channels
at once, and/or recording with the same data).
When an encoder is first connected to, it will connect to raw output,
and start encoding. Additional connections will receive that same
data being encoded as well after that. When the last encoder has
disconnected, it will stop encoding. If for some reason the encoder
needs to stop, it will use the callback with NULL to signal that
encoding has stopped. Some of these things may be subject to change
in the future, though it feels pretty good with this design so far.
Will have to see how well it works out in practice versus theory.
- Second, Started adding preliminary RTMP/x264 output plugin code.
To speed things up, I might just make a direct raw->FFmpeg output to
create a quick output plugin that we can start using for testing all
the subsystems.
2014-01-16 22:34:51 -07:00
|
|
|
/** Returns whether the output is active */
|
|
|
|
EXPORT bool obs_output_active(obs_output_t output);
|
2013-10-14 12:37:52 -07:00
|
|
|
|
Add preliminary output/encoder interface
- First, I redid the output interface for libobs. I feel like it's
going in a pretty good direction in terms of design.
Right now, the design is so that outputs and encoders are separate.
One or more outputs can connect to a specific encoder to receive its
data, or the output can connect directly to raw data from libobs
output itself, if the output doesn't want to use a designated encoder.
Data is received via callbacks set when you connect to the encoder or
raw output. Multiple outputs can receive the data from a single
encoder context if need be (such as for streaming to multiple channels
at once, and/or recording with the same data).
When an encoder is first connected to, it will connect to raw output,
and start encoding. Additional connections will receive that same
data being encoded as well after that. When the last encoder has
disconnected, it will stop encoding. If for some reason the encoder
needs to stop, it will use the callback with NULL to signal that
encoding has stopped. Some of these things may be subject to change
in the future, though it feels pretty good with this design so far.
Will have to see how well it works out in practice versus theory.
- Second, Started adding preliminary RTMP/x264 output plugin code.
To speed things up, I might just make a direct raw->FFmpeg output to
create a quick output plugin that we can start using for testing all
the subsystems.
2014-01-16 22:34:51 -07:00
|
|
|
/** Updates the settings for this output context */
|
|
|
|
EXPORT void obs_output_update(obs_output_t output, const char *settings);
|
2013-10-14 12:37:52 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/** Specifies whether the output can be paused */
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT bool obs_output_canpause(obs_output_t output);
|
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/** Pauses the output (if the functionality is allowed by the output */
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT void obs_output_pause(obs_output_t output);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
|
|
|
/* Gets the current output settings string */
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT const char *obs_output_get_settings(obs_output_t output);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
|
|
|
/* Saves the output settings string, typically used only by outputs */
|
2013-10-14 12:37:52 -07:00
|
|
|
EXPORT void obs_output_save_settings(obs_output_t output,
|
|
|
|
const char *settings);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
2013-11-20 15:00:16 -07:00
|
|
|
|
Add preliminary output/encoder interface
- First, I redid the output interface for libobs. I feel like it's
going in a pretty good direction in terms of design.
Right now, the design is so that outputs and encoders are separate.
One or more outputs can connect to a specific encoder to receive its
data, or the output can connect directly to raw data from libobs
output itself, if the output doesn't want to use a designated encoder.
Data is received via callbacks set when you connect to the encoder or
raw output. Multiple outputs can receive the data from a single
encoder context if need be (such as for streaming to multiple channels
at once, and/or recording with the same data).
When an encoder is first connected to, it will connect to raw output,
and start encoding. Additional connections will receive that same
data being encoded as well after that. When the last encoder has
disconnected, it will stop encoding. If for some reason the encoder
needs to stop, it will use the callback with NULL to signal that
encoding has stopped. Some of these things may be subject to change
in the future, though it feels pretty good with this design so far.
Will have to see how well it works out in practice versus theory.
- Second, Started adding preliminary RTMP/x264 output plugin code.
To speed things up, I might just make a direct raw->FFmpeg output to
create a quick output plugin that we can start using for testing all
the subsystems.
2014-01-16 22:34:51 -07:00
|
|
|
/* ------------------------------------------------------------------------- */
|
|
|
|
/* Stream Encoders */
|
|
|
|
EXPORT const char *obs_encoder_getdisplayname(const char *id,
|
|
|
|
const char *locale);
|
|
|
|
|
|
|
|
EXPORT obs_encoder_t obs_encoder_create(const char *id, const char *name,
|
|
|
|
const char *settings);
|
|
|
|
EXPORT void obs_encoder_destroy(obs_encoder_t encoder);
|
|
|
|
|
|
|
|
EXPORT void obs_encoder_update(obs_encoder_t encoder, const char *settings);
|
|
|
|
|
|
|
|
EXPORT bool obs_encoder_reset(obs_encoder_t encoder);
|
|
|
|
|
|
|
|
EXPORT bool obs_encoder_encode(obs_encoder_t encoder, void *frames,
|
|
|
|
size_t size);
|
|
|
|
EXPORT int obs_encoder_getheader(obs_encoder_t encoder,
|
|
|
|
struct encoder_packet **packets);
|
|
|
|
|
|
|
|
EXPORT bool obs_encoder_start(obs_encoder_t encoder,
|
|
|
|
void (*new_packet)(void *param, struct encoder_packet *packet),
|
|
|
|
void *param);
|
|
|
|
EXPORT bool obs_encoder_stop(obs_encoder_t encoder,
|
|
|
|
void (*new_packet)(void *param, struct encoder_packet *packet),
|
|
|
|
void *param);
|
|
|
|
|
2014-01-17 00:00:21 -07:00
|
|
|
EXPORT bool obs_encoder_setbitrate(obs_encoder_t encoder, uint32_t bitrate,
|
Add preliminary output/encoder interface
- First, I redid the output interface for libobs. I feel like it's
going in a pretty good direction in terms of design.
Right now, the design is so that outputs and encoders are separate.
One or more outputs can connect to a specific encoder to receive its
data, or the output can connect directly to raw data from libobs
output itself, if the output doesn't want to use a designated encoder.
Data is received via callbacks set when you connect to the encoder or
raw output. Multiple outputs can receive the data from a single
encoder context if need be (such as for streaming to multiple channels
at once, and/or recording with the same data).
When an encoder is first connected to, it will connect to raw output,
and start encoding. Additional connections will receive that same
data being encoded as well after that. When the last encoder has
disconnected, it will stop encoding. If for some reason the encoder
needs to stop, it will use the callback with NULL to signal that
encoding has stopped. Some of these things may be subject to change
in the future, though it feels pretty good with this design so far.
Will have to see how well it works out in practice versus theory.
- Second, Started adding preliminary RTMP/x264 output plugin code.
To speed things up, I might just make a direct raw->FFmpeg output to
create a quick output plugin that we can start using for testing all
the subsystems.
2014-01-16 22:34:51 -07:00
|
|
|
uint32_t buffersize);
|
|
|
|
|
2014-01-17 00:00:21 -07:00
|
|
|
EXPORT bool obs_encoder_request_keyframe(obs_encoder_t encoder);
|
Add preliminary output/encoder interface
- First, I redid the output interface for libobs. I feel like it's
going in a pretty good direction in terms of design.
Right now, the design is so that outputs and encoders are separate.
One or more outputs can connect to a specific encoder to receive its
data, or the output can connect directly to raw data from libobs
output itself, if the output doesn't want to use a designated encoder.
Data is received via callbacks set when you connect to the encoder or
raw output. Multiple outputs can receive the data from a single
encoder context if need be (such as for streaming to multiple channels
at once, and/or recording with the same data).
When an encoder is first connected to, it will connect to raw output,
and start encoding. Additional connections will receive that same
data being encoded as well after that. When the last encoder has
disconnected, it will stop encoding. If for some reason the encoder
needs to stop, it will use the callback with NULL to signal that
encoding has stopped. Some of these things may be subject to change
in the future, though it feels pretty good with this design so far.
Will have to see how well it works out in practice versus theory.
- Second, Started adding preliminary RTMP/x264 output plugin code.
To speed things up, I might just make a direct raw->FFmpeg output to
create a quick output plugin that we can start using for testing all
the subsystems.
2014-01-16 22:34:51 -07:00
|
|
|
|
|
|
|
EXPORT const char *obs_encoder_get_settings(obs_encoder_t encoder);
|
|
|
|
|
|
|
|
EXPORT void obs_encoder_save_settings(obs_encoder_t encoder,
|
|
|
|
const char *settings);
|
|
|
|
|
|
|
|
|
2013-11-20 15:00:16 -07:00
|
|
|
/* ------------------------------------------------------------------------- */
|
|
|
|
/* Stream Services */
|
Add preliminary output/encoder interface
- First, I redid the output interface for libobs. I feel like it's
going in a pretty good direction in terms of design.
Right now, the design is so that outputs and encoders are separate.
One or more outputs can connect to a specific encoder to receive its
data, or the output can connect directly to raw data from libobs
output itself, if the output doesn't want to use a designated encoder.
Data is received via callbacks set when you connect to the encoder or
raw output. Multiple outputs can receive the data from a single
encoder context if need be (such as for streaming to multiple channels
at once, and/or recording with the same data).
When an encoder is first connected to, it will connect to raw output,
and start encoding. Additional connections will receive that same
data being encoded as well after that. When the last encoder has
disconnected, it will stop encoding. If for some reason the encoder
needs to stop, it will use the callback with NULL to signal that
encoding has stopped. Some of these things may be subject to change
in the future, though it feels pretty good with this design so far.
Will have to see how well it works out in practice versus theory.
- Second, Started adding preliminary RTMP/x264 output plugin code.
To speed things up, I might just make a direct raw->FFmpeg output to
create a quick output plugin that we can start using for testing all
the subsystems.
2014-01-16 22:34:51 -07:00
|
|
|
EXPORT const char *obs_service_getdisplayname(const char *id,
|
|
|
|
const char *locale);
|
|
|
|
|
2013-11-20 15:00:16 -07:00
|
|
|
EXPORT obs_service_t obs_service_create(const char *service,
|
|
|
|
const char *settings);
|
|
|
|
EXPORT void obs_service_destroy(obs_service_t service);
|
|
|
|
|
Add preliminary output/encoder interface
- First, I redid the output interface for libobs. I feel like it's
going in a pretty good direction in terms of design.
Right now, the design is so that outputs and encoders are separate.
One or more outputs can connect to a specific encoder to receive its
data, or the output can connect directly to raw data from libobs
output itself, if the output doesn't want to use a designated encoder.
Data is received via callbacks set when you connect to the encoder or
raw output. Multiple outputs can receive the data from a single
encoder context if need be (such as for streaming to multiple channels
at once, and/or recording with the same data).
When an encoder is first connected to, it will connect to raw output,
and start encoding. Additional connections will receive that same
data being encoded as well after that. When the last encoder has
disconnected, it will stop encoding. If for some reason the encoder
needs to stop, it will use the callback with NULL to signal that
encoding has stopped. Some of these things may be subject to change
in the future, though it feels pretty good with this design so far.
Will have to see how well it works out in practice versus theory.
- Second, Started adding preliminary RTMP/x264 output plugin code.
To speed things up, I might just make a direct raw->FFmpeg output to
create a quick output plugin that we can start using for testing all
the subsystems.
2014-01-16 22:34:51 -07:00
|
|
|
EXPORT void obs_service_setdata(obs_service_t service, const char *attribute,
|
2013-11-20 15:00:16 -07:00
|
|
|
const char *data);
|
|
|
|
EXPORT const char *obs_service_getdata(obs_service_t service,
|
|
|
|
const char *attribute);
|
|
|
|
|
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|