X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=decklink_capture.h;h=69ab08e3cd48285e399c4a57d0bf5af932060003;hb=cf939d7e65533771a8f242f0283c7c55d91a5100;hp=c591cdc9867424fb84e58271f26afa4402e18679;hpb=e3bb32331aa8f0c63a43fb5434082134a6fbed12;p=nageru diff --git a/decklink_capture.h b/decklink_capture.h index c591cdc..69ab08e 100644 --- a/decklink_capture.h +++ b/decklink_capture.h @@ -71,15 +71,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; @@ -89,9 +104,20 @@ private: FrameAllocator *audio_frame_allocator = nullptr; frame_callback_t frame_callback = nullptr; + IDeckLinkConfiguration *config = 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)