chromium/third_party/blink/renderer/modules/webcodecs/video_frame_rect_util.h

// Copyright 2021 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef THIRD_PARTY_BLINK_RENDERER_MODULES_WEBCODECS_VIDEO_FRAME_RECT_UTIL_H_
#define THIRD_PARTY_BLINK_RENDERER_MODULES_WEBCODECS_VIDEO_FRAME_RECT_UTIL_H_

#include "media/base/video_types.h"
#include "ui/gfx/geometry/rect.h"
#include "ui/gfx/geometry/size.h"

namespace blink {

class DOMRectInit;
class ExceptionState;

// Converts DOMRectInit to gfx::Rect. Validates that all values (including the
// computed |right| and |bottom|) are nonnegative and fit into |coded_size|, and
// that the result is nonempty. |rect_name| is the variable name in error
// messages, eg. "name.x".
gfx::Rect ToGfxRect(const DOMRectInit* rect,
                    const char* rect_name,
                    const gfx::Size& coded_size,
                    ExceptionState& exception_state);

// Checks |rect| x and y for sample alignment in all planes.
bool ValidateOffsetAlignment(media::VideoPixelFormat format,
                             const gfx::Rect& rect,
                             const char* rect_name,
                             ExceptionState& exception_state);

// Computes the dimension of a plane (rounding up).
int PlaneSize(int frame_size, int sample_size);

// Computes the subsampled coordinates of a rect. |frame_rect| must already have
// a sample-aligned offset. The size of the rect is rounded up to the nearest
// sample boundary.
gfx::Rect PlaneRect(gfx::Rect frame_rect, gfx::Size sample_size);

}  // namespace blink

#endif  // THIRD_PARTY_BLINK_RENDERER_MODULES_WEBCODECS_VIDEO_FRAME_RECT_UTIL_H_