blob: 5e52eb740024013307880ea03c5f1314cf195bd1 [file] [log] [blame]
/*
* Copyright 2021 Google LLC
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef SkYUVAInfoLocation_DEFINED
#define SkYUVAInfoLocation_DEFINED
#include "include/core/SkColor.h"
#include "include/core/SkYUVAInfo.h"
#include <algorithm>
/**
* The location of Y, U, V, or A values within the planes described by SkYUVAInfo. Computed from a
* SkYUVAInfo and the set of channels present in a set of pixmaps/textures.
*/
struct SkYUVAInfo::YUVALocation {
/** The index of the plane where the Y, U, V, or A value is to be found. */
int fPlane = -1;
/** The channel in the plane that contains the Y, U, V, or A value. */
SkColorChannel fChannel = SkColorChannel::kA;
bool operator==(const YUVALocation& that) const {
return fPlane == that.fPlane && fChannel == that.fChannel;
}
bool operator!=(const YUVALocation& that) const { return !(*this == that); }
static bool AreValidLocations(const SkYUVAInfo::YUVALocations& locations,
int* numPlanes = nullptr) {
int maxSlotUsed = -1;
bool used[SkYUVAInfo::kMaxPlanes] = {};
bool valid = true;
for (int i = 0; i < SkYUVAInfo::kYUVAChannelCount; ++i) {
if (locations[i].fPlane < 0) {
if (i != SkYUVAInfo::YUVAChannels::kA) {
valid = false; // only the 'A' plane can be omitted
}
} else if (locations[i].fPlane >= SkYUVAInfo::kMaxPlanes) {
valid = false; // A maximum of four input textures is allowed
} else {
maxSlotUsed = std::max(locations[i].fPlane, maxSlotUsed);
used[i] = true;
}
}
// All the used slots should be packed starting at 0 with no gaps
for (int i = 0; i <= maxSlotUsed; ++i) {
if (!used[i]) {
valid = false;
}
}
if (numPlanes) {
*numPlanes = valid ? maxSlotUsed + 1 : 0;
}
return valid;
}
};
#endif