obs-encoder.c 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. /******************************************************************************
  2. Copyright (C) 2013 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. #include "obs.h"
  15. #include "obs-internal.h"
  16. bool load_encoder_info(void *module, const char *module_name,
  17. const char *id, struct encoder_info *info)
  18. {
  19. LOAD_MODULE_SUBFUNC(getname, true);
  20. LOAD_MODULE_SUBFUNC(create, true);
  21. LOAD_MODULE_SUBFUNC(destroy, true);
  22. LOAD_MODULE_SUBFUNC(update, true);
  23. LOAD_MODULE_SUBFUNC(reset, true);
  24. LOAD_MODULE_SUBFUNC(encode, true);
  25. LOAD_MODULE_SUBFUNC(getheader, true);
  26. LOAD_MODULE_SUBFUNC(setbitrate, false);
  27. LOAD_MODULE_SUBFUNC(request_keyframe, false);
  28. info->id = id;
  29. return true;
  30. }
  31. static inline struct encoder_info *get_encoder_info(const char *id)
  32. {
  33. for (size_t i = 0; i < obs->encoder_types.num; i++) {
  34. struct encoder_info *info = obs->encoder_types.array+i;
  35. if (strcmp(info->id, id) == 0)
  36. return info;
  37. }
  38. return NULL;
  39. }
  40. const char *obs_encoder_getdisplayname(const char *id, const char *locale)
  41. {
  42. struct encoder_info *ei = get_encoder_info(id);
  43. if (!ei)
  44. return NULL;
  45. return ei->getname(locale);
  46. }
  47. obs_encoder_t obs_encoder_create(const char *id, const char *name,
  48. const char *settings)
  49. {
  50. struct obs_encoder *encoder;
  51. struct encoder_info *ei = get_encoder_info(id);
  52. if (!ei)
  53. return NULL;
  54. encoder = bmalloc(sizeof(struct obs_encoder));
  55. memset(encoder, 0, sizeof(struct obs_encoder));
  56. encoder->callbacks = *ei;
  57. if (pthread_mutex_init(&encoder->data_callbacks_mutex, NULL) != 0) {
  58. bfree(encoder);
  59. return NULL;
  60. }
  61. encoder->data = ei->create(settings, encoder);
  62. if (!encoder->data) {
  63. pthread_mutex_destroy(&encoder->data_callbacks_mutex);
  64. bfree(encoder);
  65. return NULL;
  66. }
  67. dstr_copy(&encoder->settings, settings);
  68. pthread_mutex_lock(&obs->data.encoders_mutex);
  69. da_push_back(obs->data.encoders, &encoder);
  70. pthread_mutex_unlock(&obs->data.encoders_mutex);
  71. return encoder;
  72. }
  73. void obs_encoder_destroy(obs_encoder_t encoder)
  74. {
  75. if (encoder) {
  76. pthread_mutex_lock(&obs->data.encoders_mutex);
  77. da_erase_item(obs->data.encoders, &encoder);
  78. pthread_mutex_unlock(&obs->data.encoders_mutex);
  79. encoder->callbacks.destroy(encoder->data);
  80. dstr_free(&encoder->settings);
  81. bfree(encoder);
  82. }
  83. }
  84. void obs_encoder_update(obs_encoder_t encoder, const char *settings)
  85. {
  86. encoder->callbacks.update(encoder->data, settings);
  87. }
  88. bool obs_encoder_reset(obs_encoder_t encoder)
  89. {
  90. return encoder->callbacks.reset(encoder->data);
  91. }
  92. bool obs_encoder_encode(obs_encoder_t encoder, void *frames, size_t size)
  93. {
  94. /* TODO */
  95. //encoder->callbacks.encode(encoder->data, frames, size, packets);
  96. return false;
  97. }
  98. int obs_encoder_getheader(obs_encoder_t encoder,
  99. struct encoder_packet **packets)
  100. {
  101. return encoder->callbacks.getheader(encoder, packets);
  102. }
  103. bool obs_encoder_setbitrate(obs_encoder_t encoder, uint32_t bitrate,
  104. uint32_t buffersize)
  105. {
  106. if (encoder->callbacks.setbitrate)
  107. return encoder->callbacks.setbitrate(encoder->data, bitrate,
  108. buffersize);
  109. return false;
  110. }
  111. bool obs_encoder_request_keyframe(obs_encoder_t encoder)
  112. {
  113. if (encoder->callbacks.request_keyframe)
  114. return encoder->callbacks.request_keyframe(encoder->data);
  115. return false;
  116. }
  117. const char *obs_encoder_get_settings(obs_encoder_t encoder)
  118. {
  119. return encoder->settings.array;
  120. }
  121. void obs_encoder_save_settings(obs_encoder_t encoder, const char *settings)
  122. {
  123. dstr_copy(&encoder->settings, settings);
  124. }