Mercurial > hg > svcore
view data/model/test/TestZoomConstraints.h @ 1532:5360f7aba189 zoom
Pull out ZoomLevel, add inexact frame/pixel conversion functions and streaming
author | Chris Cannam |
---|---|
date | Wed, 19 Sep 2018 15:41:44 +0100 |
parents | 2f3a77472c8c |
children | 05c3fbaec8ea |
line wrap: on
line source
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ /* Sonic Visualiser An audio file viewer and annotation editor. Centre for Digital Music, Queen Mary, University of London. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. See the file COPYING included with this distribution for more information. */ #ifndef TEST_ZOOM_CONSTRAINTS_H #define TEST_ZOOM_CONSTRAINTS_H #include "../PowerOfTwoZoomConstraint.h" #include "../PowerOfSqrtTwoZoomConstraint.h" #include <QObject> #include <QtTest> #include <QDir> #include <iostream> using namespace std; class TestZoomConstraints : public QObject { Q_OBJECT void checkFpp(const ZoomConstraint &c, ZoomConstraint::RoundingDirection dir, int n, int expected) { QCOMPARE(c.getNearestZoomLevel(ZoomLevel(ZoomLevel::FramesPerPixel, n), dir), ZoomLevel(ZoomLevel::FramesPerPixel, expected)); } private slots: void unconstrainedNearest() { ZoomConstraint c; checkFpp(c, ZoomConstraint::RoundNearest, 1, 1); checkFpp(c, ZoomConstraint::RoundNearest, 2, 2); checkFpp(c, ZoomConstraint::RoundNearest, 3, 3); checkFpp(c, ZoomConstraint::RoundNearest, 4, 4); checkFpp(c, ZoomConstraint::RoundNearest, 20, 20); checkFpp(c, ZoomConstraint::RoundNearest, 32, 32); auto max = c.getMaxZoomLevel(); QCOMPARE(c.getNearestZoomLevel(max), max); QCOMPARE(c.getNearestZoomLevel(max.incremented()), max); } void unconstrainedUp() { ZoomConstraint c; checkFpp(c, ZoomConstraint::RoundUp, 1, 1); checkFpp(c, ZoomConstraint::RoundUp, 2, 2); checkFpp(c, ZoomConstraint::RoundUp, 3, 3); checkFpp(c, ZoomConstraint::RoundUp, 4, 4); checkFpp(c, ZoomConstraint::RoundUp, 20, 20); checkFpp(c, ZoomConstraint::RoundUp, 32, 32); auto max = c.getMaxZoomLevel(); QCOMPARE(c.getNearestZoomLevel(max, ZoomConstraint::RoundUp), max); QCOMPARE(c.getNearestZoomLevel(max.incremented(), ZoomConstraint::RoundUp), max); } void unconstrainedDown() { ZoomConstraint c; checkFpp(c, ZoomConstraint::RoundDown, 1, 1); checkFpp(c, ZoomConstraint::RoundDown, 2, 2); checkFpp(c, ZoomConstraint::RoundDown, 3, 3); checkFpp(c, ZoomConstraint::RoundDown, 4, 4); checkFpp(c, ZoomConstraint::RoundDown, 20, 20); checkFpp(c, ZoomConstraint::RoundDown, 32, 32); auto max = c.getMaxZoomLevel(); QCOMPARE(c.getNearestZoomLevel(max, ZoomConstraint::RoundDown), max); QCOMPARE(c.getNearestZoomLevel(max.incremented(), ZoomConstraint::RoundDown), max); } void powerOfTwoNearest() { PowerOfTwoZoomConstraint c; checkFpp(c, ZoomConstraint::RoundNearest, 1, 1); checkFpp(c, ZoomConstraint::RoundNearest, 2, 2); checkFpp(c, ZoomConstraint::RoundNearest, 3, 2); checkFpp(c, ZoomConstraint::RoundNearest, 4, 4); checkFpp(c, ZoomConstraint::RoundNearest, 20, 16); checkFpp(c, ZoomConstraint::RoundNearest, 23, 16); checkFpp(c, ZoomConstraint::RoundNearest, 24, 16); checkFpp(c, ZoomConstraint::RoundNearest, 25, 32); auto max = c.getMaxZoomLevel(); QCOMPARE(c.getNearestZoomLevel(max), max); QCOMPARE(c.getNearestZoomLevel(max.incremented()), max); } void powerOfTwoUp() { PowerOfTwoZoomConstraint c; checkFpp(c, ZoomConstraint::RoundUp, 1, 1); checkFpp(c, ZoomConstraint::RoundUp, 2, 2); checkFpp(c, ZoomConstraint::RoundUp, 3, 4); checkFpp(c, ZoomConstraint::RoundUp, 4, 4); checkFpp(c, ZoomConstraint::RoundUp, 20, 32); checkFpp(c, ZoomConstraint::RoundUp, 32, 32); checkFpp(c, ZoomConstraint::RoundUp, 33, 64); auto max = c.getMaxZoomLevel(); QCOMPARE(c.getNearestZoomLevel(max, ZoomConstraint::RoundUp), max); QCOMPARE(c.getNearestZoomLevel(max.incremented(), ZoomConstraint::RoundUp), max); } void powerOfTwoDown() { PowerOfTwoZoomConstraint c; checkFpp(c, ZoomConstraint::RoundDown, 1, 1); checkFpp(c, ZoomConstraint::RoundDown, 2, 2); checkFpp(c, ZoomConstraint::RoundDown, 3, 2); checkFpp(c, ZoomConstraint::RoundDown, 4, 4); checkFpp(c, ZoomConstraint::RoundDown, 20, 16); checkFpp(c, ZoomConstraint::RoundDown, 32, 32); checkFpp(c, ZoomConstraint::RoundDown, 33, 32); auto max = c.getMaxZoomLevel(); QCOMPARE(c.getNearestZoomLevel(max, ZoomConstraint::RoundDown), max); QCOMPARE(c.getNearestZoomLevel(max.incremented(), ZoomConstraint::RoundDown), max); } void powerOfSqrtTwoNearest() { PowerOfSqrtTwoZoomConstraint c; checkFpp(c, ZoomConstraint::RoundNearest, 1, 1); checkFpp(c, ZoomConstraint::RoundNearest, 2, 2); checkFpp(c, ZoomConstraint::RoundNearest, 3, 2); checkFpp(c, ZoomConstraint::RoundNearest, 4, 4); checkFpp(c, ZoomConstraint::RoundNearest, 18, 16); checkFpp(c, ZoomConstraint::RoundNearest, 19, 16); checkFpp(c, ZoomConstraint::RoundNearest, 20, 22); checkFpp(c, ZoomConstraint::RoundNearest, 23, 22); checkFpp(c, ZoomConstraint::RoundNearest, 28, 32); // PowerOfSqrtTwoZoomConstraint makes an effort to ensure // bigger numbers get rounded to a multiple of something // simple (64 or 90 depending on whether they are power-of-two // or power-of-sqrt-two types) checkFpp(c, ZoomConstraint::RoundNearest, 800, 720); checkFpp(c, ZoomConstraint::RoundNearest, 1023, 1024); checkFpp(c, ZoomConstraint::RoundNearest, 1024, 1024); checkFpp(c, ZoomConstraint::RoundNearest, 1024, 1024); checkFpp(c, ZoomConstraint::RoundNearest, 1025, 1024); auto max = c.getMaxZoomLevel(); QCOMPARE(c.getNearestZoomLevel(max), max); QCOMPARE(c.getNearestZoomLevel(max.incremented()), max); } void powerOfSqrtTwoUp() { PowerOfSqrtTwoZoomConstraint c; checkFpp(c, ZoomConstraint::RoundUp, 1, 1); checkFpp(c, ZoomConstraint::RoundUp, 2, 2); checkFpp(c, ZoomConstraint::RoundUp, 3, 4); checkFpp(c, ZoomConstraint::RoundUp, 4, 4); checkFpp(c, ZoomConstraint::RoundUp, 18, 22); checkFpp(c, ZoomConstraint::RoundUp, 22, 22); checkFpp(c, ZoomConstraint::RoundUp, 23, 32); checkFpp(c, ZoomConstraint::RoundUp, 800, 1024); checkFpp(c, ZoomConstraint::RoundUp, 1023, 1024); checkFpp(c, ZoomConstraint::RoundUp, 1024, 1024); // see comment above checkFpp(c, ZoomConstraint::RoundUp, 1025, 1440); auto max = c.getMaxZoomLevel(); QCOMPARE(c.getNearestZoomLevel(max, ZoomConstraint::RoundUp), max); QCOMPARE(c.getNearestZoomLevel(max.incremented(), ZoomConstraint::RoundUp), max); } void powerOfSqrtTwoDown() { PowerOfSqrtTwoZoomConstraint c; checkFpp(c, ZoomConstraint::RoundDown, 1, 1); checkFpp(c, ZoomConstraint::RoundDown, 2, 2); checkFpp(c, ZoomConstraint::RoundDown, 3, 2); checkFpp(c, ZoomConstraint::RoundDown, 4, 4); checkFpp(c, ZoomConstraint::RoundDown, 18, 16); checkFpp(c, ZoomConstraint::RoundDown, 22, 22); checkFpp(c, ZoomConstraint::RoundDown, 23, 22); // see comment above checkFpp(c, ZoomConstraint::RoundDown, 800, 720); checkFpp(c, ZoomConstraint::RoundDown, 1023, 720); checkFpp(c, ZoomConstraint::RoundDown, 1024, 1024); checkFpp(c, ZoomConstraint::RoundDown, 1025, 1024); auto max = c.getMaxZoomLevel(); QCOMPARE(c.getNearestZoomLevel(max, ZoomConstraint::RoundDown), max); QCOMPARE(c.getNearestZoomLevel(max.incremented(), ZoomConstraint::RoundDown), max); } }; #endif