xbrz.h


SUBMITTED BY: Guest

DATE: Jan. 20, 2014, 5:37 p.m.

FORMAT: C++

SIZE: 4.4 kB

HITS: 1004

  1. // ****************************************************************************
  2. // * This file is part of the HqMAME project. It is distributed under *
  3. // * GNU General Public License: http://www.gnu.org/licenses/gpl.html *
  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 MAME library (or with modified *
  8. // * versions of MAME that use the same license as MAME), and distribute *
  9. // * linked combinations including the two. You must obey the GNU General *
  10. // * Public License in all respects for all of the code used other than MAME. *
  11. // * If you modify this file, you may extend this exception to your version *
  12. // * of the file, but you are not obligated to do so. If you do not wish to *
  13. // * do so, delete this exception statement from your version. *
  14. // ****************************************************************************
  15. #ifndef XBRZ_HEADER_3847894708239054
  16. #define XBRZ_HEADER_3847894708239054
  17. #include <cstddef> //size_t
  18. #include <cstdint> //uint32_t
  19. #include <limits>
  20. #include "config.h"
  21. namespace xbrz
  22. {
  23. /*
  24. -------------------------------------------------------------------------
  25. | xBRZ: "Scale by rules" - high quality image upscaling filter by Zenju |
  26. -------------------------------------------------------------------------
  27. using a modified approach of xBR:
  28. http://board.byuu.org/viewtopic.php?f=10&t=2248
  29. - new rule set preserving small image features
  30. - support multithreading
  31. - support 64 bit architectures
  32. - support processing image slices
  33. */
  34. /*
  35. -> map source (srcWidth * srcHeight) to target (scale * width x scale * height) image, optionally processing a half-open slice of rows [yFirst, yLast) only
  36. -> color format: ARGB (BGRA byte order), alpha channel unused
  37. -> support for source/target pitch in bytes!
  38. -> 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:
  39. 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)
  40. 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
  41. in the target image data if you are using multiple threads for processing each enlarged slice!
  42. THREAD-SAFETY: - parts of the same image may be scaled by multiple threads as long as the [yFirst, yLast) ranges do not overlap!
  43. - there is a minor inefficiency for the first row of a slice, so avoid processing single rows only
  44. */
  45. void scale(size_t factor, //valid range: 2 - 5
  46. const uint32_t* src, uint32_t* trg, int srcWidth, int srcHeight,
  47. const ScalerCfg& cfg = ScalerCfg(),
  48. int yFirst = 0, int yLast = std::numeric_limits<int>::max()); //slice of source image
  49. void nearestNeighborScale(const uint32_t* src, int srcWidth, int srcHeight,
  50. uint32_t* trg, int trgWidth, int trgHeight);
  51. enum SliceType
  52. {
  53. NN_SCALE_SLICE_SOURCE,
  54. NN_SCALE_SLICE_TARGET,
  55. };
  56. void nearestNeighborScale(const uint32_t* src, int srcWidth, int srcHeight, int srcPitch, //pitch in bytes!
  57. uint32_t* trg, int trgWidth, int trgHeight, int trgPitch,
  58. SliceType st, int yFirst, int yLast);
  59. //parameter tuning
  60. bool equalColorTest(uint32_t col1, uint32_t col2, double luminanceWeight, double equalColorTolerance);
  61. //########################### implementation ###########################
  62. inline
  63. void nearestNeighborScale(const uint32_t* src, int srcWidth, int srcHeight,
  64. uint32_t* trg, int trgWidth, int trgHeight)
  65. {
  66. nearestNeighborScale(src, srcWidth, srcHeight, srcWidth * sizeof(uint32_t),
  67. trg, trgWidth, trgHeight, trgWidth * sizeof(uint32_t),
  68. NN_SCALE_SLICE_TARGET, 0, trgHeight);
  69. }
  70. }
  71. #endif

comments powered by Disqus