[libcamera-devel] [PATCH 3/4] cam: sdl_sink: Support multi-planar formats
Jacopo Mondi
jacopo at jmondi.org
Mon Aug 8 10:28:29 CEST 2022
Hi Laurent
On Sun, Aug 07, 2022 at 05:17:17AM +0300, Laurent Pinchart via libcamera-devel wrote:
> In order to prepare for NV12 support, implement support for multi-planar
> formats in the SDL sink. This mainly consists in passing a vector of
> plane data to the SDLTexture::update() function instead of a single
> value.
>
> Signed-off-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
> ---
> src/cam/sdl_sink.cpp | 21 +++++++++++++--------
> src/cam/sdl_texture.h | 4 +++-
> src/cam/sdl_texture_mjpg.cpp | 4 ++--
> src/cam/sdl_texture_mjpg.h | 2 +-
> src/cam/sdl_texture_yuv.cpp | 4 ++--
> src/cam/sdl_texture_yuv.h | 2 +-
> 6 files changed, 22 insertions(+), 15 deletions(-)
>
> diff --git a/src/cam/sdl_sink.cpp b/src/cam/sdl_sink.cpp
> index 04350bd5365b..9675cf275186 100644
> --- a/src/cam/sdl_sink.cpp
> +++ b/src/cam/sdl_sink.cpp
> @@ -185,16 +185,21 @@ void SDLSink::renderBuffer(FrameBuffer *buffer)
> {
> Image *image = mappedBuffers_[buffer].get();
>
> - /* \todo Implement support for multi-planar formats. */
> - const FrameMetadata::Plane &meta = buffer->metadata().planes()[0];
> + std::vector<Span<const uint8_t>> planes;
You could .reserve() but it's not a big deal
> + unsigned int i = 0;
>
> - Span<uint8_t> data = image->data(0);
> - if (meta.bytesused > data.size())
> - std::cerr << "payload size " << meta.bytesused
> - << " larger than plane size " << data.size()
> - << std::endl;
> + for (const FrameMetadata::Plane &meta : buffer->metadata().planes()) {
I was about to suggest
for (const auto &[i, meta] : utils::enumerate(buffer->metadata().planes())) {
and to use utils::enumerate() I have to:
#include <libcamera/base/utils.h>
Which gives me
In file included from ../include/libcamera/base/utils.h:23,
from ../src/cam/image.h:17,
from ../src/cam/image.cpp:8:
../include/libcamera/base/private.h:21:2: error: #error "Private headers must not be included in the libcamera API"
21 | #error "Private headers must not be included in the libcamera API"
Which is a bit strange as the file includes several headers from the
<libcamera/base/> inclusion path already :/
That apart
Reviewed-by: Jacopo Mondi <jacopo at jmondi.org>
Thanks
j
> + Span<uint8_t> data = image->data(i);
> + if (meta.bytesused > data.size())
> + std::cerr << "payload size " << meta.bytesused
> + << " larger than plane size " << data.size()
> + << std::endl;
>
> - texture_->update(data);
> + planes.push_back(data);
> + i++;
> + }
> +
> + texture_->update(planes);
>
> SDL_RenderClear(renderer_);
> SDL_RenderCopy(renderer_, texture_->get(), nullptr, nullptr);
> diff --git a/src/cam/sdl_texture.h b/src/cam/sdl_texture.h
> index f523fa5ebf51..e4d3fb2bcf39 100644
> --- a/src/cam/sdl_texture.h
> +++ b/src/cam/sdl_texture.h
> @@ -7,6 +7,8 @@
>
> #pragma once
>
> +#include <vector>
> +
> #include <SDL2/SDL.h>
>
> #include "image.h"
> @@ -17,7 +19,7 @@ public:
> SDLTexture(const SDL_Rect &rect, uint32_t pixelFormat, const int pitch);
> virtual ~SDLTexture();
> int create(SDL_Renderer *renderer);
> - virtual void update(libcamera::Span<const uint8_t> data) = 0;
> + virtual void update(const std::vector<libcamera::Span<const uint8_t>> &data) = 0;
> SDL_Texture *get() const { return ptr_; }
>
> protected:
> diff --git a/src/cam/sdl_texture_mjpg.cpp b/src/cam/sdl_texture_mjpg.cpp
> index 7542efd75d96..8dd5ee3eb6bc 100644
> --- a/src/cam/sdl_texture_mjpg.cpp
> +++ b/src/cam/sdl_texture_mjpg.cpp
> @@ -76,8 +76,8 @@ int SDLTextureMJPG::decompress(Span<const uint8_t> data)
> return 0;
> }
>
> -void SDLTextureMJPG::update(Span<const uint8_t> data)
> +void SDLTextureMJPG::update(const std::vector<libcamera::Span<const uint8_t>> &data)
> {
> - decompress(data);
> + decompress(data[0]);
> SDL_UpdateTexture(ptr_, nullptr, rgb_.get(), pitch_);
> }
> diff --git a/src/cam/sdl_texture_mjpg.h b/src/cam/sdl_texture_mjpg.h
> index 5141ed73bf70..814ca79ac193 100644
> --- a/src/cam/sdl_texture_mjpg.h
> +++ b/src/cam/sdl_texture_mjpg.h
> @@ -14,7 +14,7 @@ class SDLTextureMJPG : public SDLTexture
> public:
> SDLTextureMJPG(const SDL_Rect &rect);
>
> - void update(libcamera::Span<const uint8_t> data) override;
> + void update(const std::vector<libcamera::Span<const uint8_t>> &data) override;
>
> private:
> int decompress(libcamera::Span<const uint8_t> data);
> diff --git a/src/cam/sdl_texture_yuv.cpp b/src/cam/sdl_texture_yuv.cpp
> index 07df4961a1ab..a5721182a68b 100644
> --- a/src/cam/sdl_texture_yuv.cpp
> +++ b/src/cam/sdl_texture_yuv.cpp
> @@ -14,7 +14,7 @@ SDLTextureYUYV::SDLTextureYUYV(const SDL_Rect &rect, unsigned int stride)
> {
> }
>
> -void SDLTextureYUYV::update(Span<const uint8_t> data)
> +void SDLTextureYUYV::update(const std::vector<libcamera::Span<const uint8_t>> &data)
> {
> - SDL_UpdateTexture(ptr_, &rect_, data.data(), pitch_);
> + SDL_UpdateTexture(ptr_, &rect_, data[0].data(), pitch_);
> }
> diff --git a/src/cam/sdl_texture_yuv.h b/src/cam/sdl_texture_yuv.h
> index 81e51381ec62..c9130298b91d 100644
> --- a/src/cam/sdl_texture_yuv.h
> +++ b/src/cam/sdl_texture_yuv.h
> @@ -13,5 +13,5 @@ class SDLTextureYUYV : public SDLTexture
> {
> public:
> SDLTextureYUYV(const SDL_Rect &rect, unsigned int stride);
> - void update(libcamera::Span<const uint8_t> data) override;
> + void update(const std::vector<libcamera::Span<const uint8_t>> &data) override;
> };
> --
> Regards,
>
> Laurent Pinchart
>
More information about the libcamera-devel
mailing list