| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713 | OBS Core API Reference======================.. code:: cpp   #include <obs.h>.. _obs_init_shutdown_reference:Initialization, Shutdown, and Information-----------------------------------------.. function:: bool obs_startup(const char *locale, const char *module_config_path, profiler_name_store_t *store)   Initializes the OBS core context.     :param  locale:             The locale to use for modules                               (E.G. "en-US")   :param  module_config_path: Path to module config storage directory                               (or *NULL* if none)   :param  store:              The profiler name store for OBS to use or NULL   :return:                    *false* if already initialized or failed                               to initialize---------------------.. function:: void obs_shutdown(void)   Releases all data associated with OBS and terminates the OBS context.---------------------.. function:: bool obs_initialized(void)   :return: true if the main OBS context has been initialized---------------------.. function:: uint32_t obs_get_version(void)   :return: The current core version---------------------.. function:: const char *obs_get_version_string(void)   :return: The current core version string---------------------.. function:: void obs_set_locale(const char *locale)   Sets a new locale to use for modules.  This will call   obs_module_set_locale for each module with the new locale.     :param  locale: The locale to use for modules---------------------.. function:: const char *obs_get_locale(void)   :return: The current locale---------------------.. function:: profiler_name_store_t *obs_get_profiler_name_store(void)   :return: The profiler name store (see util/profiler.h) used by OBS,            which is either a name store passed to obs_startup, an            internal name store, or NULL in case obs_initialized()            returns false.---------------------.. function:: int obs_reset_video(struct obs_video_info *ovi)   Sets base video output base resolution/fps/format.     Note: This data cannot be changed if an output is currently active.   Note: The graphics module cannot be changed without fully destroying   the OBS context.   :param   ovi: Pointer to an obs_video_info structure containing the                 specification of the graphics subsystem,   :return:      | OBS_VIDEO_SUCCESS          - Success                 | OBS_VIDEO_NOT_SUPPORTED    - The adapter lacks capabilities                 | OBS_VIDEO_INVALID_PARAM    - A parameter is invalid                 | OBS_VIDEO_CURRENTLY_ACTIVE - Video is currently active                 | OBS_VIDEO_MODULE_NOT_FOUND - The graphics module is not found                 | OBS_VIDEO_FAIL             - Generic failure   Relevant data types used with this function:.. code:: cpp   struct obs_video_info {           /**            * Graphics module to use (usually "libobs-opengl" or "libobs-d3d11")            */           const char          *graphics_module;              uint32_t            fps_num;       /**< Output FPS numerator */           uint32_t            fps_den;       /**< Output FPS denominator */              uint32_t            base_width;    /**< Base compositing width */           uint32_t            base_height;   /**< Base compositing height */              uint32_t            output_width;  /**< Output width */           uint32_t            output_height; /**< Output height */           enum video_format   output_format; /**< Output format */              /** Video adapter index to use (NOTE: avoid for optimus laptops) */           uint32_t            adapter;              /** Use shaders to convert to different color formats */           bool                gpu_conversion;              enum video_colorspace colorspace;  /**< YUV type (if YUV) */           enum video_range_type range;       /**< YUV range (if YUV) */              enum obs_scale_type scale_type;    /**< How to scale if scaling */   };---------------------.. function:: bool obs_reset_audio(const struct obs_audio_info *oai)   Sets base audio output format/channels/samples/etc.   Note: Cannot reset base audio if an output is currently active.   :return: *true* if successful, *false* otherwise   Relevant data types used with this function:.. code:: cpp   struct obs_audio_info {           uint32_t            samples_per_sec;           enum speaker_layout speakers;   };---------------------.. function:: bool obs_get_video_info(struct obs_video_info *ovi)   Gets the current video settings.      :return: *false* if no video---------------------.. function:: bool obs_get_audio_info(struct obs_audio_info *oai)   Gets the current audio settings.      :return: *false* if no audio---------------------Libobs Objects--------------.. function:: bool obs_enum_source_types(size_t idx, const char **id)   Enumerates all source types (inputs, filters, transitions, etc).---------------------.. function:: bool obs_enum_input_types(size_t idx, const char **id)   Enumerates all available inputs source types.     Inputs are general source inputs (such as capture sources, device sources,   etc).---------------------.. function:: bool obs_enum_filter_types(size_t idx, const char **id)   Enumerates all available filter source types.     Filters are sources that are used to modify the video/audio output of   other sources.---------------------.. function:: bool obs_enum_transition_types(size_t idx, const char **id)   Enumerates all available transition source types.     Transitions are sources used to transition between two or more other   sources.---------------------.. function:: bool obs_enum_output_types(size_t idx, const char **id)   Enumerates all available output types.---------------------.. function:: bool obs_enum_encoder_types(size_t idx, const char **id)   Enumerates all available encoder types.---------------------.. function:: bool obs_enum_service_types(size_t idx, const char **id)   Enumerates all available service types.---------------------.. function:: void obs_enum_sources(bool (*enum_proc)(void*, obs_source_t*), void *param)   Enumerates all input sources.     Callback function returns true to continue enumeration, or false to end   enumeration.     Use :c:func:`obs_source_get_ref()` or   :c:func:`obs_source_get_weak_source()` if you want to retain a   reference after obs_enum_sources finishes.---------------------.. function:: void obs_enum_scenes(bool (*enum_proc)(void*, obs_source_t*), void *param)   Enumerates all scenes.     Callback function returns true to continue enumeration, or false to end   enumeration.     Use :c:func:`obs_source_get_ref()` or   :c:func:`obs_source_get_weak_source()` if you want to retain a   reference after obs_enum_scenes finishes. ---------------------.. function:: void obs_enum_outputs(bool (*enum_proc)(void*, obs_output_t*), void *param)   Enumerates outputs.---------------------.. function:: void obs_enum_encoders(bool (*enum_proc)(void*, obs_encoder_t*), void *param)   Enumerates encoders.---------------------.. function:: obs_source_t *obs_get_source_by_name(const char *name)   Gets a source by its name.     Increments the source reference counter, use   :c:func:`obs_source_release()` to release it when complete.---------------------.. function:: obs_source_t *obs_get_transition_by_name(const char *name)   Gets a transition by its name.     Increments the source reference counter, use   :c:func:`obs_source_release()` to release it when complete.---------------------.. function:: obs_scene_t *obs_get_scene_by_name(const char *name)   Gets a scene by its name.     Increments the scene reference counter, use   :c:func:`obs_scene_release()` to release it when complete.---------------------.. function:: obs_output_t *obs_get_output_by_name(const char *name)   Gets an output by its name.   Increments the output reference counter, use   :c:func:`obs_output_release()` to release it when complete.---------------------.. function:: obs_encoder_t *obs_get_encoder_by_name(const char *name)   Gets an encoder by its name.   Increments the encoder reference counter, use   :c:func:`obs_encoder_release()` to release it when complete.---------------------.. function:: obs_service_t *obs_get_service_by_name(const char *name)   Gets an service by its name.   Increments the service reference counter, use   :c:func:`obs_service_release()` to release it when complete.---------------------.. function:: obs_data_t *obs_save_source(obs_source_t *source)   :return: A new reference to a source's saved data---------------------.. function:: obs_source_t *obs_load_source(obs_data_t *data)   :return: A source created from saved data---------------------.. function:: void obs_load_sources(obs_data_array_t *array, obs_load_source_cb cb, void *private_data)   Helper function to load active sources from a data array.   Relevant data types used with this function:.. code:: cpp   typedef void (*obs_load_source_cb)(void *private_data, obs_source_t *source);---------------------.. function:: obs_data_array_t *obs_save_sources(void)   :return: A data array with the saved data of all active sources---------------------.. function:: obs_data_array_t *obs_save_sources_filtered(obs_save_source_filter_cb cb, void *data)   :return: A data array with the saved data of all active sources,            filtered by the *cb* function   Relevant data types used with this function:.. code:: cpp   typedef bool (*obs_save_source_filter_cb)(void *data, obs_source_t *source);---------------------Video, Audio, and Graphics--------------------------.. function:: void obs_enter_graphics(void)   Helper function for entering the OBS graphics context.---------------------.. function:: void obs_leave_graphics(void)   Helper function for leaving the OBS graphics context.---------------------.. function:: audio_t *obs_get_audio(void)   :return: The main audio output handler for this OBS context---------------------.. function:: video_t *obs_get_video(void)   :return: The main video output handler for this OBS context---------------------.. function:: void obs_set_output_source(uint32_t channel, obs_source_t *source)   Sets the primary output source for a channel.---------------------.. function:: obs_source_t *obs_get_output_source(uint32_t channel)   Gets the primary output source for a channel and increments the reference   counter for that source.  Use :c:func:`obs_source_release()` to release.---------------------.. function:: gs_effect_t *obs_get_base_effect(enum obs_base_effect effect)   Returns a commoinly used base effect.   :param effect: | Can be one of the following values:                  | OBS_EFFECT_DEFAULT             - RGB/YUV                  | OBS_EFFECT_DEFAULT_RECT        - RGB/YUV (using texture_rect)                  | OBS_EFFECT_OPAQUE              - RGB/YUV (alpha set to 1.0)                  | OBS_EFFECT_SOLID               - RGB/YUV (solid color only)                  | OBS_EFFECT_BICUBIC             - Bicubic downscale                  | OBS_EFFECT_LANCZOS             - Lanczos downscale                  | OBS_EFFECT_BILINEAR_LOWRES     - Bilinear low resolution downscale                  | OBS_EFFECT_PREMULTIPLIED_ALPHA - Premultiplied alpha---------------------.. function:: void obs_render_main_view(void)   Renders the main view.   Note: This function is deprecated.---------------------.. function:: void obs_render_main_texture(void)   Renders the main output texture.  Useful for rendering a preview pane   of the main output.---------------------.. function:: void obs_set_master_volume(float volume)   Sets the master user volume.---------------------.. function:: float obs_get_master_volume(void)   :return: The master user volume---------------------.. function:: bool obs_audio_monitoring_available(void)   :return: Whether audio monitoring is supported and available on the current platform---------------------.. function:: void obs_enum_audio_monitoring_devices(obs_enum_audio_device_cb cb, void *data)   Enumerates audio devices which can be used for audio monitoring.   Relevant data types used with this function:.. code:: cpp   typedef bool (*obs_enum_audio_device_cb)(void *data, const char *name, const char *id);---------------------.. function:: bool obs_set_audio_monitoring_device(const char *name, const char *id)   Sets the current audio device for audio monitoring.---------------------.. function:: void obs_get_audio_monitoring_device(const char **name, const char **id)   Gets the current audio device for audio monitoring.---------------------.. function:: void obs_add_main_render_callback(void (*draw)(void *param, uint32_t cx, uint32_t cy), void *param)              void obs_remove_main_render_callback(void (*draw)(void *param, uint32_t cx, uint32_t cy), void *param)   Adds/removes a main rendering callback.  Allows custom rendering to   the main stream/recording output.---------------------.. function:: void obs_add_raw_video_callback(const struct video_scale_info *conversion, void (*callback)(void *param, struct video_data *frame), void *param)              void obs_remove_raw_video_callback(void (*callback)(void *param, struct video_data *frame), void *param)   Adds/removes a raw video callback.  Allows the ability to obtain raw   video frames without necessarily using an output.   :param conversion: Specifies conversion requirements.  Can be NULL.   :param callback:   The callback that receives raw video frames.   :param param:      The private data associated with the callback.---------------------.. function:: void obs_add_raw_audio_callback(size_t mix_idx, const struct audio_convert_info *conversion, audio_output_callback_t callback, void *param)              void obs_remove_raw_raw_callback(size_t track, audio_output_callback_t callback, void *param)   Adds/removes a raw audio callback.  Allows the ability to obtain raw   audio data without necessarily using an output.   :param mix_idx:    Specifies audio track to get data from.   :param conversion: Specifies conversion requirements.  Can be NULL.   :param callback:   The callback that receives raw audio data.   :param param:      The private data associated with the callback.Primary signal/procedure handlers---------------------------------.. function:: signal_handler_t *obs_get_signal_handler(void)   :return: The primary obs signal handler   See :ref:`core_signal_handler_reference` for more information on   core signals.---------------------.. function:: proc_handler_t *obs_get_proc_handler(void)   :return: The primary obs procedure handler.. _core_signal_handler_reference:Core OBS Signals----------------**source_create** (ptr source)   Called when a source has been created.**source_destroy** (ptr source)   Called when a source has been destroyed.**source_remove** (ptr source)   Called when a source has been removed (:c:func:`obs_source_remove()`   has been called on the source).**source_save** (ptr source)   Called when a source is being saved.**source_load** (ptr source)   Called when a source is being loaded.**source_activate** (ptr source)   Called when a source has been activated in the main view (visible on   stream/recording).**source_deactivate** (ptr source)   Called when a source has been deactivated from the main view (no   longer visible on stream/recording).**source_show** (ptr source)   Called when a source is visible on any display and/or on the main   view.**source_hide** (ptr source)   Called when a source is no longer visible on any display and/or on   the main view.**source_rename** (ptr source, string new_name, string prev_name)   Called when a source has been renamed.**source_volume** (ptr source, in out float volume)   Called when a source's volume has changed.**source_transition_start** (ptr source)   Called when a transition has started its transition.**source_transition_video_stop** (ptr source)   Called when a transition has stopped its video transitioning.**source_transition_stop** (ptr source)   Called when a transition has stopped its transition.**channel_change** (int channel, in out ptr source, ptr prev_source)   Called when :c:func:`obs_set_output_source()` has been called.**master_volume** (in out float volume)   Called when the master volume has changed.**hotkey_layout_change** ()   Called when the hotkey layout has changed.**hotkey_register** (ptr hotkey)   Called when a hotkey has been registered.**hotkey_unregister** (ptr hotkey)   Called when a hotkey has been unregistered.**hotkey_bindings_changed** (ptr hotkey)   Called when a hotkey's bindings has changed.---------------------.. _display_reference:Displays--------.. function:: obs_display_t *obs_display_create(const struct gs_init_data *graphics_data)   Adds a new window display linked to the main render pipeline.  This creates   a new swap chain which updates every frame.     *(Important note: do not use more than one display widget within the   hierarchy of the same base window; this will cause presentation   stalls on Macs.)*   :param  graphics_data: The swap chain initialization data   :return:               The new display context, or NULL if failed   Relevant data types used with this function:.. code:: cpp   enum gs_color_format {           [...]           GS_RGBA,           GS_BGRX,           GS_BGRA,           GS_RGBA16F,           GS_RGBA32F,           [...]   };      enum gs_zstencil_format {           GS_ZS_NONE,           GS_Z16,           GS_Z24_S8,           GS_Z32F,           GS_Z32F_S8X24   };      struct gs_window {   #if defined(_WIN32)           void                    *hwnd;   #elif defined(__APPLE__)           __unsafe_unretained id  view;   #elif defined(__linux__) || defined(__FreeBSD__)           uint32_t                id;           void                    *display;   #endif   };      struct gs_init_data {           struct gs_window        window;           uint32_t                cx, cy;           uint32_t                num_backbuffers;           enum gs_color_format    format;           enum gs_zstencil_format zsformat;           uint32_t                adapter;   };---------------------.. function:: void obs_display_destroy(obs_display_t *display)   Destroys a display context.---------------------.. function:: void obs_display_resize(obs_display_t *display, uint32_t cx, uint32_t cy)   Changes the size of a display context.---------------------.. function:: void obs_display_add_draw_callback(obs_display_t *display, void (*draw)(void *param, uint32_t cx, uint32_t cy), void *param)   Adds a draw callback for a display context, which will be called   whenever the display is rendered.     :param  display: The display context   :param  draw:    The draw callback which is called each time a frame                    updates   :param  param:   The user data to be associated with this draw callback---------------------.. function:: void obs_display_remove_draw_callback(obs_display_t *display, void (*draw)(void *param, uint32_t cx, uint32_t cy), void *param)   Removes a draw callback for a display context.---------------------.. function:: void obs_display_set_enabled(obs_display_t *display, bool enable)   Enables/disables a display context.---------------------.. function:: bool obs_display_enabled(obs_display_t *display)   :return: *true* if the display is enabled, *false* otherwise---------------------.. function:: void obs_display_set_background_color(obs_display_t *display, uint32_t color)   Sets the background (clear) color for the display context.
 |