xbrz.h 4.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. // ****************************************************************************
  2. // * This file is part of the xBRZ project. It is distributed under *
  3. // * GNU General Public License: https://www.gnu.org/licenses/gpl-3.0 *
  4. // * Copyright (C) Zenju (zenju AT gmx DOT de) - All Rights Reserved *
  5. // * *
  6. // * Additionally and as a special exception, the author gives permission *
  7. // * to link the code of this program with the following libraries *
  8. // * (or with modified versions that use the same licenses), and distribute *
  9. // * linked combinations including the two: MAME, FreeFileSync, Snes9x, ePSXe *
  10. // * You must obey the GNU General Public License in all respects for all of *
  11. // * the code used other than MAME, FreeFileSync, Snes9x, ePSXe. *
  12. // * If you modify this file, you may extend this exception to your version *
  13. // * of the file, but you are not obligated to do so. If you do not wish to *
  14. // * do so, delete this exception statement from your version. *
  15. // ****************************************************************************
  16. #ifndef XBRZ_HEADER_3847894708239054
  17. #define XBRZ_HEADER_3847894708239054
  18. #include <cstddef> //size_t
  19. #include <cstdint> //uint32_t
  20. #include <limits>
  21. #include "xbrz_config.h"
  22. namespace xbrz
  23. {
  24. /*
  25. -------------------------------------------------------------------------
  26. | xBRZ: "Scale by rules" - high quality image upscaling filter by Zenju |
  27. -------------------------------------------------------------------------
  28. using a modified approach of xBR:
  29. http://board.byuu.org/viewtopic.php?f=10&t=2248
  30. - new rule set preserving small image features
  31. - highly optimized for performance
  32. - support alpha channel
  33. - support multithreading
  34. - support 64-bit architectures
  35. - support processing image slices
  36. - support scaling up to 6xBRZ
  37. */
  38. enum class ColorFormat //from high bits -> low bits, 8 bit per channel
  39. {
  40. RGB, //8 bit for each red, green, blue, upper 8 bits unused
  41. ARGB, //including alpha channel, BGRA byte order on little-endian machines
  42. ARGB_CLAMPED, // like ARGB, but edges are treated as opaque, with same color as edge
  43. ARGB_UNBUFFERED, //like ARGB, but without the one-time buffer creation overhead (ca. 100 - 300 ms) at the expense of a slightly slower scaling time
  44. };
  45. const int SCALE_FACTOR_MAX = 6;
  46. /*
  47. -> map source (srcWidth * srcHeight) to target (scale * width x scale * height) image, optionally processing a half-open slice of rows [yFirst, yLast) only
  48. -> 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:
  49. 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)
  50. 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
  51. in the target image data if you are using multiple threads for processing each enlarged slice!
  52. THREAD-SAFETY: - parts of the same image may be scaled by multiple threads as long as the [yFirst, yLast) ranges do not overlap!
  53. - there is a minor inefficiency for the first row of a slice, so avoid processing single rows only; suggestion: process at least 8-16 rows
  54. */
  55. void scale(size_t factor, //valid range: 2 - SCALE_FACTOR_MAX
  56. const uint32_t* src, uint32_t* trg, int srcWidth, int srcHeight,
  57. ColorFormat colFmt,
  58. const ScalerCfg& cfg = ScalerCfg(),
  59. int yFirst = 0, int yLast = std::numeric_limits<int>::max()); //slice of source image
  60. void bilinearScale(const uint32_t* src, int srcWidth, int srcHeight,
  61. /**/ uint32_t* trg, int trgWidth, int trgHeight);
  62. void nearestNeighborScale(const uint32_t* src, int srcWidth, int srcHeight,
  63. /**/ uint32_t* trg, int trgWidth, int trgHeight);
  64. //parameter tuning
  65. bool equalColorTest(uint32_t col1, uint32_t col2, ColorFormat colFmt, double luminanceWeight, double equalColorTolerance);
  66. }
  67. #endif