Subversion Repositories Kolibri OS

Rev

Blame | Last modification | View Log | RSS feed

  1. // ****************************************************************************
  2. // * This file is part of the HqMAME 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 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.  
  16. #ifndef XBRZ_HEADER_3847894708239054
  17. #define XBRZ_HEADER_3847894708239054
  18.  
  19. #include <cstddef> //size_t
  20. #include <cstdint> //uint32_t
  21. #include <limits>
  22.  
  23. #include "xbrz_config.h"
  24.  
  25. namespace xbrz
  26. {
  27. /*
  28.    -------------------------------------------------------------------------
  29.  | xBRZ: "Scale by rules" - high quality image upscaling filter by Zenju |
  30.    -------------------------------------------------------------------------
  31.    using a modified approach of xBR:
  32.    http://board.byuu.org/viewtopic.php?f=10&t=2248
  33.    - new rule set preserving small image features
  34.    - highly optimized for performance
  35.    - support alpha channel
  36.    - support multithreading
  37.    - support 64-bit architectures
  38.    - support processing image slices
  39.    - support scaling up to 6xBRZ
  40.  */
  41.  
  42. enum class ColorFormat //from high bits -> low bits, 8 bit per channel
  43. {
  44.         RGB, //8 bit for each red, green, blue, upper 8 bits unused
  45.         ARGB, //including alpha channel, BGRA byte order on little-endian machines
  46. };
  47.  
  48. /*
  49.    -> map source (srcWidth * srcHeight) to target (scale * width x scale * height) image, optionally processing a half-open slice of rows [yFirst, yLast) only
  50.    -> support for source/target pitch in bytes!
  51.    -> 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:
  52.    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)
  53.    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
  54.    in the target image data if you are using multiple threads for processing each enlarged slice!
  55.  
  56.    THREAD-SAFETY: - parts of the same image may be scaled by multiple threads as long as the [yFirst, yLast) ranges do not overlap!
  57.                - 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
  58.  */
  59. void scale(size_t factor, //valid range: 2 - 6
  60.            const uint32_t* src, uint32_t* trg, int srcWidth, int srcHeight,
  61.            ColorFormat colFmt,
  62.            const ScalerCfg& cfg = ScalerCfg(),
  63.            int yFirst = 0, int yLast = std::numeric_limits<int>::max()); //slice of source image
  64.  
  65. void nearestNeighborScale(const uint32_t* src, int srcWidth, int srcHeight,
  66.                           /**/ uint32_t* trg, int trgWidth, int trgHeight);
  67.  
  68.  
  69. //parameter tuning
  70. bool equalColorTest(uint32_t col1, uint32_t col2, ColorFormat colFmt, double luminanceWeight, double equalColorTolerance);
  71. }
  72.  
  73. #endif
  74.