diff options
author | Bent Bisballe Nyeng <deva@aasimon.org> | 2020-02-23 15:28:41 +0100 |
---|---|---|
committer | Bent Bisballe Nyeng <deva@aasimon.org> | 2020-03-07 19:07:00 +0100 |
commit | 0ea8c2f03ffacecb1b02aad4416ae52eb69aa5a1 (patch) | |
tree | 25d1fb447b5792db34533805b5d09d004537f351 /test | |
parent | ca4c3e6006c112503fe9be957353b4aa3bddfe69 (diff) |
Add UI benchmark test.
Diffstat (limited to 'test')
-rw-r--r-- | test/uitests/Makefile.am | 12 | ||||
-rw-r--r-- | test/uitests/benchmarktest.cc | 108 |
2 files changed, 119 insertions, 1 deletions
diff --git a/test/uitests/Makefile.am b/test/uitests/Makefile.am index 14cbf4e..e85190f 100644 --- a/test/uitests/Makefile.am +++ b/test/uitests/Makefile.am @@ -1,5 +1,5 @@ noinst_PROGRAMS = resizetest tabwidgettest framewidgettest \ - filebrowsertest + filebrowsertest benchmarktest resizetest_LDADD = $(top_srcdir)/plugingui/libdggui.la $(top_srcdir)/src/libdg.la resizetest_CXXFLAGS = \ @@ -36,3 +36,13 @@ framewidgettest_CXXFLAGS = \ framewidgettest_SOURCES = \ framewidgettest.cc \ $(top_srcdir)/hugin/hugin.c + +benchmarktest_LDADD = \ + $(top_srcdir)/plugingui/libdggui.la $(top_srcdir)/src/libdg.la +benchmarktest_CXXFLAGS = \ + -I$(top_srcdir)/plugingui \ + -I$(top_srcdir)/src \ + -I$(top_srcdir)/hugin +benchmarktest_SOURCES = \ + benchmarktest.cc \ + $(top_srcdir)/hugin/hugin.c diff --git a/test/uitests/benchmarktest.cc b/test/uitests/benchmarktest.cc new file mode 100644 index 0000000..c304877 --- /dev/null +++ b/test/uitests/benchmarktest.cc @@ -0,0 +1,108 @@ +/* -*- Mode: c++ -*- */ +/*************************************************************************** + * benchmarktest.cc + * + * Sun Feb 23 14:24:12 CET 2020 + * Copyright 2020 Bent Bisballe Nyeng + * deva@aasimon.org + ****************************************************************************/ + +/* + * This file is part of DrumGizmo. + * + * DrumGizmo is free software; you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * (at your option) any later version. + * + * DrumGizmo 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 Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with DrumGizmo; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. + */ +#include <chrono> +#include <iostream> +#include <cstdint> +#include <string> + +#include <image.h> +#include <painter.h> +#include <canvas.h> + +class TimedCanvas + : public GUI::Canvas +{ +public: + GUI::PixelBufferAlpha& GetPixelBuffer() override + { + return pixbuf; + } + +private: + GUI::PixelBufferAlpha pixbuf{800, 600}; +}; + +class TimedScope +{ +public: + using clock_t = std::chrono::steady_clock; + + TimedScope(const std::string& title, std::size_t iterations) + : title(title) + , iterations(iterations) + , begin(clock_t::now()) + {} + + ~TimedScope() + { + clock_t::time_point end= std::chrono::steady_clock::now(); + + auto micro_seconds = + std::chrono::duration_cast<std::chrono::microseconds>(end - begin).count(); + micro_seconds /= iterations; + std::cout << title << ": " << micro_seconds << " µs " << + "(" << (micro_seconds / 1000) << " ms)" << std::endl; + } + +private: + std::string title; + std::size_t iterations; + clock_t::time_point begin; +}; + +int main() +{ + TimedCanvas canvas; + GUI::Painter painter(canvas); + GUI::Image image(":resources/bg.png"); + + { + TimedScope timed("No scale", 10000); + for(int i = 0; i < 10000; ++i) + { + painter.drawImage(0, 0, image); + } + } + + { + TimedScope timed("Scaled 1:1", 2000); + for(int i = 0; i < 2000; ++i) + { + painter.drawImageStretched(0, 0, image, 370, 330); + } + } + + { + TimedScope timed("Scaled to window", 1000); + for(int i = 0; i < 1000; ++i) + { + painter.drawImageStretched(0, 0, image, 800, 6000); + } + } + + return 0; +} |