2013-09-30 19:37:13 -07:00
|
|
|
/******************************************************************************
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
Copyright (C) 2013-2014 by Hugh Bailey <obs.jim@gmail.com>
|
2013-09-30 19:37:13 -07:00
|
|
|
|
|
|
|
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
|
|
|
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
#include "obs.h"
|
|
|
|
|
2014-10-12 19:54:49 +02:00
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
* @brief header for modules implementing sources.
|
|
|
|
*
|
|
|
|
* Sources are modules that either feed data to libobs or modify it.
|
|
|
|
*/
|
|
|
|
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2014-02-12 12:57:51 -07:00
|
|
|
enum obs_source_type {
|
|
|
|
OBS_SOURCE_TYPE_INPUT,
|
|
|
|
OBS_SOURCE_TYPE_FILTER,
|
|
|
|
OBS_SOURCE_TYPE_TRANSITION,
|
2015-12-29 15:48:45 -08:00
|
|
|
OBS_SOURCE_TYPE_SCENE,
|
2014-02-12 12:57:51 -07:00
|
|
|
};
|
|
|
|
|
2017-10-08 05:15:28 -05:00
|
|
|
enum obs_balance_type {
|
|
|
|
OBS_BALANCE_TYPE_SINE_LAW,
|
|
|
|
OBS_BALANCE_TYPE_SQUARE_LAW,
|
|
|
|
OBS_BALANCE_TYPE_LINEAR,
|
|
|
|
};
|
2014-04-13 02:22:28 -07:00
|
|
|
|
2019-07-27 23:59:16 -05:00
|
|
|
enum obs_icon_type {
|
|
|
|
OBS_ICON_TYPE_UNKNOWN,
|
|
|
|
OBS_ICON_TYPE_IMAGE,
|
|
|
|
OBS_ICON_TYPE_COLOR,
|
|
|
|
OBS_ICON_TYPE_SLIDESHOW,
|
|
|
|
OBS_ICON_TYPE_AUDIO_INPUT,
|
|
|
|
OBS_ICON_TYPE_AUDIO_OUTPUT,
|
|
|
|
OBS_ICON_TYPE_DESKTOP_CAPTURE,
|
|
|
|
OBS_ICON_TYPE_WINDOW_CAPTURE,
|
|
|
|
OBS_ICON_TYPE_GAME_CAPTURE,
|
|
|
|
OBS_ICON_TYPE_CAMERA,
|
|
|
|
OBS_ICON_TYPE_TEXT,
|
|
|
|
OBS_ICON_TYPE_MEDIA,
|
|
|
|
OBS_ICON_TYPE_BROWSER,
|
|
|
|
OBS_ICON_TYPE_CUSTOM,
|
|
|
|
};
|
|
|
|
|
2019-07-10 00:45:35 -05:00
|
|
|
enum obs_media_state {
|
|
|
|
OBS_MEDIA_STATE_NONE,
|
|
|
|
OBS_MEDIA_STATE_PLAYING,
|
|
|
|
OBS_MEDIA_STATE_OPENING,
|
|
|
|
OBS_MEDIA_STATE_BUFFERING,
|
|
|
|
OBS_MEDIA_STATE_PAUSED,
|
|
|
|
OBS_MEDIA_STATE_STOPPED,
|
|
|
|
OBS_MEDIA_STATE_ENDED,
|
|
|
|
OBS_MEDIA_STATE_ERROR,
|
|
|
|
};
|
|
|
|
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
/**
|
|
|
|
* @name Source output flags
|
2013-09-30 19:37:13 -07:00
|
|
|
*
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
* These flags determine what type of data the source outputs and expects.
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Source has video.
|
2013-09-30 19:37:13 -07:00
|
|
|
*
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
* Unless SOURCE_ASYNC_VIDEO is specified, the source must include the
|
|
|
|
* video_render callback in the source definition structure.
|
|
|
|
*/
|
2019-06-22 22:13:45 -07:00
|
|
|
#define OBS_SOURCE_VIDEO (1 << 0)
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Source has audio.
|
2013-09-30 19:37:13 -07:00
|
|
|
*
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
* 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.
|
|
|
|
*/
|
2019-06-22 22:13:45 -07:00
|
|
|
#define OBS_SOURCE_AUDIO (1 << 1)
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
|
2014-04-13 02:22:28 -07:00
|
|
|
/** Async video flag (use OBS_SOURCE_ASYNC_VIDEO) */
|
2019-06-22 22:13:45 -07:00
|
|
|
#define OBS_SOURCE_ASYNC (1 << 2)
|
2014-04-13 02:22:28 -07:00
|
|
|
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
/**
|
|
|
|
* Source passes raw video data via RAM.
|
2013-09-30 19:37:13 -07:00
|
|
|
*
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
* Use the obs_source_output_video function to pass raw video data, which will
|
|
|
|
* be automatically uploaded at the specified timestamp.
|
2013-09-30 19:37:13 -07:00
|
|
|
*
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
* 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.
|
|
|
|
*/
|
2019-06-22 22:13:45 -07:00
|
|
|
#define OBS_SOURCE_ASYNC_VIDEO (OBS_SOURCE_ASYNC | OBS_SOURCE_VIDEO)
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Source uses custom drawing, rather than a default effect.
|
2013-09-30 19:37:13 -07:00
|
|
|
*
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
* If this flag is specified, the video_render callback will pass a NULL
|
|
|
|
* effect, and effect-based filters will not use direct rendering.
|
2013-09-30 19:37:13 -07:00
|
|
|
*/
|
2019-06-22 22:13:45 -07:00
|
|
|
#define OBS_SOURCE_CUSTOM_DRAW (1 << 3)
|
2013-09-30 19:37:13 -07:00
|
|
|
|
2014-09-14 15:31:57 -05:00
|
|
|
/**
|
|
|
|
* Source supports interaction.
|
2014-10-12 19:54:49 +02:00
|
|
|
*
|
2014-09-14 15:31:57 -05:00
|
|
|
* When this is used, the source will receive interaction events
|
|
|
|
* if they provide the necessary callbacks in the source definition structure.
|
|
|
|
*/
|
2019-06-22 22:13:45 -07:00
|
|
|
#define OBS_SOURCE_INTERACTION (1 << 5)
|
2014-09-14 15:31:57 -05:00
|
|
|
|
2015-12-17 06:46:10 -08:00
|
|
|
/**
|
|
|
|
* Source composites sub-sources
|
|
|
|
*
|
|
|
|
* When used specifies that the source composites one or more sub-sources.
|
|
|
|
* Sources that render sub-sources must implement the audio_render callback
|
|
|
|
* in order to perform custom mixing of sub-sources.
|
|
|
|
*
|
|
|
|
* This capability flag is always set for transitions.
|
|
|
|
*/
|
2019-06-22 22:13:45 -07:00
|
|
|
#define OBS_SOURCE_COMPOSITE (1 << 6)
|
2015-12-17 06:46:10 -08:00
|
|
|
|
2016-01-12 16:25:47 -08:00
|
|
|
/**
|
|
|
|
* Source should not be fully duplicated
|
|
|
|
*
|
|
|
|
* When this is used, specifies that the source should not be fully duplicated,
|
|
|
|
* and should prefer to duplicate via holding references rather than full
|
|
|
|
* duplication.
|
|
|
|
*/
|
2019-06-22 22:13:45 -07:00
|
|
|
#define OBS_SOURCE_DO_NOT_DUPLICATE (1 << 7)
|
2016-01-12 16:25:47 -08:00
|
|
|
|
2016-09-14 16:27:45 -07:00
|
|
|
/**
|
|
|
|
* Source is deprecated and should not be used
|
|
|
|
*/
|
2019-06-22 22:13:45 -07:00
|
|
|
#define OBS_SOURCE_DEPRECATED (1 << 8)
|
2016-09-14 16:27:45 -07:00
|
|
|
|
2017-02-05 21:37:35 -08:00
|
|
|
/**
|
|
|
|
* Source cannot have its audio monitored
|
|
|
|
*
|
2017-04-04 20:14:11 -03:00
|
|
|
* Specifies that this source may cause a feedback loop if audio is monitored
|
|
|
|
* with a device selected as desktop audio.
|
|
|
|
*
|
2017-02-05 21:37:35 -08:00
|
|
|
* This is used primarily with desktop audio capture sources.
|
|
|
|
*/
|
2019-06-22 22:13:45 -07:00
|
|
|
#define OBS_SOURCE_DO_NOT_SELF_MONITOR (1 << 9)
|
2017-02-05 21:37:35 -08:00
|
|
|
|
2017-12-25 12:20:54 -08:00
|
|
|
/**
|
|
|
|
* Source type is currently disabled and should not be shown to the user
|
|
|
|
*/
|
2019-06-22 22:13:45 -07:00
|
|
|
#define OBS_SOURCE_CAP_DISABLED (1 << 10)
|
2017-12-25 12:20:54 -08:00
|
|
|
|
2020-01-15 01:47:53 -08:00
|
|
|
/**
|
|
|
|
* Source type is obsolete (has been updated with new defaults/properties/etc)
|
|
|
|
*/
|
|
|
|
#define OBS_SOURCE_CAP_OBSOLETE OBS_SOURCE_CAP_DISABLED
|
|
|
|
|
2019-07-26 00:02:31 -07:00
|
|
|
/**
|
|
|
|
* Source should enable monitoring by default. Monitoring should be set by the
|
|
|
|
* frontend if this flag is set.
|
|
|
|
*/
|
|
|
|
#define OBS_SOURCE_MONITOR_BY_DEFAULT (1 << 11)
|
|
|
|
|
2019-08-21 14:35:40 -07:00
|
|
|
/** Used internally for audio submixing */
|
|
|
|
#define OBS_SOURCE_SUBMIX (1 << 12)
|
|
|
|
|
2019-07-10 00:45:35 -05:00
|
|
|
/**
|
|
|
|
* Source type can be controlled by media controls
|
|
|
|
*/
|
|
|
|
#define OBS_SOURCE_CONTROLLABLE_MEDIA (1 << 13)
|
|
|
|
|
2019-08-26 17:58:20 -05:00
|
|
|
/**
|
|
|
|
* Source type provides cea708 data
|
|
|
|
*/
|
|
|
|
#define OBS_SOURCE_CEA_708 (1 << 14)
|
|
|
|
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
/** @} */
|
2013-09-30 19:37:13 -07:00
|
|
|
|
2014-09-25 17:44:05 -07:00
|
|
|
typedef void (*obs_source_enum_proc_t)(obs_source_t *parent,
|
2019-06-22 22:13:45 -07:00
|
|
|
obs_source_t *child, void *param);
|
2014-02-20 17:44:42 -07:00
|
|
|
|
2015-12-17 04:28:35 -08:00
|
|
|
struct obs_source_audio_mix {
|
|
|
|
struct audio_output_data output[MAX_AUDIO_MIXES];
|
|
|
|
};
|
|
|
|
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
/**
|
|
|
|
* Source definition structure
|
|
|
|
*/
|
|
|
|
struct obs_source_info {
|
2013-09-30 19:37:13 -07:00
|
|
|
/* ----------------------------------------------------------------- */
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
/* Required implementation*/
|
2013-09-30 19:37:13 -07:00
|
|
|
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
/** Unique string identifier for the source */
|
|
|
|
const char *id;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Type of source.
|
|
|
|
*
|
2014-02-12 08:38:49 -07:00
|
|
|
* OBS_SOURCE_TYPE_INPUT for input sources,
|
|
|
|
* OBS_SOURCE_TYPE_FILTER for filter sources, and
|
|
|
|
* OBS_SOURCE_TYPE_TRANSITION for transition sources.
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
*/
|
|
|
|
enum obs_source_type type;
|
|
|
|
|
|
|
|
/** Source output flags */
|
|
|
|
uint32_t output_flags;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the translated name of the source type
|
|
|
|
*
|
2015-09-16 01:30:51 -07:00
|
|
|
* @param type_data The type_data variable of this structure
|
|
|
|
* @return The translated name of the source type
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
*/
|
2015-09-16 01:30:51 -07:00
|
|
|
const char *(*get_name)(void *type_data);
|
2013-11-13 06:24:20 -07:00
|
|
|
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
/**
|
|
|
|
* Creates the source data for the source
|
|
|
|
*
|
|
|
|
* @param settings Settings to initialize the source with
|
2017-03-19 07:35:51 -04:00
|
|
|
* @param source Source that this data is associated with
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
* @return The data associated with this source
|
|
|
|
*/
|
2014-09-25 17:44:05 -07:00
|
|
|
void *(*create)(obs_data_t *settings, obs_source_t *source);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
2014-05-04 21:01:46 +02:00
|
|
|
/**
|
|
|
|
* Destroys the private data for the source
|
|
|
|
*
|
|
|
|
* Async sources must not call obs_source_output_video after returning
|
|
|
|
* from destroy
|
|
|
|
*/
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
void (*destroy)(void *data);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
2014-04-13 02:22:28 -07:00
|
|
|
/** Returns the width of the source. Required if this is an input
|
|
|
|
* source and has non-async video */
|
2014-08-04 14:38:26 -07:00
|
|
|
uint32_t (*get_width)(void *data);
|
2014-03-23 01:07:54 -07:00
|
|
|
|
2014-04-13 02:22:28 -07:00
|
|
|
/** Returns the height of the source. Required if this is an input
|
|
|
|
* source and has non-async video */
|
2014-08-04 14:38:26 -07:00
|
|
|
uint32_t (*get_height)(void *data);
|
2014-03-23 01:07:54 -07:00
|
|
|
|
2013-09-30 19:37:13 -07:00
|
|
|
/* ----------------------------------------------------------------- */
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
/* Optional implementation */
|
|
|
|
|
2014-03-07 06:55:21 -07:00
|
|
|
/**
|
|
|
|
* Gets the default settings for this source
|
|
|
|
*
|
|
|
|
* @param[out] settings Data to assign default settings to
|
2017-08-29 09:29:56 -07:00
|
|
|
* @deprecated Use get_defaults2 if type_data is needed
|
2014-03-07 06:55:21 -07:00
|
|
|
*/
|
2014-09-25 17:44:05 -07:00
|
|
|
void (*get_defaults)(obs_data_t *settings);
|
2014-03-07 06:55:21 -07:00
|
|
|
|
2014-10-12 19:54:49 +02:00
|
|
|
/**
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
* Gets the property information of this source
|
|
|
|
*
|
2014-02-14 15:13:36 -07:00
|
|
|
* @return The properties data
|
2017-08-29 09:45:36 -07:00
|
|
|
* @deprecated Use get_properties2 if type_data is needed
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
*/
|
2014-09-29 17:36:13 +02:00
|
|
|
obs_properties_t *(*get_properties)(void *data);
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Updates the settings for this source
|
|
|
|
*
|
|
|
|
* @param data Source data
|
|
|
|
* @param settings New settings for this source
|
|
|
|
*/
|
2014-09-25 17:44:05 -07:00
|
|
|
void (*update)(void *data, obs_data_t *settings);
|
2013-09-30 19:37:13 -07:00
|
|
|
|
2014-02-23 17:46:00 -07:00
|
|
|
/** Called when the source has been activated in the main view */
|
2013-09-30 19:37:13 -07:00
|
|
|
void (*activate)(void *data);
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
|
|
|
|
/**
|
2014-02-23 17:46:00 -07:00
|
|
|
* Called when the source has been deactivated from the main view
|
|
|
|
* (no longer being played/displayed)
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
*/
|
2013-09-30 19:37:13 -07:00
|
|
|
void (*deactivate)(void *data);
|
|
|
|
|
2014-02-23 17:46:00 -07:00
|
|
|
/** Called when the source is visible */
|
|
|
|
void (*show)(void *data);
|
|
|
|
|
|
|
|
/** Called when the source is no longer visible */
|
|
|
|
void (*hide)(void *data);
|
|
|
|
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
/**
|
|
|
|
* Called each video frame with the time elapsed
|
|
|
|
*
|
|
|
|
* @param data Source data
|
|
|
|
* @param seconds Seconds elapsed since the last frame
|
|
|
|
*/
|
2013-09-30 19:37:13 -07:00
|
|
|
void (*video_tick)(void *data, float seconds);
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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
|
2014-02-12 08:38:49 -07:00
|
|
|
* a source needs to do is set the "image" parameter of the effect to
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
* the desired texture, and then draw. If the output flags include
|
2017-03-19 07:35:51 -04:00
|
|
|
* SOURCE_COLOR_MATRIX, you may optionally set the "color_matrix"
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
* 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.
|
|
|
|
*/
|
2014-09-25 17:44:05 -07:00
|
|
|
void (*video_render)(void *data, gs_effect_t *effect);
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Called to filter raw async video data.
|
|
|
|
*
|
|
|
|
* @note This function is only used with filter sources.
|
|
|
|
*
|
2015-03-07 09:37:07 -08:00
|
|
|
* @param data Filter data
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
* @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
|
|
|
|
*/
|
2019-06-22 22:13:45 -07:00
|
|
|
struct obs_source_frame *(*filter_video)(
|
|
|
|
void *data, struct obs_source_frame *frame);
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Called to filter raw audio data.
|
|
|
|
*
|
|
|
|
* @note This function is only used with filter sources.
|
|
|
|
*
|
2015-03-07 09:37:07 -08:00
|
|
|
* @param data Filter data
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
* @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
|
2015-03-07 09:37:07 -08:00
|
|
|
* data for later if time is needed for processing. If
|
|
|
|
* you are returning new data, that data must exist
|
|
|
|
* until the next call to the filter_audio callback or
|
|
|
|
* until the filter is removed/destroyed.
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
*/
|
2014-08-02 08:32:53 -07:00
|
|
|
struct obs_audio_data *(*filter_audio)(void *data,
|
2019-06-22 22:13:45 -07:00
|
|
|
struct obs_audio_data *audio);
|
2014-02-20 17:44:42 -07:00
|
|
|
|
|
|
|
/**
|
2015-12-22 04:59:02 -08:00
|
|
|
* Called to enumerate all active sources being used within this
|
|
|
|
* source. If the source has children that render audio/video it must
|
|
|
|
* implement this callback.
|
2014-02-20 17:44:42 -07:00
|
|
|
*
|
2015-03-07 09:37:07 -08:00
|
|
|
* @param data Filter data
|
2014-02-20 17:44:42 -07:00
|
|
|
* @param enum_callback Enumeration callback
|
|
|
|
* @param param User data to pass to callback
|
|
|
|
*/
|
2015-12-22 04:59:02 -08:00
|
|
|
void (*enum_active_sources)(void *data,
|
2019-06-22 22:13:45 -07:00
|
|
|
obs_source_enum_proc_t enum_callback,
|
|
|
|
void *param);
|
2014-04-26 23:47:50 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Called when saving a source. This is a separate function because
|
|
|
|
* sometimes a source needs to know when it is being saved so it
|
|
|
|
* doesn't always have to update the current settings until a certain
|
|
|
|
* point.
|
|
|
|
*
|
|
|
|
* @param data Source data
|
|
|
|
* @param settings Settings
|
|
|
|
*/
|
2014-09-25 17:44:05 -07:00
|
|
|
void (*save)(void *data, obs_data_t *settings);
|
2014-04-26 23:47:50 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Called when loading a source from saved data. This should be called
|
|
|
|
* after all the loading sources have actually been created because
|
|
|
|
* sometimes there are sources that depend on each other.
|
|
|
|
*
|
|
|
|
* @param data Source data
|
|
|
|
* @param settings Settings
|
|
|
|
*/
|
2014-09-25 17:44:05 -07:00
|
|
|
void (*load)(void *data, obs_data_t *settings);
|
2014-09-14 15:31:57 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Called when interacting with a source and a mouse-down or mouse-up
|
|
|
|
* occurs.
|
2014-10-12 19:54:49 +02:00
|
|
|
*
|
2014-09-14 15:31:57 -05:00
|
|
|
* @param data Source data
|
|
|
|
* @param event Mouse event properties
|
|
|
|
* @param type Mouse button pushed
|
|
|
|
* @param mouse_up Mouse event type (true if mouse-up)
|
|
|
|
* @param click_count Mouse click count (1 for single click, etc.)
|
|
|
|
*/
|
2019-06-22 22:13:45 -07:00
|
|
|
void (*mouse_click)(void *data, const struct obs_mouse_event *event,
|
|
|
|
int32_t type, bool mouse_up, uint32_t click_count);
|
2014-09-14 15:31:57 -05:00
|
|
|
/**
|
|
|
|
* Called when interacting with a source and a mouse-move occurs.
|
|
|
|
*
|
|
|
|
* @param data Source data
|
|
|
|
* @param event Mouse event properties
|
|
|
|
* @param mouse_leave Mouse leave state (true if mouse left source)
|
|
|
|
*/
|
2019-06-22 22:13:45 -07:00
|
|
|
void (*mouse_move)(void *data, const struct obs_mouse_event *event,
|
|
|
|
bool mouse_leave);
|
2014-09-14 15:31:57 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Called when interacting with a source and a mouse-wheel occurs.
|
|
|
|
*
|
|
|
|
* @param data Source data
|
|
|
|
* @param event Mouse event properties
|
|
|
|
* @param x_delta Movement delta in the horizontal direction
|
|
|
|
* @param y_delta Movement delta in the vertical direction
|
|
|
|
*/
|
2019-06-22 22:13:45 -07:00
|
|
|
void (*mouse_wheel)(void *data, const struct obs_mouse_event *event,
|
|
|
|
int x_delta, int y_delta);
|
2014-09-14 15:31:57 -05:00
|
|
|
/**
|
|
|
|
* Called when interacting with a source and gain focus/lost focus event
|
|
|
|
* occurs.
|
|
|
|
*
|
|
|
|
* @param data Source data
|
|
|
|
* @param focus Focus state (true if focus gained)
|
|
|
|
*/
|
|
|
|
void (*focus)(void *data, bool focus);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Called when interacting with a source and a key-up or key-down
|
|
|
|
* occurs.
|
|
|
|
*
|
|
|
|
* @param data Source data
|
|
|
|
* @param event Key event properties
|
|
|
|
* @param focus Key event type (true if mouse-up)
|
|
|
|
*/
|
|
|
|
void (*key_click)(void *data, const struct obs_key_event *event,
|
2019-06-22 22:13:45 -07:00
|
|
|
bool key_up);
|
libobs: Refactor source volume transition design
This changes the way source volume handles transitioning between being
active and inactive states.
The previous way that transitioning handled volume was that it set the
presentation volume of the source and all of its sub-sources to 0.0 if
the source was inactive, and 1.0 if active. Transition sources would
then also set the presentation volume for sub-sources to whatever their
transitioning volume was. However, the problem with this is that the
design didn't take in to account if the source or its sub-sources were
active anywhere else, so because of that it would break if that ever
happened, and I didn't realize that when I was designing it.
So instead, this completely overhauls the design of handling
transitioning volume. Each frame, it'll go through all sources and
check whether they're active or inactive and set the base volume
accordingly. If transitions are currently active, it will actually walk
the active source tree and check whether the source is in a
transitioning state somewhere.
- If the source is a sub-source of a transition, and it's not active
outside of the transition, then the transition will control the
volume of the source.
- If the source is a sub-source of a transition, but it's also active
outside of the transition, it'll defer to whichever is louder.
This also adds a new callback to the obs_source_info structure for
transition sources, get_transition_volume, which is called to get the
transitioning volume of a sub-source.
2014-12-27 22:16:10 -08:00
|
|
|
|
2015-03-07 09:33:08 -08:00
|
|
|
/**
|
|
|
|
* Called when the filter is removed from a source
|
|
|
|
*
|
|
|
|
* @param data Filter data
|
|
|
|
* @param source Source that the filter being removed from
|
|
|
|
*/
|
|
|
|
void (*filter_remove)(void *data, obs_source_t *source);
|
2015-09-15 22:39:11 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Private data associated with this entry
|
|
|
|
*/
|
|
|
|
void *type_data;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* If defined, called to free private data on shutdown
|
|
|
|
*/
|
|
|
|
void (*free_type_data)(void *type_data);
|
2015-12-17 06:46:10 -08:00
|
|
|
|
|
|
|
bool (*audio_render)(void *data, uint64_t *ts_out,
|
2019-06-22 22:13:45 -07:00
|
|
|
struct obs_source_audio_mix *audio_output,
|
|
|
|
uint32_t mixers, size_t channels,
|
|
|
|
size_t sample_rate);
|
2017-01-16 09:51:40 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Called to enumerate all active and inactive sources being used
|
|
|
|
* within this source. If this callback isn't implemented,
|
|
|
|
* enum_active_sources will be called instead.
|
|
|
|
*
|
|
|
|
* This is typically used if a source can have inactive child sources.
|
|
|
|
*
|
|
|
|
* @param data Filter data
|
|
|
|
* @param enum_callback Enumeration callback
|
|
|
|
* @param param User data to pass to callback
|
|
|
|
*/
|
|
|
|
void (*enum_all_sources)(void *data,
|
2019-06-22 22:13:45 -07:00
|
|
|
obs_source_enum_proc_t enum_callback,
|
|
|
|
void *param);
|
2017-07-19 09:24:10 -07:00
|
|
|
|
|
|
|
void (*transition_start)(void *data);
|
|
|
|
void (*transition_stop)(void *data);
|
2017-08-29 09:29:56 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the default settings for this source
|
2019-07-10 19:37:52 +02:00
|
|
|
*
|
|
|
|
* If get_defaults is also defined both will be called, and the first
|
|
|
|
* call will be to get_defaults, then to get_defaults2.
|
2017-08-29 09:29:56 -07:00
|
|
|
*
|
|
|
|
* @param type_data The type_data variable of this structure
|
|
|
|
* @param[out] settings Data to assign default settings to
|
|
|
|
*/
|
|
|
|
void (*get_defaults2)(void *type_data, obs_data_t *settings);
|
2017-08-29 09:45:36 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the property information of this source
|
|
|
|
*
|
|
|
|
* @param data Source data
|
|
|
|
* @param type_data The type_data variable of this structure
|
|
|
|
* @return The properties data
|
|
|
|
*/
|
|
|
|
obs_properties_t *(*get_properties2)(void *data, void *type_data);
|
2019-08-21 14:35:40 -07:00
|
|
|
|
|
|
|
bool (*audio_mix)(void *data, uint64_t *ts_out,
|
|
|
|
struct audio_output_data *audio_output,
|
|
|
|
size_t channels, size_t sample_rate);
|
2019-07-27 23:59:16 -05:00
|
|
|
|
|
|
|
/** Icon type for the source */
|
|
|
|
enum obs_icon_type icon_type;
|
2019-07-10 00:45:35 -05:00
|
|
|
|
|
|
|
/** Media controls */
|
|
|
|
void (*media_play_pause)(void *data, bool pause);
|
|
|
|
void (*media_restart)(void *data);
|
|
|
|
void (*media_stop)(void *data);
|
|
|
|
void (*media_next)(void *data);
|
|
|
|
void (*media_previous)(void *data);
|
|
|
|
int64_t (*media_get_duration)(void *data);
|
|
|
|
int64_t (*media_get_time)(void *data);
|
2020-02-06 18:44:04 +01:00
|
|
|
void (*media_set_time)(void *data, int64_t miliseconds);
|
2019-07-10 00:45:35 -05:00
|
|
|
enum obs_media_state (*media_get_state)(void *data);
|
2020-03-09 06:03:10 -07:00
|
|
|
|
|
|
|
/* version-related stuff */
|
|
|
|
uint32_t version; /* increment if needed to specify a new version */
|
|
|
|
const char *unversioned_id; /* set internally, don't set manually */
|
2013-09-30 19:37:13 -07:00
|
|
|
};
|
|
|
|
|
2014-04-05 01:43:59 -07:00
|
|
|
EXPORT void obs_register_source_s(const struct obs_source_info *info,
|
2019-06-22 22:13:45 -07:00
|
|
|
size_t size);
|
2014-04-05 01:43:59 -07:00
|
|
|
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
/**
|
2017-03-19 07:35:51 -04:00
|
|
|
* Registers a source definition to the current obs context. This should be
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
* used in obs_module_load.
|
|
|
|
*
|
|
|
|
* @param info Pointer to the source definition structure
|
|
|
|
*/
|
2014-04-05 01:43:59 -07:00
|
|
|
#define obs_register_source(info) \
|
|
|
|
obs_register_source_s(info, sizeof(struct obs_source_info))
|
2013-09-30 19:37:13 -07:00
|
|
|
|
Revamp API and start using doxygen
The API used to be designed in such a way to where it would expect
exports for each individual source/output/encoder/etc. You would export
functions for each and it would automatically load those functions based
on a specific naming scheme from the module.
The idea behind this was that I wanted to limit the usage of structures
in the API so only functions could be used. It was an interesting idea
in theory, but this idea turned out to be flawed in a number of ways:
1.) Requiring exports to create sources/outputs/encoders/etc meant that
you could not create them by any other means, which meant that
things like faruton's .net plugin would become difficult.
2.) Export function declarations could not be checked, therefore if you
created a function with the wrong parameters and parameter types,
the compiler wouldn't know how to check for that.
3.) Required overly complex load functions in libobs just to handle it.
It makes much more sense to just have a load function that you call
manually. Complexity is the bane of all good programs.
4.) It required that you have functions of specific names, which looked
and felt somewhat unsightly.
So, to fix these issues, I replaced it with a more commonly used API
scheme, seen commonly in places like kernels and typical C libraries
with abstraction. You simply create a structure that contains the
callback definitions, and you pass it to a function to register that
definition (such as obs_register_source), which you call in the
obs_module_load of the module.
It will also automatically check the structure size and ensure that it
only loads the required values if the structure happened to add new
values in an API change.
The "main" source file for each module must include obs-module.h, and
must use OBS_DECLARE_MODULE() within that source file.
Also, started writing some doxygen documentation in to the main library
headers. Will add more detailed documentation as I go.
2014-02-12 08:04:50 -07:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|