Summary: This new version of the distance function simplifies the findPreferredImageInPackage method by using the aspect ratio in the calculation. Now, it won't only search for a wallpaper with the same aspect ratio, but will also choose one with the closest possible aspect ratio when a perfect match is not found. Also, I separated the method that chooses the preferred image to not use KPackage in order to use it from a test application that tests the distance algorithm with all possible resolutions. Test application that tests the Image::findPreferredImage method The test initializes a list of available wallpaper image sizes, then a list of screen resolutions, and then executes Image::findPreferredImage to find out which is the preferred image in each case. Test Plan: I tested with different screen resolutions on a virtual machine with openSUSE Leap 42.2 RC1 and also included a commit that adds a test application (not built by default) that tests all possible resolutions. Reviewers: #plasma, mart Reviewed By: mart Subscribers: mart, plasma-devel Tags: #plasma Differential Revision: https://phabricator.kde.org/D3188wilder-5.14
parent
d1133288c3
commit
c309f1eaeb
5 changed files with 147 additions and 34 deletions
@ -0,0 +1,11 @@ |
||||
set(testfindpreferredimage_SRCS |
||||
testfindpreferredimage.cpp |
||||
../image.cpp |
||||
../backgroundlistmodel.cpp |
||||
) |
||||
|
||||
add_executable(testfindpreferredimage EXCLUDE_FROM_ALL ${testfindpreferredimage_SRCS}) |
||||
|
||||
target_link_libraries(testfindpreferredimage |
||||
plasma_wallpaper_imageplugin |
||||
Qt5::Test) |
||||
@ -0,0 +1,106 @@ |
||||
/***************************************************************************
|
||||
* Copyright 2016 Antonio Larrosa <larrosa@kde.org> * |
||||
* * |
||||
* 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. * |
||||
* * |
||||
* This program is distributed in the hope that it will be useful, * |
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of * |
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * |
||||
* GNU General Public License for more details. * |
||||
* * |
||||
* You should have received a copy of the GNU General Public License * |
||||
* along with this program; if not, write to the * |
||||
* Free Software Foundation, Inc., * |
||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA . * |
||||
***************************************************************************/ |
||||
#include "image.h" |
||||
#include <QtTest/QtTest> |
||||
#include <QDebug> |
||||
|
||||
extern QSize resSize(const QString &str); |
||||
|
||||
QString formatResolution(const QString &str) |
||||
{ |
||||
QSize size = resSize(str); |
||||
float aspectRatio = (size.height() > 0 ) ? size.width() / (float)size.height() : 0; |
||||
return QString("%1 (%2)").arg(str, 9).arg(aspectRatio, 7); |
||||
} |
||||
|
||||
class TestResolutions: public QObject |
||||
{ |
||||
Q_OBJECT |
||||
|
||||
private slots: |
||||
void testResolutions_data(); |
||||
void testResolutions(); |
||||
|
||||
protected: |
||||
Image m_image; |
||||
QStringList m_images; |
||||
}; |
||||
|
||||
void TestResolutions::testResolutions_data() |
||||
{ |
||||
// The list of available wallpaper image sizes
|
||||
m_images << QStringLiteral("1280x1024") |
||||
<< QStringLiteral("1350x1080") |
||||
<< QStringLiteral("1440x1080") |
||||
<< QStringLiteral("1600x1200") |
||||
<< QStringLiteral("1920x1080") |
||||
<< QStringLiteral("1920x1200") |
||||
<< QStringLiteral("3840x2400"); |
||||
qDebug() << "Available images:"; |
||||
foreach( auto image, m_images) { |
||||
qDebug() << formatResolution(image); |
||||
} |
||||
|
||||
// The list of possible screen resolutions to test and the appropiate images that should be chosen
|
||||
QTest::addColumn<QString>("resolution"); |
||||
QTest::addColumn<QString>("expected"); |
||||
QTest::newRow("1280x1024") << QStringLiteral("1280x1024") << QStringLiteral("1280x1024"); |
||||
QTest::newRow("1350x1080") << QStringLiteral("1350x1080") << QStringLiteral("1350x1080"); |
||||
QTest::newRow("1440x1080") << QStringLiteral("1440x1080") << QStringLiteral("1440x1080"); |
||||
QTest::newRow("1600x1200") << QStringLiteral("1600x1200") << QStringLiteral("1600x1200"); |
||||
QTest::newRow("1920x1080") << QStringLiteral("1920x1080") << QStringLiteral("1920x1080"); |
||||
QTest::newRow("1920x1200") << QStringLiteral("1920x1200") << QStringLiteral("1920x1200"); |
||||
QTest::newRow("3840x2400") << QStringLiteral("3840x2400") << QStringLiteral("3840x2400"); |
||||
QTest::newRow("4096x2160") << QStringLiteral("4096x2160") << QStringLiteral("1920x1080"); |
||||
QTest::newRow("3840x2160") << QStringLiteral("3840x2160") << QStringLiteral("1920x1080"); |
||||
QTest::newRow("3200x1800") << QStringLiteral("3200x1800") << QStringLiteral("1920x1080"); |
||||
QTest::newRow("2048x1080") << QStringLiteral("2048x1080") << QStringLiteral("1920x1080"); |
||||
QTest::newRow("1680x1050") << QStringLiteral("1680x1050") << QStringLiteral("1920x1200"); |
||||
QTest::newRow("1400x1050") << QStringLiteral("1400x1050") << QStringLiteral("1440x1080"); |
||||
QTest::newRow("1440x900") << QStringLiteral("1440x900") << QStringLiteral("1920x1200"); |
||||
QTest::newRow("1280x960") << QStringLiteral("1280x960") << QStringLiteral("1440x1080"); |
||||
QTest::newRow("1280x854") << QStringLiteral("1280x854") << QStringLiteral("1920x1200"); |
||||
QTest::newRow("1280x800") << QStringLiteral("1280x800") << QStringLiteral("1920x1200"); |
||||
QTest::newRow("1280x720") << QStringLiteral("1280x720") << QStringLiteral("1920x1080"); |
||||
QTest::newRow("1152x768") << QStringLiteral("1152x768") << QStringLiteral("1920x1200"); |
||||
QTest::newRow("1024x768") << QStringLiteral("1024x768") << QStringLiteral("1440x1080"); |
||||
QTest::newRow("800x600") << QStringLiteral("800x600") << QStringLiteral("1440x1080"); |
||||
QTest::newRow("848x480") << QStringLiteral("848x480") << QStringLiteral("1920x1080"); |
||||
QTest::newRow("720x480") << QStringLiteral("720x480") << QStringLiteral("1920x1200"); |
||||
QTest::newRow("640x480") << QStringLiteral("640x480") << QStringLiteral("1440x1080"); |
||||
QTest::newRow("1366x768") << QStringLiteral("1366x768") << QStringLiteral("1920x1080"); |
||||
QTest::newRow("1600x814") << QStringLiteral("1600x814") << QStringLiteral("1920x1080"); |
||||
} |
||||
|
||||
void TestResolutions::testResolutions() |
||||
{ |
||||
QFETCH(QString, resolution); |
||||
QFETCH(QString, expected); |
||||
|
||||
m_image.setTargetSize( resSize( resolution ) ); |
||||
QString preferred = m_image.findPreferedImage(m_images); |
||||
|
||||
qDebug() << "For a screen size of " << formatResolution(resolution) |
||||
<< " the " << formatResolution(preferred) << " wallpaper was preferred"; |
||||
|
||||
QCOMPARE(preferred, expected); |
||||
} |
||||
|
||||
QTEST_MAIN(TestResolutions) |
||||
#include "testfindpreferredimage.moc" |
||||
Loading…
Reference in new issue