Sunshine master
Self-hosted game stream host for Moonlight.
pipewire::pipewire_display_t Class Referenceabstract
Inheritance diagram for pipewire::pipewire_display_t:
[legend]
Collaboration diagram for pipewire::pipewire_display_t:
[legend]

Public Member Functions

std::shared_ptr< platf::img_talloc_img () override
 
platf::capture_e capture (const push_captured_image_cb_t &push_captured_image_cb, const pull_free_image_cb_t &pull_free_image_cb, bool *cursor) override
 Capture a frame.
 
virtual bool check_stream_dead (platf::capture_e &out_status)
 
virtual int configure_stream (const std::string &display_name, int &out_pipewire_fd, uint32_t &out_pipewire_node, uint64_t &out_pipewire_objectserial)=0
 Configure the pipewire stream.
 
int dummy_img (platf::img_t *img) override
 
bool get_hdr_metadata (SS_HDR_METADATA &metadata) override
 
int init (platf::mem_type_e hwdevice_type, const std::string &display_name, const ::video::config_t &config)
 
bool is_hdr () override
 
std::unique_ptr< platf::avcodec_encode_device_tmake_avcodec_encode_device (platf::pix_fmt_e pix_fmt) override
 
platf::capture_e snapshot (const pull_free_image_cb_t &pull_free_image_cb, std::shared_ptr< platf::img_t > &img_out, std::chrono::milliseconds timeout, bool show_cursor)
 
virtual void verify_and_update_display_parameters ()
 Verify and update display parameters for logical dimensions, desktop dimensions and logical desktop dimensions (default is adapted from wlgrab)
 
- Public Member Functions inherited from platf::display_t
virtual bool is_codec_supported (std::string_view name, const ::video::config_t &config)
 Check that a given codec is supported by the display device.
 
virtual std::unique_ptr< nvenc_encode_device_tmake_nvenc_encode_device (pix_fmt_e pix_fmt)
 

Static Public Member Functions

static bool init_pipewire_and_check_hwdevice_type (platf::mem_type_e hwdevice_type)
 

Protected Attributes

pipewire_t pipewire
 
std::shared_ptr< shared_state_tshared_state
 
- Protected Attributes inherited from platf::display_t
logging::time_delta_periodic_logger sleep_overshoot_logger = {debug, "Frame capture sleep overshoot"}
 

Additional Inherited Members

- Public Types inherited from platf::display_t
using pull_free_image_cb_t = std::function<bool(std::shared_ptr<img_t> &img_out)>
 Get free image from pool. Calls must be synchronized. Blocks until there is free image in the pool or capture is interrupted.
 
using push_captured_image_cb_t = std::function<bool(std::shared_ptr<img_t> &&img, bool frame_captured)>
 Callback for when a new image is ready. When display has a new image ready or a timeout occurs, this callback will be called with the image. If a frame was captured, frame_captured will be true. If a timeout occurred, it will be false.
 
- Public Attributes inherited from platf::display_t
int env_height {0}
 
int env_logical_height {0}
 
int env_logical_width {0}
 
int env_width {0}
 
int height {0}
 
int logical_height {0}
 
int logical_width {0}
 
int offset_x {0}
 
int offset_y {0}
 
int width {0}
 

Member Function Documentation

◆ alloc_img()

std::shared_ptr< platf::img_t > pipewire::pipewire_display_t::alloc_img ( )
inlineoverridevirtual

Implements platf::display_t.

◆ capture()

platf::capture_e pipewire::pipewire_display_t::capture ( const push_captured_image_cb_t & push_captured_image_cb,
const pull_free_image_cb_t & pull_free_image_cb,
bool * cursor )
inlineoverridevirtual

Capture a frame.

Parameters
push_captured_image_cbThe callback that is called with captured image, must be called from the same thread as capture()
pull_free_image_cbCapture backends call this callback to get empty image from the pool. If backend uses multiple threads, calls to this callback must be synchronized. Calls to this callback and push_captured_image_cb must be synchronized as well.
cursorA pointer to the flag that indicates whether the cursor should be captured as well.
Return values
capture_e::okWhen stopping
capture_e::errorOn error
capture_e::reinitWhen need of reinitialization

Implements platf::display_t.

◆ configure_stream()

virtual int pipewire::pipewire_display_t::configure_stream ( const std::string & display_name,
int & out_pipewire_fd,
uint32_t & out_pipewire_node,
uint64_t & out_pipewire_objectserial )
pure virtual

Configure the pipewire stream.

Parameters
display_nameprovide a stream for this display_name
out_pipewire_fdset to the pipewire fd for the stream during function call (or -1 for using the local context)
out_pipewire_nodeset to the pipewire node of the stream during function call (or PW_ID_ANY to refer to object_serial)
out_pipewire_objectserialset the pipewire object serial of the stream during function call
Returns
0 if the stream successfully configured

Implemented in kwin::kwin_t, and portal::portal_t.

◆ dummy_img()

int pipewire::pipewire_display_t::dummy_img ( platf::img_t * img)
inlineoverridevirtual

Implements platf::display_t.

◆ get_hdr_metadata()

bool pipewire::pipewire_display_t::get_hdr_metadata ( SS_HDR_METADATA & metadata)
inlineoverridevirtual

Reimplemented from platf::display_t.

◆ is_hdr()

bool pipewire::pipewire_display_t::is_hdr ( )
inlineoverridevirtual

Reimplemented from platf::display_t.

◆ make_avcodec_encode_device()

std::unique_ptr< platf::avcodec_encode_device_t > pipewire::pipewire_display_t::make_avcodec_encode_device ( platf::pix_fmt_e pix_fmt)
inlineoverridevirtual

Reimplemented from platf::display_t.


The documentation for this class was generated from the following file: