2013-08-25 07:19:42 +00:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* 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/. */
|
|
|
|
|
2015-05-15 03:52:05 +00:00
|
|
|
#ifndef mozilla_image_Orientation_h
|
|
|
|
#define mozilla_image_Orientation_h
|
2013-08-25 07:19:42 +00:00
|
|
|
|
|
|
|
#include <stdint.h>
|
2021-10-06 14:41:17 +00:00
|
|
|
#include "mozilla/gfx/Rect.h"
|
2013-08-25 07:19:42 +00:00
|
|
|
|
|
|
|
namespace mozilla {
|
2021-10-06 14:41:17 +00:00
|
|
|
|
|
|
|
// Pixel values in an image considering orientation metadata, such as the size
|
|
|
|
// of an image as seen by consumers of the image.
|
|
|
|
//
|
|
|
|
// Any public methods on RasterImage that use untyped units are interpreted as
|
|
|
|
// oriented pixels.
|
|
|
|
struct OrientedPixel {};
|
|
|
|
template <>
|
|
|
|
struct IsPixel<OrientedPixel> : std::true_type {};
|
|
|
|
typedef gfx::IntPointTyped<OrientedPixel> OrientedIntPoint;
|
|
|
|
typedef gfx::IntSizeTyped<OrientedPixel> OrientedIntSize;
|
|
|
|
typedef gfx::IntRectTyped<OrientedPixel> OrientedIntRect;
|
|
|
|
|
|
|
|
// Pixel values in an image ignoring orientation metadata, such as are stored
|
|
|
|
// in surfaces and the raw pixel data in the image.
|
|
|
|
struct UnorientedPixel {};
|
|
|
|
template <>
|
|
|
|
struct IsPixel<UnorientedPixel> : std::true_type {};
|
|
|
|
typedef gfx::IntPointTyped<UnorientedPixel> UnorientedIntPoint;
|
|
|
|
typedef gfx::IntSizeTyped<UnorientedPixel> UnorientedIntSize;
|
|
|
|
typedef gfx::IntRectTyped<UnorientedPixel> UnorientedIntRect;
|
|
|
|
|
2013-08-25 07:19:42 +00:00
|
|
|
namespace image {
|
|
|
|
|
2015-01-25 22:22:07 +00:00
|
|
|
enum class Angle : uint8_t { D0, D90, D180, D270 };
|
2013-08-25 07:19:42 +00:00
|
|
|
|
2015-01-25 22:22:07 +00:00
|
|
|
enum class Flip : uint8_t { Unflipped, Horizontal };
|
2013-08-25 07:19:42 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* A struct that describes an image's orientation as a rotation optionally
|
|
|
|
* followed by a reflection. This may be used to be indicate an image's inherent
|
|
|
|
* orientation or a desired orientation for the image.
|
2020-04-17 02:57:32 +00:00
|
|
|
*
|
|
|
|
* When flipFirst = true, this indicates that the reflection is applied before
|
|
|
|
* the rotation. (This is used by OrientedImage to represent the inverse of an
|
|
|
|
* underlying image's Orientation.)
|
2013-08-25 07:19:42 +00:00
|
|
|
*/
|
|
|
|
struct Orientation {
|
2014-12-05 23:58:00 +00:00
|
|
|
explicit Orientation(Angle aRotation = Angle::D0,
|
2020-04-17 02:57:32 +00:00
|
|
|
Flip aFlip = Flip::Unflipped, bool aFlipFirst = false)
|
|
|
|
: rotation(aRotation), flip(aFlip), flipFirst(aFlipFirst) {}
|
|
|
|
|
|
|
|
Orientation Reversed() const {
|
|
|
|
return Orientation(InvertAngle(rotation), flip, !flipFirst);
|
|
|
|
}
|
2013-08-25 07:19:42 +00:00
|
|
|
|
|
|
|
bool IsIdentity() const {
|
|
|
|
return (rotation == Angle::D0) && (flip == Flip::Unflipped);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool SwapsWidthAndHeight() const {
|
|
|
|
return (rotation == Angle::D90) || (rotation == Angle::D270);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool operator==(const Orientation& aOther) const {
|
2020-04-17 02:57:32 +00:00
|
|
|
return rotation == aOther.rotation && flip == aOther.flip &&
|
|
|
|
flipFirst == aOther.flipFirst;
|
2013-08-25 07:19:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
bool operator!=(const Orientation& aOther) const {
|
|
|
|
return !(*this == aOther);
|
|
|
|
}
|
|
|
|
|
2021-10-06 14:41:17 +00:00
|
|
|
OrientedIntSize ToOriented(const UnorientedIntSize& aSize) const {
|
|
|
|
if (SwapsWidthAndHeight()) {
|
|
|
|
return OrientedIntSize(aSize.height, aSize.width);
|
|
|
|
} else {
|
|
|
|
return OrientedIntSize(aSize.width, aSize.height);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
UnorientedIntSize ToUnoriented(const OrientedIntSize& aSize) const {
|
|
|
|
if (SwapsWidthAndHeight()) {
|
|
|
|
return UnorientedIntSize(aSize.height, aSize.width);
|
|
|
|
} else {
|
|
|
|
return UnorientedIntSize(aSize.width, aSize.height);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-04-17 02:57:30 +00:00
|
|
|
static Angle InvertAngle(Angle aAngle) {
|
|
|
|
switch (aAngle) {
|
|
|
|
case Angle::D90:
|
|
|
|
return Angle::D270;
|
|
|
|
case Angle::D270:
|
|
|
|
return Angle::D90;
|
|
|
|
default:
|
|
|
|
return aAngle;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-08-25 07:19:42 +00:00
|
|
|
Angle rotation;
|
|
|
|
Flip flip;
|
2020-04-17 02:57:32 +00:00
|
|
|
bool flipFirst;
|
2013-08-25 07:19:42 +00:00
|
|
|
};
|
|
|
|
|
2015-03-23 23:59:00 +00:00
|
|
|
} // namespace image
|
|
|
|
} // namespace mozilla
|
2013-08-25 07:19:42 +00:00
|
|
|
|
2015-05-15 03:52:05 +00:00
|
|
|
#endif // mozilla_image_Orientation_h
|