Update StarImageProcessing.cpp

This commit is contained in:
Kae 2024-12-27 21:54:59 +11:00
parent 8f1cadbbf2
commit 45c89cefb6
2 changed files with 11 additions and 18 deletions

View File

@ -10,11 +10,7 @@
namespace Star { namespace Star {
Image scaleNearest(Image const& srcImage, Vec2F scale) { Image scaleNearest(Image const& srcImage, Vec2F const& scale) {
if (scale[0] < 0.0f || scale[1] < 0.0f) {
Logger::warn("Negative scale in scaleNearest({})", scale);
scale = scale.piecewiseMax(Vec2F::filled(0.f));
}
Vec2U srcSize = srcImage.size(); Vec2U srcSize = srcImage.size();
Vec2U destSize = Vec2U::round(vmult(Vec2F(srcSize), scale)); Vec2U destSize = Vec2U::round(vmult(Vec2F(srcSize), scale));
destSize[0] = max(destSize[0], 1u); destSize[0] = max(destSize[0], 1u);
@ -29,11 +25,7 @@ Image scaleNearest(Image const& srcImage, Vec2F scale) {
return destImage; return destImage;
} }
Image scaleBilinear(Image const& srcImage, Vec2F scale) { Image scaleBilinear(Image const& srcImage, Vec2F const& scale) {
if (scale[0] < 0.0f || scale[1] < 0.0f) {
Logger::warn("Negative scale in scaleBilinear({})", scale);
scale = scale.piecewiseMax(Vec2F::filled(0.f));
}
Vec2U srcSize = srcImage.size(); Vec2U srcSize = srcImage.size();
Vec2U destSize = Vec2U::round(vmult(Vec2F(srcSize), scale)); Vec2U destSize = Vec2U::round(vmult(Vec2F(srcSize), scale));
destSize[0] = max(destSize[0], 1u); destSize[0] = max(destSize[0], 1u);
@ -57,11 +49,7 @@ Image scaleBilinear(Image const& srcImage, Vec2F scale) {
return destImage; return destImage;
} }
Image scaleBicubic(Image const& srcImage, Vec2F scale) { Image scaleBicubic(Image const& srcImage, Vec2F const& scale) {
if (scale[0] < 0.0f || scale[1] < 0.0f) {
Logger::warn("Negative scale in scaleBicubic({})", scale);
scale = scale.piecewiseMax(Vec2F::filled(0.f));
}
Vec2U srcSize = srcImage.size(); Vec2U srcSize = srcImage.size();
Vec2U destSize = Vec2U::round(vmult(Vec2F(srcSize), scale)); Vec2U destSize = Vec2U::round(vmult(Vec2F(srcSize), scale));
destSize[0] = max(destSize[0], 1u); destSize[0] = max(destSize[0], 1u);
@ -631,6 +619,11 @@ void processImageOperation(ImageOperation const& operation, Image& image, ImageR
image = borderImage; image = borderImage;
} else if (auto op = operation.ptr<ScaleImageOperation>()) { } else if (auto op = operation.ptr<ScaleImageOperation>()) {
auto scale = op->scale;
if (scale[0] < 0.0f || scale[1] < 0.0f) {
Logger::warn("Negative scale in ScaleImageOperation ({})", scale);
scale = scale.piecewiseMax(Vec2F::filled(0.f));
}
if (op->mode == ScaleImageOperation::Nearest) if (op->mode == ScaleImageOperation::Nearest)
image = scaleNearest(image, op->scale); image = scaleNearest(image, op->scale);
else if (op->mode == ScaleImageOperation::Bilinear) else if (op->mode == ScaleImageOperation::Bilinear)

View File

@ -10,9 +10,9 @@ STAR_CLASS(Image);
STAR_EXCEPTION(ImageOperationException, StarException); STAR_EXCEPTION(ImageOperationException, StarException);
Image scaleNearest(Image const& srcImage, Vec2F scale); Image scaleNearest(Image const& srcImage, Vec2F const& scale);
Image scaleBilinear(Image const& srcImage, Vec2F scale); Image scaleBilinear(Image const& srcImage, Vec2F const& scale);
Image scaleBicubic(Image const& srcImage, Vec2F scale); Image scaleBicubic(Image const& srcImage, Vec2F const& scale);
StringList colorDirectivesFromConfig(JsonArray const& directives); StringList colorDirectivesFromConfig(JsonArray const& directives);
String paletteSwapDirectivesFromConfig(Json const& swaps); String paletteSwapDirectivesFromConfig(Json const& swaps);