123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192 |
- /*=========================================================================
- Library: CTK
- Copyright (c) Kitware Inc.
- Licensed under the Apache License, Version 2.0 (the "License");
- you may not use this file except in compliance with the License.
- You may obtain a copy of the License at
- http://www.commontk.org/LICENSE
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
- =========================================================================*/
- // Qt includes
- #include <QApplication>
- #include <QTimer>
- // CTK includes
- #include "ctkCoordinatesWidget.h"
- // STD includes
- #include <cstdlib>
- #include <iostream>
- //-----------------------------------------------------------------------------
- int ctkCoordinatesWidgetTest1(int argc, char * argv [] )
- {
- QApplication app(argc, argv);
- ctkCoordinatesWidget coordinatesWidget;
- if (coordinatesWidget.dimension() != 3)
- {
- std::cerr << "ctkCoordinatesWidget: bad default dimension" << std::endl;
- return EXIT_FAILURE;
- }
- coordinatesWidget.setDimension(4);
- if (coordinatesWidget.dimension() != 4)
- {
- std::cerr << "ctkCoordinatesWidget::setDimension failed" << std::endl;
- return EXIT_FAILURE;
- }
- if (coordinatesWidget.decimals() != 3 ||
- coordinatesWidget.singleStep() != 1. ||
- coordinatesWidget.minimum() != -100000. ||
- coordinatesWidget.maximum() != 100000.)
- {
- std::cerr << "Bad default ctkCoordinatesWidget values" << std::endl;
- return EXIT_FAILURE;
- }
- coordinatesWidget.setDecimals(4);
- if (coordinatesWidget.decimals() != 4)
- {
- std::cerr << "ctkCoordinatesWidget::setDecimals failed" << std::endl;
- return EXIT_FAILURE;
- }
- coordinatesWidget.setSingleStep(0.1);
- if (coordinatesWidget.singleStep() != 0.1)
- {
- std::cerr << "ctkCoordinatesWidget::setSingleStep failed" << std::endl;
- return EXIT_FAILURE;
- }
- coordinatesWidget.setMinimum(-9999.);
- if (coordinatesWidget.minimum() != -9999.)
- {
- std::cerr << "ctkCoordinatesWidget::setMinimum failed" << std::endl;
- return EXIT_FAILURE;
- }
- coordinatesWidget.setMaximum(9999.);
- if (coordinatesWidget.maximum() != 9999.)
- {
- std::cerr << "ctkCoordinatesWidget::setMaximum failed" << std::endl;
- return EXIT_FAILURE;
- }
- double const* coordinates = coordinatesWidget.coordinates();
- if (coordinates[0] != 0. ||
- coordinates[1] != 0. ||
- coordinates[2] != 0. ||
- coordinates[3] != 0.)
- {
- std::cerr << "ctkCoordinatesWidget::coordinates() failed"
- << coordinates[0] << " "
- << coordinates[1] << " "
- << coordinates[2] << " "
- << coordinates[3] << " " << std::endl;
- return EXIT_FAILURE;
- }
-
- if (coordinatesWidget.coordinatesAsString() != "0,0,0,0")
- {
- std::cerr << "ctkCoordinatesWidget::coordinatesAsString() failed"
- << coordinatesWidget.coordinatesAsString().toStdString()
- << std::endl;
- return EXIT_FAILURE;
- }
-
- double newCoordinates[4] = {1.0, 10.00012, -541292., 0.4};
- coordinatesWidget.setCoordinates(newCoordinates);
- coordinates = coordinatesWidget.coordinates();
-
- if (coordinates[0] != 1. ||
- coordinates[1] != 10.0001 ||
- coordinates[2] != -9999. ||
- coordinates[3] != 0.4)
- {
- std::cerr << "ctkCoordinatesWidget::coordinates() failed"
- << coordinates[0] << " "
- << coordinates[1] << " "
- << coordinates[2] << " "
- << coordinates[3] << " " << std::endl;
- return EXIT_FAILURE;
- }
-
- if (coordinatesWidget.coordinatesAsString() != "1,10.0001,-9999,0.4")
- {
- std::cerr << "ctkCoordinatesWidget::coordinatesAsString() failed"
- << coordinatesWidget.coordinatesAsString().toStdString() << std::endl;
- return EXIT_FAILURE;
- }
-
- coordinatesWidget.setCoordinatesAsString("1.000000001, -2, 3.01, 40000.01");
- coordinates = coordinatesWidget.coordinates();
- if (!qFuzzyCompare(coordinates[0], 1.) ||
- !qFuzzyCompare(coordinates[1], -2.) ||
- !qFuzzyCompare(coordinates[2], 3.01) ||
- !qFuzzyCompare(coordinates[3], 9999.))
- {
- std::cerr << "ctkCoordinatesWidget::coordinates() failed: "
- << coordinates[0] << " " << qFuzzyCompare(coordinates[0], 1.) << ", "
- << coordinates[1] << " " << qFuzzyCompare(coordinates[1], -2.) << ", "
- << coordinates[2] << " " << qFuzzyCompare(coordinates[2], 3.01) << ", "
- << coordinates[3] << " " << qFuzzyCompare(coordinates[3], 9999.) << ", "
- << std::endl;
- return EXIT_FAILURE;
- }
-
- if (coordinatesWidget.coordinatesAsString() != "1,-2,3.01,9999")
- {
- std::cerr << "ctkCoordinatesWidget::coordinatesAsString() failed"
- << coordinatesWidget.coordinatesAsString().toStdString() << std::endl;
- return EXIT_FAILURE;
- }
- coordinatesWidget.setDimension(0);
-
- if (coordinatesWidget.dimension() != 4)
- {
- std::cerr << "ctkCoordinatesWidget::setDimension() failed: "
- << coordinatesWidget.dimension() << std::endl;
- return EXIT_FAILURE;
- }
- coordinatesWidget.setDimension(3);
-
- if (coordinatesWidget.dimension() != 3)
- {
- std::cerr << "ctkCoordinatesWidget::setDimension() failed: "
- << coordinatesWidget.dimension() << std::endl;
- return EXIT_FAILURE;
- }
- coordinatesWidget.show();
- if (argc < 2 || QString(argv[1]) != "-I" )
- {
- QTimer::singleShot(200, &app, SLOT(quit()));
- }
-
- return app.exec();
- }
|