ctkCrosshairLabelTest2.cpp 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249
  1. /*=========================================================================
  2. Library: CTK
  3. Copyright (c) Kitware Inc.
  4. Licensed under the Apache License, Version 2.0 (the "License");
  5. you may not use this file except in compliance with the License.
  6. You may obtain a copy of the License at
  7. http://www.apache.org/licenses/LICENSE-2.0.txt
  8. Unless required by applicable law or agreed to in writing, software
  9. distributed under the License is distributed on an "AS IS" BASIS,
  10. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  11. See the License for the specific language governing permissions and
  12. limitations under the License.
  13. =========================================================================*/
  14. // Qt includes
  15. #include <QApplication>
  16. #include <QIcon>
  17. #include <QSignalSpy>
  18. #include <QStyle>
  19. #include <QTimer>
  20. // CTK includes
  21. #include "ctkCrosshairLabel.h"
  22. #include "ctkCommandLineParser.h"
  23. // STD includes
  24. #include <cstdlib>
  25. #include <iostream>
  26. //-----------------------------------------------------------------------------
  27. bool imageCompare(ctkCrosshairLabel& crosshair, QString baselineDirectory,
  28. QString baselineFilename)
  29. {
  30. QImage output = QPixmap::grabWidget(&crosshair).toImage();
  31. QImage baseline(baselineDirectory + "/" + baselineFilename);
  32. return output == baseline;
  33. }
  34. //-----------------------------------------------------------------------------
  35. // (Used to create baselines, not during testing).
  36. void imageSave(ctkCrosshairLabel& crosshair, QString baselineDirectory,
  37. QString baselineFilename)
  38. {
  39. QImage output = QPixmap::grabWidget(&crosshair).toImage();
  40. output.save(baselineDirectory + "/" + baselineFilename);
  41. }
  42. //-----------------------------------------------------------------------------
  43. bool runBaselineTest(ctkCrosshairLabel& crosshair,
  44. QString baselineDirectory, QString baselineFilename,
  45. QString errorMessage)
  46. {
  47. QApplication::processEvents();
  48. if (!imageCompare(crosshair, baselineDirectory, baselineFilename))
  49. {
  50. std::cerr << "ctkCrosshairLabel baseline comparison failed when "
  51. << qPrintable(errorMessage) << "." << std::endl;
  52. return false;
  53. }
  54. return true;
  55. }
  56. //-----------------------------------------------------------------------------
  57. int ctkCrosshairLabelTest2(int argc, char * argv [] )
  58. {
  59. QApplication app(argc, argv);
  60. // Command line parser
  61. ctkCommandLineParser parser;
  62. parser.addArgument("", "-D", QVariant::String);
  63. parser.addArgument("", "-V", QVariant::String);
  64. parser.addArgument("", "-I", QVariant::String);
  65. bool ok = false;
  66. QHash<QString, QVariant> parsedArgs = parser.parseArguments(app.arguments(), &ok);
  67. if (!ok)
  68. {
  69. std::cerr << qPrintable(parser.errorString()) << std::endl;
  70. return EXIT_FAILURE;
  71. }
  72. QString dataDirectory = parsedArgs["-D"].toString();
  73. QString baselineDirectory = parsedArgs["-V"].toString();
  74. bool interactive = parsedArgs["-I"].toBool();
  75. // The remainder is interactive, so abort now if command line args specify otherwise
  76. if (interactive)
  77. {
  78. return EXIT_SUCCESS;
  79. }
  80. // Create the crosshair widget
  81. ctkCrosshairLabel crosshair;
  82. QPen crosshairPen(Qt::yellow);
  83. crosshairPen.setJoinStyle(Qt::MiterJoin);
  84. crosshair.setCrosshairPen(crosshairPen);
  85. crosshair.setMarginColor(Qt::blue);
  86. QPixmap pixmap(dataDirectory + "/" + "computerIcon.png");
  87. // Basesize is always odd
  88. QSize baseSize = pixmap.size();
  89. if (pixmap.width() % 2 == 0)
  90. {
  91. baseSize.setWidth(baseSize.width()+1);
  92. }
  93. if (pixmap.height() % 2 == 0)
  94. {
  95. baseSize.setHeight(baseSize.height()+1);
  96. }
  97. // Odd widget size
  98. crosshair.setMinimumSize(baseSize);
  99. crosshair.setPixmap(pixmap.scaled(baseSize));
  100. crosshair.show();
  101. // Test bullsEyeWidth and line width with odd widget size
  102. crosshair.setCrosshairType(ctkCrosshairLabel::BullsEyeCrosshair);
  103. ///
  104. crosshair.setBullsEyeWidth(15);
  105. crosshairPen.setWidth(1);
  106. crosshair.setCrosshairPen(crosshairPen);
  107. if (!runBaselineTest(crosshair, baselineDirectory,
  108. "ctkCrosshairLabelTest2a.png",
  109. "using bulls-eye crosshair (odd size, bullsEye 15, width 1)"))
  110. {
  111. return EXIT_FAILURE;
  112. }
  113. ///
  114. crosshairPen.setWidth(5);
  115. crosshair.setCrosshairPen(crosshairPen);
  116. if (!runBaselineTest(crosshair, baselineDirectory,
  117. "ctkCrosshairLabelTest2b.png",
  118. "using bulls-eye crosshair (odd size, bullsEye 15, width 5)"))
  119. {
  120. return EXIT_FAILURE;
  121. }
  122. ///
  123. crosshair.setBullsEyeWidth(14);
  124. crosshairPen.setWidth(0); // equivalent to 1
  125. crosshair.setCrosshairPen(crosshairPen);
  126. if (!runBaselineTest(crosshair, baselineDirectory,
  127. "ctkCrosshairLabelTest2c.png",
  128. "using bulls-eye crosshair (odd size, bullsEye 14, width 1)"))
  129. {
  130. return EXIT_FAILURE;
  131. }
  132. ///
  133. crosshairPen.setWidth(4);
  134. crosshair.setCrosshairPen(crosshairPen);
  135. if (!runBaselineTest(crosshair, baselineDirectory,
  136. "ctkCrosshairLabelTest2d.png",
  137. "using bulls-eye crosshair (odd size, bullsEye 14, width 4)"))
  138. {
  139. return EXIT_FAILURE;
  140. }
  141. // Test bullsEyeWidth and line width with even widget size
  142. crosshair.resize(baseSize.width()+1, baseSize.height()+1);
  143. ///
  144. crosshair.setBullsEyeWidth(14);
  145. crosshairPen.setWidth(1);
  146. crosshair.setCrosshairPen(crosshairPen);
  147. if (!runBaselineTest(crosshair, baselineDirectory,
  148. "ctkCrosshairLabelTest2e.png",
  149. "using bulls-eye crosshair (even size, bullsEye 14, width 1)"))
  150. {
  151. return EXIT_FAILURE;
  152. }
  153. ///
  154. crosshairPen.setWidth(4);
  155. crosshair.setCrosshairPen(crosshairPen);
  156. if (!runBaselineTest(crosshair, baselineDirectory,
  157. "ctkCrosshairLabelTest2f.png",
  158. "using bulls-eye crosshair (even size, bullsEye 14, width 4)"))
  159. {
  160. return EXIT_FAILURE;
  161. }
  162. ///
  163. crosshair.setBullsEyeWidth(15);
  164. crosshairPen.setWidth(0);
  165. crosshair.setCrosshairPen(crosshairPen);
  166. if (!runBaselineTest(crosshair, baselineDirectory,
  167. "ctkCrosshairLabelTest2g.png",
  168. "using bulls-eye crosshair (even size, bullsEye 15, width 1)"))
  169. {
  170. return EXIT_FAILURE;
  171. }
  172. ///
  173. crosshairPen.setWidth(5);
  174. crosshair.setCrosshairPen(crosshairPen);
  175. if (!runBaselineTest(crosshair, baselineDirectory,
  176. "ctkCrosshairLabelTest2h.png",
  177. "using bulls-eye crosshair (even size, bullsEye 15, width 5)"))
  178. {
  179. return EXIT_FAILURE;
  180. }
  181. // Crosshair not shown
  182. crosshair.resize(baseSize);
  183. crosshair.setShowCrosshair(false);
  184. crosshair.setCrosshairPen(crosshairPen);
  185. if (!runBaselineTest(crosshair, baselineDirectory,
  186. "ctkCrosshairLabelTest2i.png",
  187. "show crosshair false"))
  188. {
  189. return EXIT_FAILURE;
  190. }
  191. // Crosshair crosshair
  192. crosshair.setShowCrosshair(true);
  193. crosshair.setCrosshairType(ctkCrosshairLabel::SimpleCrosshair);
  194. crosshairPen.setWidth(0);
  195. crosshair.setCrosshairPen(crosshairPen);
  196. if (!runBaselineTest(crosshair, baselineDirectory,
  197. "ctkCrosshairLabelTest2j.png",
  198. "using cross-hair crosshair (odd size)"))
  199. {
  200. return EXIT_FAILURE;
  201. }
  202. crosshair.resize(baseSize.width()+1, baseSize.height()+1);
  203. crosshairPen.setWidth(1);
  204. crosshair.setCrosshairPen(crosshairPen);
  205. if (!runBaselineTest(crosshair, baselineDirectory,
  206. "ctkCrosshairLabelTest2k.png",
  207. "using cross-hair crosshair (even size)"))
  208. {
  209. return EXIT_FAILURE;
  210. }
  211. // We already tested for interactive mode
  212. QTimer::singleShot(200, &app, SLOT(quit()));
  213. return app.exec();
  214. }