obs-service.h 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. /******************************************************************************
  2. Copyright (C) 2013-2014 by Hugh Bailey <[email protected]>
  3. This program is free software: you can redistribute it and/or modify
  4. it under the terms of the GNU General Public License as published by
  5. the Free Software Foundation, either version 2 of the License, or
  6. (at your option) any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU General Public License for more details.
  11. You should have received a copy of the GNU General Public License
  12. along with this program. If not, see <http://www.gnu.org/licenses/>.
  13. ******************************************************************************/
  14. #pragma once
  15. /**
  16. * @file
  17. * @brief header for modules implementing services.
  18. *
  19. * Services are modules that implement provider specific settings for outputs.
  20. */
  21. #ifdef __cplusplus
  22. extern "C" {
  23. #endif
  24. struct obs_service_resolution {
  25. int cx;
  26. int cy;
  27. };
  28. struct obs_service_info {
  29. /* required */
  30. const char *id;
  31. const char *(*get_name)(void *type_data);
  32. void *(*create)(obs_data_t *settings, obs_service_t *service);
  33. void (*destroy)(void *data);
  34. /* optional */
  35. void (*activate)(void *data, obs_data_t *settings);
  36. void (*deactivate)(void *data);
  37. void (*update)(void *data, obs_data_t *settings);
  38. void (*get_defaults)(obs_data_t *settings);
  39. obs_properties_t *(*get_properties)(void *data);
  40. /**
  41. * Called when getting ready to start up an output, before the encoders
  42. * and output are initialized
  43. *
  44. * @param data Internal service data
  45. * @param output Output context
  46. * @return true to allow the output to start up,
  47. * false to prevent output from starting up
  48. */
  49. bool (*initialize)(void *data, obs_output_t *output);
  50. const char *(*get_url)(void *data);
  51. const char *(*get_key)(void *data);
  52. const char *(*get_username)(void *data);
  53. const char *(*get_password)(void *data);
  54. bool (*deprecated_1)();
  55. void (*apply_encoder_settings)(void *data,
  56. obs_data_t *video_encoder_settings,
  57. obs_data_t *audio_encoder_settings);
  58. void *type_data;
  59. void (*free_type_data)(void *type_data);
  60. const char *(*get_output_type)(void *data);
  61. void (*get_supported_resolutions)(
  62. void *data, struct obs_service_resolution **resolutions,
  63. size_t *count);
  64. void (*get_max_fps)(void *data, int *fps);
  65. void (*get_max_bitrate)(void *data, int *video_bitrate,
  66. int *audio_bitrate);
  67. const char **(*get_supported_video_codecs)(void *data);
  68. };
  69. EXPORT void obs_register_service_s(const struct obs_service_info *info,
  70. size_t size);
  71. #define obs_register_service(info) \
  72. obs_register_service_s(info, sizeof(struct obs_service_info))
  73. #ifdef __cplusplus
  74. }
  75. #endif