2451b80ef6
Before, async video sources would flicker because they were only being drawn when they were updated. So when updated, they'd draw that frame, then it would stop drawing it until it updated again. This fixes that issue and they should now draw properly. Also, fix a few other minor bugs and issues relating to async video, and make it so that non-async video filters can be properly applied to them. For the purposes of testing, change the 'test-random' source to an async video source that updates every quarter of a second with a new random face. Also fix a bug where non-async video sources wouldn't have filter effects applied properly.
281 lines
8.5 KiB
C
281 lines
8.5 KiB
C
/******************************************************************************
|
|
Copyright (C) 2013-2014 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
|
|
the Free Software Foundation, either version 2 of the License, or
|
|
(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/>.
|
|
******************************************************************************/
|
|
|
|
#pragma once
|
|
|
|
#include "obs.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
|
|
enum obs_source_type {
|
|
OBS_SOURCE_TYPE_INPUT,
|
|
OBS_SOURCE_TYPE_FILTER,
|
|
OBS_SOURCE_TYPE_TRANSITION,
|
|
|
|
OBS_SOURCE_TYPE_SCENE = 0x80000000
|
|
};
|
|
|
|
|
|
/**
|
|
* @name Source output flags
|
|
*
|
|
* These flags determine what type of data the source outputs and expects.
|
|
* @{
|
|
*/
|
|
|
|
/**
|
|
* Source has video.
|
|
*
|
|
* Unless SOURCE_ASYNC_VIDEO is specified, the source must include the
|
|
* video_render callback in the source definition structure.
|
|
*/
|
|
#define OBS_SOURCE_VIDEO (1<<0)
|
|
|
|
/**
|
|
* Source has audio.
|
|
*
|
|
* Use the obs_source_output_audio function to pass raw audio data, which will
|
|
* be automatically converted and uploaded. If used with SOURCE_ASYNC_VIDEO,
|
|
* audio will automatically be synced up to the video output.
|
|
*/
|
|
#define OBS_SOURCE_AUDIO (1<<1)
|
|
|
|
/** Async video flag (use OBS_SOURCE_ASYNC_VIDEO) */
|
|
#define OBS_SOURCE_ASYNC (1<<2)
|
|
|
|
/**
|
|
* Source passes raw video data via RAM.
|
|
*
|
|
* Use the obs_source_output_video function to pass raw video data, which will
|
|
* be automatically uploaded at the specified timestamp.
|
|
*
|
|
* If this flag is specified, it is not necessary to include the video_render
|
|
* callback. However, if you wish to use that function as well, you must call
|
|
* obs_source_getframe to get the current frame data, and
|
|
* obs_source_releaseframe to release the data when complete.
|
|
*/
|
|
#define OBS_SOURCE_ASYNC_VIDEO (OBS_SOURCE_ASYNC | OBS_SOURCE_VIDEO)
|
|
|
|
/**
|
|
* Source uses custom drawing, rather than a default effect.
|
|
*
|
|
* If this flag is specified, the video_render callback will pass a NULL
|
|
* effect, and effect-based filters will not use direct rendering.
|
|
*/
|
|
#define OBS_SOURCE_CUSTOM_DRAW (1<<3)
|
|
|
|
/**
|
|
* Source uses a color matrix (usually YUV sources).
|
|
*
|
|
* When this is used, the video_render callback will automatically assign a
|
|
* 4x4 YUV->RGB matrix to the "color_matrix" parameter of the effect, or it can
|
|
* be changed to a custom value.
|
|
*/
|
|
#define OBS_SOURCE_COLOR_MATRIX (1<<4)
|
|
|
|
/** @} */
|
|
|
|
typedef void (*obs_source_enum_proc_t)(obs_source_t parent, obs_source_t child,
|
|
void *param);
|
|
|
|
/**
|
|
* Source definition structure
|
|
*/
|
|
struct obs_source_info {
|
|
/* ----------------------------------------------------------------- */
|
|
/* Required implementation*/
|
|
|
|
/** Unique string identifier for the source */
|
|
const char *id;
|
|
|
|
/**
|
|
* Type of source.
|
|
*
|
|
* OBS_SOURCE_TYPE_INPUT for input sources,
|
|
* OBS_SOURCE_TYPE_FILTER for filter sources, and
|
|
* OBS_SOURCE_TYPE_TRANSITION for transition sources.
|
|
*/
|
|
enum obs_source_type type;
|
|
|
|
/** Source output flags */
|
|
uint32_t output_flags;
|
|
|
|
/**
|
|
* Get the translated name of the source type
|
|
*
|
|
* @param locale The locale to translate with
|
|
* @return The translated name of the source type
|
|
*/
|
|
const char *(*getname)(const char *locale);
|
|
|
|
/**
|
|
* Creates the source data for the source
|
|
*
|
|
* @param settings Settings to initialize the source with
|
|
* @param source Source that this data is assoicated with
|
|
* @return The data associated with this source
|
|
*/
|
|
void *(*create)(obs_data_t settings, obs_source_t source);
|
|
|
|
/** Destroys the private data for the source */
|
|
void (*destroy)(void *data);
|
|
|
|
/** Returns the width of the source. Required if this is an input
|
|
* source and has non-async video */
|
|
uint32_t (*getwidth)(void *data);
|
|
|
|
/** Returns the height of the source. Required if this is an input
|
|
* source and has non-async video */
|
|
uint32_t (*getheight)(void *data);
|
|
|
|
/* ----------------------------------------------------------------- */
|
|
/* Optional implementation */
|
|
|
|
/**
|
|
* Gets the default settings for this source
|
|
*
|
|
* @param[out] settings Data to assign default settings to
|
|
*/
|
|
void (*defaults)(obs_data_t settings);
|
|
|
|
/**
|
|
* Gets the property information of this source
|
|
*
|
|
* @param locale The locale to translate with
|
|
* @return The properties data
|
|
*/
|
|
obs_properties_t (*properties)(const char *locale);
|
|
|
|
/**
|
|
* Updates the settings for this source
|
|
*
|
|
* @param data Source data
|
|
* @param settings New settings for this source
|
|
*/
|
|
void (*update)(void *data, obs_data_t settings);
|
|
|
|
/** Called when the source has been activated in the main view */
|
|
void (*activate)(void *data);
|
|
|
|
/**
|
|
* Called when the source has been deactivated from the main view
|
|
* (no longer being played/displayed)
|
|
*/
|
|
void (*deactivate)(void *data);
|
|
|
|
/** Called when the source is visible */
|
|
void (*show)(void *data);
|
|
|
|
/** Called when the source is no longer visible */
|
|
void (*hide)(void *data);
|
|
|
|
/**
|
|
* Called each video frame with the time elapsed
|
|
*
|
|
* @param data Source data
|
|
* @param seconds Seconds elapsed since the last frame
|
|
*/
|
|
void (*video_tick)(void *data, float seconds);
|
|
|
|
/**
|
|
* Called when rendering the source with the graphics subsystem.
|
|
*
|
|
* If this is an input/transition source, this is called to draw the
|
|
* source texture with the graphics subsystem using the specified
|
|
* effect.
|
|
*
|
|
* If this is a filter source, it wraps source draw calls (for
|
|
* example applying a custom effect with custom parameters to a
|
|
* source). In this case, it's highly recommended to use the
|
|
* obs_source_process_filter function to automatically handle
|
|
* effect-based filter processing. However, you can implement custom
|
|
* draw handling as desired as well.
|
|
*
|
|
* If the source output flags do not include SOURCE_CUSTOM_DRAW, all
|
|
* a source needs to do is set the "image" parameter of the effect to
|
|
* the desired texture, and then draw. If the output flags include
|
|
* SOURCE_COLOR_MATRIX, you may optionally set the the "color_matrix"
|
|
* parameter of the effect to a custom 4x4 conversion matrix (by
|
|
* default it will be set to an YUV->RGB conversion matrix)
|
|
*
|
|
* @param data Source data
|
|
* @param effect Effect to be used with this source. If the source
|
|
* output flags include SOURCE_CUSTOM_DRAW, this will
|
|
* be NULL, and the source is expected to process with
|
|
* an effect manually.
|
|
*/
|
|
void (*video_render)(void *data, effect_t effect);
|
|
|
|
/**
|
|
* Called to filter raw async video data.
|
|
*
|
|
* @note This function is only used with filter sources.
|
|
*
|
|
* @param data Source data
|
|
* @param frame Video frame to filter
|
|
* @return New video frame data. This can defer video data to
|
|
* be drawn later if time is needed for processing
|
|
*/
|
|
struct source_frame *(*filter_video)(void *data,
|
|
const struct source_frame *frame);
|
|
|
|
/**
|
|
* Called to filter raw audio data.
|
|
*
|
|
* @note This function is only used with filter sources.
|
|
*
|
|
* @param data Source data
|
|
* @param audio Audio data to filter.
|
|
* @return Modified or new audio data. You can directly modify
|
|
* the data passed and return it, or you can defer audio
|
|
* data for later if time is needed for processing.
|
|
*/
|
|
struct filtered_audio *(*filter_audio)(void *data,
|
|
struct filtered_audio *audio);
|
|
|
|
/**
|
|
* Called to enumerate all sources being used within this source.
|
|
* If the source has children it must implement this callback.
|
|
*
|
|
* @param data Source data
|
|
* @param enum_callback Enumeration callback
|
|
* @param param User data to pass to callback
|
|
*/
|
|
void (*enum_sources)(void *data,
|
|
obs_source_enum_proc_t enum_callback,
|
|
void *param);
|
|
};
|
|
|
|
EXPORT void obs_register_source_s(const struct obs_source_info *info,
|
|
size_t size);
|
|
|
|
/**
|
|
* Regsiters a source definition to the current obs context. This should be
|
|
* used in obs_module_load.
|
|
*
|
|
* @param info Pointer to the source definition structure
|
|
*/
|
|
#define obs_register_source(info) \
|
|
obs_register_source_s(info, sizeof(struct obs_source_info))
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|