X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;ds=sidebyside;f=decklink_capture.h;h=59c3b02e6096528098e315a64d98034ecfa1b2cf;hb=b1b7b5477664b3871f25e4e990fa8835952303d6;hp=c591cdc9867424fb84e58271f26afa4402e18679;hpb=e3bb32331aa8f0c63a43fb5434082134a6fbed12;p=nageru diff --git a/decklink_capture.h b/decklink_capture.h index c591cdc..59c3b02 100644 --- a/decklink_capture.h +++ b/decklink_capture.h @@ -17,7 +17,7 @@ class IDeckLinkDisplayMode; class DeckLinkCapture : public CaptureInterface, IDeckLinkInputCallback { public: - DeckLinkCapture(IDeckLink *card, int card_index); + DeckLinkCapture(IDeckLink *card, int card_index); // Takes ownership of . ~DeckLinkCapture(); // IDeckLinkInputCallback. @@ -36,6 +36,9 @@ public: void set_video_frame_allocator(FrameAllocator *allocator) override { video_frame_allocator = allocator; + if (owned_video_frame_allocator.get() != allocator) { + owned_video_frame_allocator.reset(); + } } FrameAllocator *get_video_frame_allocator() override @@ -47,6 +50,9 @@ public: void set_audio_frame_allocator(FrameAllocator *allocator) override { audio_frame_allocator = allocator; + if (owned_audio_frame_allocator.get() != allocator) { + owned_audio_frame_allocator.reset(); + } } FrameAllocator *get_audio_frame_allocator() override @@ -71,15 +77,30 @@ public: return description; } - void configure_card() override {} + void configure_card() override; void start_bm_capture() override; void stop_dequeue_thread() override; + std::map get_available_video_modes() const override { return video_modes; } + void set_video_mode(uint32_t video_mode_id) override; + uint32_t get_current_video_mode() const override { return current_video_mode; } + + std::map get_available_video_inputs() const override { return video_inputs; } + void set_video_input(uint32_t video_input_id) override; + uint32_t get_current_video_input() const override { return current_video_input; } + + std::map get_available_audio_inputs() const override { return audio_inputs; } + void set_audio_input(uint32_t audio_input_id) override; + uint32_t get_current_audio_input() const override { return current_audio_input; } + private: + void set_video_mode_no_restart(uint32_t video_mode_id); + std::atomic refcount{1}; bool done_init = false; std::string description; uint16_t timecode = 0; + int card_index; bool has_dequeue_callbacks = false; std::function dequeue_init_callback = nullptr; @@ -87,11 +108,25 @@ private: FrameAllocator *video_frame_allocator = nullptr; FrameAllocator *audio_frame_allocator = nullptr; + std::unique_ptr owned_video_frame_allocator; + std::unique_ptr owned_audio_frame_allocator; frame_callback_t frame_callback = nullptr; + IDeckLinkConfiguration *config = nullptr; + + IDeckLink *card = nullptr; IDeckLinkInput *input = nullptr; BMDTimeValue frame_duration; BMDTimeScale time_scale; + + std::map video_modes; + BMDDisplayMode current_video_mode; + + std::map video_inputs; + BMDVideoConnection current_video_input; + + std::map audio_inputs; + BMDAudioConnection current_audio_input; }; #endif // !defined(_DECKLINK_CAPTURE_H)