DISTRHO Plugin Framework
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

220 lines
10KB

  1. /*
  2. * DISTRHO Plugin Framework (DPF)
  3. * Copyright (C) 2012-2021 Filipe Coelho <falktx@falktx.com>
  4. *
  5. * Permission to use, copy, modify, and/or distribute this software for any purpose with
  6. * or without fee is hereby granted, provided that the above copyright notice and this
  7. * permission notice appear in all copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD
  10. * TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN
  11. * NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  12. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER
  13. * IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
  14. * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  15. */
  16. #include "tests.hpp"
  17. #define DPF_TEST_COLOR_CPP
  18. #include "dgl/src/Color.cpp"
  19. // --------------------------------------------------------------------------------------------------------------------
  20. int main()
  21. {
  22. USE_NAMESPACE_DGL;
  23. // constructor with no arguments, must give solid black
  24. {
  25. Color c;
  26. DISTRHO_ASSERT_EQUAL(c.red, 0.0f, "red value is 0");
  27. DISTRHO_ASSERT_EQUAL(c.green, 0.0f, "green value is 0");
  28. DISTRHO_ASSERT_EQUAL(c.blue, 0.0f, "blue value is 0");
  29. DISTRHO_ASSERT_EQUAL(c.alpha, 1.0f, "alpha value is 1");
  30. }
  31. // constructor gives correct floating-point values (arguments are r, g, b, a; in order)
  32. {
  33. Color c(0.1f, 0.2f, 0.3f, 0.4f);
  34. DISTRHO_ASSERT_EQUAL(c.red, 0.1f, "red value is 0.1");
  35. DISTRHO_ASSERT_EQUAL(c.green, 0.2f, "green value is 0.2");
  36. DISTRHO_ASSERT_EQUAL(c.blue, 0.3f, "blue value is 0.3");
  37. DISTRHO_ASSERT_EQUAL(c.alpha, 0.4f, "alpha value is 0.4");
  38. }
  39. // constructor gives correct integer values normalized to float (arguments are r, g, b, a; in order)
  40. {
  41. Color c(51, 102, 153);
  42. DISTRHO_ASSERT_SAFE_EQUAL(c.red, 0.2f, "red value is 0.2 (integer 51)");
  43. DISTRHO_ASSERT_SAFE_EQUAL(c.green, 0.4f, "green value is 0.4 (integer 102)");
  44. DISTRHO_ASSERT_SAFE_EQUAL(c.blue, 0.6f, "blue value is 0.6 (integer 153)");
  45. DISTRHO_ASSERT_SAFE_EQUAL(c.alpha, 1.0f, "alpha value is 1");
  46. Color white(255, 255, 255);
  47. DISTRHO_ASSERT_EQUAL(white.red, 1.0f, "white's red value is 1");
  48. DISTRHO_ASSERT_EQUAL(white.green, 1.0f, "white's green value is 1");
  49. DISTRHO_ASSERT_EQUAL(white.blue, 1.0f, "white's blue value is 1");
  50. DISTRHO_ASSERT_EQUAL(white.alpha, 1.0f, "white alpha value is 1");
  51. }
  52. // copy colors around
  53. {
  54. Color black;
  55. Color halfTransparentWhite(1.0f, 1.0f, 1.0f, 0.5f);
  56. // constructor copy
  57. Color test(halfTransparentWhite);
  58. DISTRHO_ASSERT_EQUAL(test.red, 1.0f, "copied white's red value is 1.0");
  59. DISTRHO_ASSERT_EQUAL(test.green, 1.0f, "copied white's green value is 1");
  60. DISTRHO_ASSERT_EQUAL(test.blue, 1.0f, "copied white's blue value is 1");
  61. DISTRHO_ASSERT_EQUAL(test.alpha, 0.5f, "copied white's alpha value is 0.5");
  62. // assign operator
  63. test = black;
  64. DISTRHO_ASSERT_EQUAL(test.red, 0.0f, "assigned black's red value is 0");
  65. DISTRHO_ASSERT_EQUAL(test.green, 0.0f, "assigned black's green value is 0");
  66. DISTRHO_ASSERT_EQUAL(test.blue, 0.0f, "assigned black's blue value is 0");
  67. DISTRHO_ASSERT_EQUAL(test.alpha, 1.0f, "assigned black's alpha value is 1");
  68. }
  69. // simple color comparisons
  70. {
  71. Color black1, black2;
  72. Color white(1.0f, 1.0f, 1.0f);
  73. Color halfTransparentWhite(1.0f, 1.0f, 1.0f, 0.5f);
  74. // logic operators
  75. DISTRHO_ASSERT_EQUAL(black1, black1, "color equals itself");
  76. DISTRHO_ASSERT_EQUAL(black1, black2, "black equals black");
  77. DISTRHO_ASSERT_NOT_EQUAL(black1, white, "black is not white");
  78. DISTRHO_ASSERT_NOT_EQUAL(black1, halfTransparentWhite, "black is not half-transparent white");
  79. DISTRHO_ASSERT_NOT_EQUAL(white, halfTransparentWhite, "white is not half-transparent white");
  80. // class functions (truthful)
  81. DISTRHO_ASSERT_EQUAL(black1.isEqual(black1), true, "color equals itself");
  82. DISTRHO_ASSERT_EQUAL(black1.isEqual(black2), true, "black equals black");
  83. DISTRHO_ASSERT_EQUAL(black1.isNotEqual(white), true, "black is not white");
  84. DISTRHO_ASSERT_EQUAL(white.isNotEqual(halfTransparentWhite), true, "white is not half-transparent white");
  85. // class functions (inverted)
  86. DISTRHO_ASSERT_EQUAL(black1.isNotEqual(black1), false, "color equals itself");
  87. DISTRHO_ASSERT_EQUAL(black1.isNotEqual(black2), false, "black equals black");
  88. DISTRHO_ASSERT_EQUAL(black1.isEqual(white), false, "black is not white");
  89. DISTRHO_ASSERT_EQUAL(white.isEqual(halfTransparentWhite), false, "white is not half-transparent white");
  90. // class functions ignoring alpha
  91. DISTRHO_ASSERT_EQUAL(black1.isEqual(black1, false), true, "color equals itself");
  92. DISTRHO_ASSERT_EQUAL(black1.isEqual(black2, false), true, "black equals black");
  93. DISTRHO_ASSERT_EQUAL(black1.isNotEqual(white, false), true, "black is not white");
  94. DISTRHO_ASSERT_EQUAL(white.isEqual(halfTransparentWhite, false), true,
  95. "white is half-transparent white if we ignore alpha");
  96. }
  97. // TODO advanced color comparisons
  98. {
  99. }
  100. // TODO fromHSL
  101. {
  102. }
  103. // create colors from html strings
  104. {
  105. Color c000 = Color::fromHTML("#000");
  106. DISTRHO_ASSERT_EQUAL(c000.red, 0.0f, "#000 red value is 0");
  107. DISTRHO_ASSERT_EQUAL(c000.green, 0.0f, "#000 green value is 0");
  108. DISTRHO_ASSERT_EQUAL(c000.blue, 0.0f, "#000 blue value is 0");
  109. DISTRHO_ASSERT_EQUAL(c000.alpha, 1.0f, "#000 alpha value is 1");
  110. Color c000000 = Color::fromHTML("#000000");
  111. DISTRHO_ASSERT_EQUAL(c000000.red, 0.0f, "#000000 red value is 0");
  112. DISTRHO_ASSERT_EQUAL(c000000.green, 0.0f, "#000000 green value is 0");
  113. DISTRHO_ASSERT_EQUAL(c000000.blue, 0.0f, "#000000 blue value is 0");
  114. DISTRHO_ASSERT_EQUAL(c000000.alpha, 1.0f, "#000000 alpha value is 1");
  115. Color cfff = Color::fromHTML("#fff");
  116. DISTRHO_ASSERT_EQUAL(cfff.red, 1.0f, "#fff red value is 1");
  117. DISTRHO_ASSERT_EQUAL(cfff.green, 1.0f, "#fff green value is 1");
  118. DISTRHO_ASSERT_EQUAL(cfff.blue, 1.0f, "#fff blue value is 1");
  119. DISTRHO_ASSERT_EQUAL(cfff.alpha, 1.0f, "#fff alpha value is 1");
  120. Color cffffff = Color::fromHTML("#ffffff");
  121. DISTRHO_ASSERT_EQUAL(cffffff.red, 1.0f, "#ffffff red value is 1");
  122. DISTRHO_ASSERT_EQUAL(cffffff.green, 1.0f, "#ffffff green value is 1");
  123. DISTRHO_ASSERT_EQUAL(cffffff.blue, 1.0f, "#ffffff blue value is 1");
  124. DISTRHO_ASSERT_EQUAL(cffffff.alpha, 1.0f, "#ffffff alpha value is 1");
  125. Color cf00 = Color::fromHTML("#f00");
  126. DISTRHO_ASSERT_EQUAL(cf00.red, 1.0f, "#f00 red value is 1");
  127. DISTRHO_ASSERT_EQUAL(cf00.green, 0.0f, "#f00 green value is 0");
  128. DISTRHO_ASSERT_EQUAL(cf00.blue, 0.0f, "#f00 blue value is 0");
  129. Color cff0000 = Color::fromHTML("#ff0000");
  130. DISTRHO_ASSERT_EQUAL(cff0000.red, 1.0f, "#ff0000 red value is 1");
  131. DISTRHO_ASSERT_EQUAL(cff0000.green, 0.0f, "#ff0000 green value is 0");
  132. DISTRHO_ASSERT_EQUAL(cff0000.blue, 0.0f, "#ff0000 blue value is 0");
  133. Color c0f0 = Color::fromHTML("#0f0");
  134. DISTRHO_ASSERT_EQUAL(c0f0.red, 0.0f, "#0f0 red value is 0");
  135. DISTRHO_ASSERT_EQUAL(c0f0.green, 1.0f, "#0f0 green value is 1");
  136. DISTRHO_ASSERT_EQUAL(c0f0.blue, 0.0f, "#0f0 blue value is 0");
  137. Color c00ff00 = Color::fromHTML("#00ff00");
  138. DISTRHO_ASSERT_EQUAL(c00ff00.red, 0.0f, "#00ff00 red value is 0");
  139. DISTRHO_ASSERT_EQUAL(c00ff00.green, 1.0f, "#00ff00 green value is 1");
  140. DISTRHO_ASSERT_EQUAL(c00ff00.blue, 0.0f, "#00ff00 blue value is 0");
  141. Color c00f = Color::fromHTML("#00f");
  142. DISTRHO_ASSERT_EQUAL(c00f.red, 0.0f, "#00f red value is 0");
  143. DISTRHO_ASSERT_EQUAL(c00f.green, 0.0f, "#00f green value is 0");
  144. DISTRHO_ASSERT_EQUAL(c00f.blue, 1.0f, "#00f blue value is 1");
  145. Color c0000ff = Color::fromHTML("#0000ff");
  146. DISTRHO_ASSERT_EQUAL(c0000ff.red, 0.0f, "#0000ff red value is 0");
  147. DISTRHO_ASSERT_EQUAL(c0000ff.green, 0.0f, "#0000ff green value is 0");
  148. DISTRHO_ASSERT_EQUAL(c0000ff.blue, 1.0f, "#0000ff blue value is 1");
  149. // half point, round to 1 decimal point due to precision loss
  150. Color grey = Color::fromHTML("#7b7b7b");
  151. DISTRHO_ASSERT_SAFE_EQUAL(std::round(grey.red*10)/10, 0.5f, "grey's rounded red value is 0.5");
  152. DISTRHO_ASSERT_SAFE_EQUAL(std::round(grey.green*10)/10, 0.5f, "grey's rounded green value is 0.5");
  153. DISTRHO_ASSERT_SAFE_EQUAL(std::round(grey.blue*10)/10, 0.5f, "grey's rounded blue value is 0.5");
  154. }
  155. // check bounds
  156. {
  157. Color negativeInteger(-1, -1, -1, -1.0f);
  158. DISTRHO_ASSERT_EQUAL(negativeInteger.red, 0.0f, "red value is 0");
  159. DISTRHO_ASSERT_EQUAL(negativeInteger.green, 0.0f, "green value is 0");
  160. DISTRHO_ASSERT_EQUAL(negativeInteger.blue, 0.0f, "blue value is 0");
  161. DISTRHO_ASSERT_EQUAL(negativeInteger.alpha, 0.0f, "alpha value is 0");
  162. Color negativeFloat(-1.0f, -1.0f, -1.0f, -1.0f);
  163. DISTRHO_ASSERT_EQUAL(negativeFloat.red, 0.0f, "red value is 0");
  164. DISTRHO_ASSERT_EQUAL(negativeFloat.green, 0.0f, "green value is 0");
  165. DISTRHO_ASSERT_EQUAL(negativeFloat.blue, 0.0f, "blue value is 0");
  166. DISTRHO_ASSERT_EQUAL(negativeFloat.alpha, 0.0f, "alpha value is 0");
  167. Color overflowInteger(0xfff, 0xfff, 0xfff, 0xfff);
  168. DISTRHO_ASSERT_EQUAL(overflowInteger.red, 1.0f, "red value is 1");
  169. DISTRHO_ASSERT_EQUAL(overflowInteger.green, 1.0f, "green value is 1");
  170. DISTRHO_ASSERT_EQUAL(overflowInteger.blue, 1.0f, "blue value is 1");
  171. DISTRHO_ASSERT_EQUAL(overflowInteger.alpha, 1.0f, "alpha value is 1");
  172. Color overflowFloat(2.0f, 2.0f, 2.0f, 2.0f);
  173. DISTRHO_ASSERT_EQUAL(overflowFloat.red, 1.0f, "red value is 1");
  174. DISTRHO_ASSERT_EQUAL(overflowFloat.green, 1.0f, "green value is 1");
  175. DISTRHO_ASSERT_EQUAL(overflowFloat.blue, 1.0f, "blue value is 1");
  176. DISTRHO_ASSERT_EQUAL(overflowFloat.alpha, 1.0f, "alpha value is 1");
  177. }
  178. // TODO interpolation
  179. {
  180. }
  181. return 0;
  182. }
  183. // --------------------------------------------------------------------------------------------------------------------