From 26a029d407be480d791972afb5975cf62c9360a6 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Fri, 19 Apr 2024 02:47:55 +0200 Subject: Adding upstream version 124.0.1. Signed-off-by: Daniel Baumann --- gfx/2d/PathCairo.h | 101 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 101 insertions(+) create mode 100644 gfx/2d/PathCairo.h (limited to 'gfx/2d/PathCairo.h') diff --git a/gfx/2d/PathCairo.h b/gfx/2d/PathCairo.h new file mode 100644 index 0000000000..1e58ef1512 --- /dev/null +++ b/gfx/2d/PathCairo.h @@ -0,0 +1,101 @@ +/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* vim: set ts=8 sts=2 et sw=2 tw=80: */ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +#ifndef MOZILLA_GFX_PATH_CAIRO_H_ +#define MOZILLA_GFX_PATH_CAIRO_H_ + +#include "2D.h" +#include "cairo.h" +#include + +namespace mozilla { +namespace gfx { + +class PathCairo; + +class PathBuilderCairo : public PathBuilder { + public: + MOZ_DECLARE_REFCOUNTED_VIRTUAL_TYPENAME(PathBuilderCairo, override) + + explicit PathBuilderCairo(FillRule aFillRule); + + void MoveTo(const Point& aPoint) override; + void LineTo(const Point& aPoint) override; + void BezierTo(const Point& aCP1, const Point& aCP2, + const Point& aCP3) override; + void QuadraticBezierTo(const Point& aCP1, const Point& aCP2) override; + void Close() override; + void Arc(const Point& aOrigin, float aRadius, float aStartAngle, + float aEndAngle, bool aAntiClockwise = false) override; + already_AddRefed Finish() override; + + BackendType GetBackendType() const override { return BackendType::CAIRO; } + + bool IsActive() const override { return !mPathData.empty(); } + + static already_AddRefed Create(FillRule aFillRule); + + private: // data + friend class PathCairo; + + FillRule mFillRule; + std::vector mPathData; +}; + +class PathCairo : public Path { + public: + MOZ_DECLARE_REFCOUNTED_VIRTUAL_TYPENAME(PathCairo, override) + + PathCairo(FillRule aFillRule, std::vector& aPathData, + const Point& aCurrentPoint, const Point& aBeginPoint); + explicit PathCairo(cairo_t* aContext); + virtual ~PathCairo(); + + BackendType GetBackendType() const override { return BackendType::CAIRO; } + + already_AddRefed CopyToBuilder( + FillRule aFillRule) const override; + already_AddRefed TransformedCopyToBuilder( + const Matrix& aTransform, FillRule aFillRule) const override; + + bool ContainsPoint(const Point& aPoint, + const Matrix& aTransform) const override; + + bool StrokeContainsPoint(const StrokeOptions& aStrokeOptions, + const Point& aPoint, + const Matrix& aTransform) const override; + + Rect GetBounds(const Matrix& aTransform = Matrix()) const override; + + Rect GetStrokedBounds(const StrokeOptions& aStrokeOptions, + const Matrix& aTransform = Matrix()) const override; + + void StreamToSink(PathSink* aSink) const override; + + FillRule GetFillRule() const override { return mFillRule; } + + void SetPathOnContext(cairo_t* aContext) const; + + void AppendPathToBuilder(PathBuilderCairo* aBuilder, + const Matrix* aTransform = nullptr) const; + + bool IsEmpty() const override; + + private: + void EnsureContainingContext(const Matrix& aTransform) const; + + FillRule mFillRule; + std::vector mPathData; + mutable cairo_t* mContainingContext; + mutable Matrix mContainingTransform; + Point mCurrentPoint; + Point mBeginPoint; +}; + +} // namespace gfx +} // namespace mozilla + +#endif /* MOZILLA_GFX_PATH_CAIRO_H_ */ -- cgit v1.2.3