mirror of
https://github.com/ZDoom/gzdoom.git
synced 2024-11-24 13:01:48 +00:00
- added xBRZ files.
This commit is contained in:
parent
4a80f8e4ed
commit
3ae2e77512
6 changed files with 2878 additions and 0 deletions
1229
src/gl/xbr/xbrz.cpp
Normal file
1229
src/gl/xbr/xbrz.cpp
Normal file
File diff suppressed because it is too large
Load diff
102
src/gl/xbr/xbrz.h
Normal file
102
src/gl/xbr/xbrz.h
Normal file
|
@ -0,0 +1,102 @@
|
||||||
|
// ****************************************************************************
|
||||||
|
// * This file is part of the HqMAME project. It is distributed under *
|
||||||
|
// * GNU General Public License: http://www.gnu.org/licenses/gpl-3.0 *
|
||||||
|
// * Copyright (C) Zenju (zenju AT gmx DOT de) - All Rights Reserved *
|
||||||
|
// * *
|
||||||
|
// * Additionally and as a special exception, the author gives permission *
|
||||||
|
// * to link the code of this program with the MAME library (or with modified *
|
||||||
|
// * versions of MAME that use the same license as MAME), and distribute *
|
||||||
|
// * linked combinations including the two. You must obey the GNU General *
|
||||||
|
// * Public License in all respects for all of the code used other than MAME. *
|
||||||
|
// * If you modify this file, you may extend this exception to your version *
|
||||||
|
// * of the file, but you are not obligated to do so. If you do not wish to *
|
||||||
|
// * do so, delete this exception statement from your version. *
|
||||||
|
// * *
|
||||||
|
// * An explicit permission was granted to use xBRZ in combination with ZDoom *
|
||||||
|
// * and derived projects as long as it is used for non-commercial purposes. *
|
||||||
|
// * *
|
||||||
|
// * Backported to C++98 by Alexey Lysiuk *
|
||||||
|
// ****************************************************************************
|
||||||
|
|
||||||
|
#ifndef XBRZ_HEADER_3847894708239054
|
||||||
|
#define XBRZ_HEADER_3847894708239054
|
||||||
|
|
||||||
|
#include <cstddef> //size_t
|
||||||
|
#include <stdint.h> //uint32_t
|
||||||
|
#include <limits>
|
||||||
|
#include "xbrz_config.h"
|
||||||
|
|
||||||
|
namespace xbrz
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
-------------------------------------------------------------------------
|
||||||
|
| xBRZ: "Scale by rules" - high quality image upscaling filter by Zenju |
|
||||||
|
-------------------------------------------------------------------------
|
||||||
|
using a modified approach of xBR:
|
||||||
|
http://board.byuu.org/viewtopic.php?f=10&t=2248
|
||||||
|
- new rule set preserving small image features
|
||||||
|
- highly optimized for performance
|
||||||
|
- support alpha channel
|
||||||
|
- support multithreading
|
||||||
|
- support 64-bit architectures
|
||||||
|
- support processing image slices
|
||||||
|
- support scaling up to 6xBRZ
|
||||||
|
*/
|
||||||
|
|
||||||
|
enum ColorFormat //from high bits -> low bits, 8 bit per channel
|
||||||
|
{
|
||||||
|
RGB, //8 bit for each red, green, blue, upper 8 bits unused
|
||||||
|
ARGB, //including alpha channel, BGRA byte order on little-endian machines
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
-> map source (srcWidth * srcHeight) to target (scale * width x scale * height) image, optionally processing a half-open slice of rows [yFirst, yLast) only
|
||||||
|
-> support for source/target pitch in bytes!
|
||||||
|
-> if your emulator changes only a few image slices during each cycle (e.g. DOSBox) then there's no need to run xBRZ on the complete image:
|
||||||
|
Just make sure you enlarge the source image slice by 2 rows on top and 2 on bottom (this is the additional range the xBRZ algorithm is using during analysis)
|
||||||
|
Caveat: If there are multiple changed slices, make sure they do not overlap after adding these additional rows in order to avoid a memory race condition
|
||||||
|
in the target image data if you are using multiple threads for processing each enlarged slice!
|
||||||
|
|
||||||
|
THREAD-SAFETY: - parts of the same image may be scaled by multiple threads as long as the [yFirst, yLast) ranges do not overlap!
|
||||||
|
- there is a minor inefficiency for the first row of a slice, so avoid processing single rows only; suggestion: process 8-16 rows at least
|
||||||
|
*/
|
||||||
|
#ifdef max
|
||||||
|
#undef max
|
||||||
|
#endif
|
||||||
|
void scale(size_t factor, //valid range: 2 - 6
|
||||||
|
const uint32_t* src, uint32_t* trg, int srcWidth, int srcHeight,
|
||||||
|
ColorFormat colFmt,
|
||||||
|
const ScalerCfg& cfg = ScalerCfg(),
|
||||||
|
int yFirst = 0, int yLast = std::numeric_limits<int>::max()); //slice of source image
|
||||||
|
|
||||||
|
void nearestNeighborScale(const uint32_t* src, int srcWidth, int srcHeight,
|
||||||
|
uint32_t* trg, int trgWidth, int trgHeight);
|
||||||
|
|
||||||
|
enum SliceType
|
||||||
|
{
|
||||||
|
NN_SCALE_SLICE_SOURCE,
|
||||||
|
NN_SCALE_SLICE_TARGET,
|
||||||
|
};
|
||||||
|
void nearestNeighborScale(const uint32_t* src, int srcWidth, int srcHeight, int srcPitch, //pitch in bytes!
|
||||||
|
uint32_t* trg, int trgWidth, int trgHeight, int trgPitch,
|
||||||
|
SliceType st, int yFirst, int yLast);
|
||||||
|
|
||||||
|
//parameter tuning
|
||||||
|
bool equalColorTest(uint32_t col1, uint32_t col2, ColorFormat colFmt, double luminanceWeight, double equalColorTolerance);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//########################### implementation ###########################
|
||||||
|
inline
|
||||||
|
void nearestNeighborScale(const uint32_t* src, int srcWidth, int srcHeight,
|
||||||
|
uint32_t* trg, int trgWidth, int trgHeight)
|
||||||
|
{
|
||||||
|
nearestNeighborScale(src, srcWidth, srcHeight, srcWidth * sizeof(uint32_t),
|
||||||
|
trg, trgWidth, trgHeight, trgWidth * sizeof(uint32_t),
|
||||||
|
NN_SCALE_SLICE_TARGET, 0, trgHeight);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
45
src/gl/xbr/xbrz_config.h
Normal file
45
src/gl/xbr/xbrz_config.h
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
// ****************************************************************************
|
||||||
|
// * This file is part of the HqMAME project. It is distributed under *
|
||||||
|
// * GNU General Public License: http://www.gnu.org/licenses/gpl-3.0 *
|
||||||
|
// * Copyright (C) Zenju (zenju AT gmx DOT de) - All Rights Reserved *
|
||||||
|
// * *
|
||||||
|
// * Additionally and as a special exception, the author gives permission *
|
||||||
|
// * to link the code of this program with the MAME library (or with modified *
|
||||||
|
// * versions of MAME that use the same license as MAME), and distribute *
|
||||||
|
// * linked combinations including the two. You must obey the GNU General *
|
||||||
|
// * Public License in all respects for all of the code used other than MAME. *
|
||||||
|
// * If you modify this file, you may extend this exception to your version *
|
||||||
|
// * of the file, but you are not obligated to do so. If you do not wish to *
|
||||||
|
// * do so, delete this exception statement from your version. *
|
||||||
|
// * *
|
||||||
|
// * An explicit permission was granted to use xBRZ in combination with ZDoom *
|
||||||
|
// * and derived projects as long as it is used for non-commercial purposes. *
|
||||||
|
// * *
|
||||||
|
// * Backported to C++98 by Alexey Lysiuk *
|
||||||
|
// ****************************************************************************
|
||||||
|
|
||||||
|
#ifndef XBRZ_CONFIG_HEADER_284578425345
|
||||||
|
#define XBRZ_CONFIG_HEADER_284578425345
|
||||||
|
|
||||||
|
//do NOT include any headers here! used by xBRZ_dll!!!
|
||||||
|
|
||||||
|
namespace xbrz
|
||||||
|
{
|
||||||
|
struct ScalerCfg
|
||||||
|
{
|
||||||
|
ScalerCfg() :
|
||||||
|
luminanceWeight(1),
|
||||||
|
equalColorTolerance(30),
|
||||||
|
dominantDirectionThreshold(3.6),
|
||||||
|
steepDirectionThreshold(2.2),
|
||||||
|
newTestAttribute(0) {}
|
||||||
|
|
||||||
|
double luminanceWeight;
|
||||||
|
double equalColorTolerance;
|
||||||
|
double dominantDirectionThreshold;
|
||||||
|
double steepDirectionThreshold;
|
||||||
|
double newTestAttribute; //unused; test new parameters
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
45
src/gl/xbr/xbrz_config_old.h
Normal file
45
src/gl/xbr/xbrz_config_old.h
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
// ****************************************************************************
|
||||||
|
// * This file is part of the HqMAME project. It is distributed under *
|
||||||
|
// * GNU General Public License: http://www.gnu.org/licenses/gpl.html *
|
||||||
|
// * Copyright (C) Zenju (zenju AT gmx DOT de) - All Rights Reserved *
|
||||||
|
// * *
|
||||||
|
// * Additionally and as a special exception, the author gives permission *
|
||||||
|
// * to link the code of this program with the MAME library (or with modified *
|
||||||
|
// * versions of MAME that use the same license as MAME), and distribute *
|
||||||
|
// * linked combinations including the two. You must obey the GNU General *
|
||||||
|
// * Public License in all respects for all of the code used other than MAME. *
|
||||||
|
// * If you modify this file, you may extend this exception to your version *
|
||||||
|
// * of the file, but you are not obligated to do so. If you do not wish to *
|
||||||
|
// * do so, delete this exception statement from your version. *
|
||||||
|
// * *
|
||||||
|
// * An explicit permission was granted to use xBRZ in combination with ZDoom *
|
||||||
|
// * and derived projects as long as it is used for non-commercial purposes. *
|
||||||
|
// * *
|
||||||
|
// * Backported to C++98 by Alexey Lysiuk *
|
||||||
|
// ****************************************************************************
|
||||||
|
|
||||||
|
#ifndef __XBRZ_CONFIG_OLD_HEADER_INCLUDED__
|
||||||
|
#define __XBRZ_CONFIG_OLD_HEADER_INCLUDED__
|
||||||
|
|
||||||
|
//do NOT include any headers here! used by xBRZ_dll!!!
|
||||||
|
|
||||||
|
namespace xbrz_old
|
||||||
|
{
|
||||||
|
struct ScalerCfg
|
||||||
|
{
|
||||||
|
ScalerCfg() :
|
||||||
|
luminanceWeight_(1),
|
||||||
|
equalColorTolerance_(30),
|
||||||
|
dominantDirectionThreshold(3.6),
|
||||||
|
steepDirectionThreshold(2.2),
|
||||||
|
newTestAttribute_(0) {}
|
||||||
|
|
||||||
|
double luminanceWeight_;
|
||||||
|
double equalColorTolerance_;
|
||||||
|
double dominantDirectionThreshold;
|
||||||
|
double steepDirectionThreshold;
|
||||||
|
double newTestAttribute_; //unused; test new parameters
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
1365
src/gl/xbr/xbrz_old.cpp
Normal file
1365
src/gl/xbr/xbrz_old.cpp
Normal file
File diff suppressed because it is too large
Load diff
92
src/gl/xbr/xbrz_old.h
Normal file
92
src/gl/xbr/xbrz_old.h
Normal file
|
@ -0,0 +1,92 @@
|
||||||
|
// ****************************************************************************
|
||||||
|
// * This file is part of the HqMAME project. It is distributed under *
|
||||||
|
// * GNU General Public License: http://www.gnu.org/licenses/gpl.html *
|
||||||
|
// * Copyright (C) Zenju (zenju AT gmx DOT de) - All Rights Reserved *
|
||||||
|
// * *
|
||||||
|
// * Additionally and as a special exception, the author gives permission *
|
||||||
|
// * to link the code of this program with the MAME library (or with modified *
|
||||||
|
// * versions of MAME that use the same license as MAME), and distribute *
|
||||||
|
// * linked combinations including the two. You must obey the GNU General *
|
||||||
|
// * Public License in all respects for all of the code used other than MAME. *
|
||||||
|
// * If you modify this file, you may extend this exception to your version *
|
||||||
|
// * of the file, but you are not obligated to do so. If you do not wish to *
|
||||||
|
// * do so, delete this exception statement from your version. *
|
||||||
|
// * *
|
||||||
|
// * An explicit permission was granted to use xBRZ in combination with ZDoom *
|
||||||
|
// * and derived projects as long as it is used for non-commercial purposes. *
|
||||||
|
// * *
|
||||||
|
// * Backported to C++98 by Alexey Lysiuk *
|
||||||
|
// ****************************************************************************
|
||||||
|
|
||||||
|
#ifndef __XBRZ_OLD_HEADER_INCLUDED__
|
||||||
|
#define __XBRZ_OLD_HEADER_INCLUDED__
|
||||||
|
|
||||||
|
#include <cstddef> //size_t
|
||||||
|
#include <stdint.h> //uint32_t
|
||||||
|
#include <limits>
|
||||||
|
#include "xbrz_config_old.h"
|
||||||
|
|
||||||
|
namespace xbrz_old
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
-------------------------------------------------------------------------
|
||||||
|
| xBRZ: "Scale by rules" - high quality image upscaling filter by Zenju |
|
||||||
|
-------------------------------------------------------------------------
|
||||||
|
using a modified approach of xBR:
|
||||||
|
http://board.byuu.org/viewtopic.php?f=10&t=2248
|
||||||
|
- new rule set preserving small image features
|
||||||
|
- support multithreading
|
||||||
|
- support 64 bit architectures
|
||||||
|
- support processing image slices
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
-> map source (srcWidth * srcHeight) to target (scale * width x scale * height) image, optionally processing a half-open slice of rows [yFirst, yLast) only
|
||||||
|
-> color format: ARGB (BGRA byte order), alpha channel unused
|
||||||
|
-> support for source/target pitch in bytes!
|
||||||
|
-> if your emulator changes only a few image slices during each cycle (e.g. Dosbox) then there's no need to run xBRZ on the complete image:
|
||||||
|
Just make sure you enlarge the source image slice by 2 rows on top and 2 on bottom (this is the additional range the xBRZ algorithm is using during analysis)
|
||||||
|
Caveat: If there are multiple changed slices, make sure they do not overlap after adding these additional rows in order to avoid a memory race condition
|
||||||
|
if you are using multiple threads for processing each enlarged slice!
|
||||||
|
|
||||||
|
THREAD-SAFETY: - parts of the same image may be scaled by multiple threads as long as the [yFirst, yLast) ranges do not overlap!
|
||||||
|
- there is a minor inefficiency for the first row of a slice, so avoid processing single rows only
|
||||||
|
|
||||||
|
|
||||||
|
*/
|
||||||
|
void scale(size_t factor, //valid range: 2 - 5
|
||||||
|
const uint32_t* src, uint32_t* trg, int srcWidth, int srcHeight,
|
||||||
|
const ScalerCfg& cfg = ScalerCfg(),
|
||||||
|
int yFirst = 0, int yLast = std::numeric_limits<int>::max()); //slice of source image
|
||||||
|
|
||||||
|
void nearestNeighborScale(const uint32_t* src, int srcWidth, int srcHeight,
|
||||||
|
uint32_t* trg, int trgWidth, int trgHeight);
|
||||||
|
|
||||||
|
enum SliceType
|
||||||
|
{
|
||||||
|
NN_SCALE_SLICE_SOURCE,
|
||||||
|
NN_SCALE_SLICE_TARGET,
|
||||||
|
};
|
||||||
|
void nearestNeighborScale(const uint32_t* src, int srcWidth, int srcHeight, int srcPitch, //pitch in bytes!
|
||||||
|
uint32_t* trg, int trgWidth, int trgHeight, int trgPitch,
|
||||||
|
SliceType st, int yFirst, int yLast);
|
||||||
|
|
||||||
|
//parameter tuning
|
||||||
|
bool equalColor(uint32_t col1, uint32_t col2, double luminanceWeight, double equalColorTolerance);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//########################### implementation ###########################
|
||||||
|
inline
|
||||||
|
void nearestNeighborScale(const uint32_t* src, int srcWidth, int srcHeight,
|
||||||
|
uint32_t* trg, int trgWidth, int trgHeight)
|
||||||
|
{
|
||||||
|
nearestNeighborScale(src, srcWidth, srcHeight, srcWidth * sizeof(uint32_t),
|
||||||
|
trg, trgWidth, trgHeight, trgWidth * sizeof(uint32_t),
|
||||||
|
NN_SCALE_SLICE_TARGET, 0, trgHeight);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
Loading…
Reference in a new issue