summaryrefslogtreecommitdiff
path: root/platform/android/src/android_renderer_frontend.cpp
diff options
context:
space:
mode:
authorKiyong Jung <autoexec.bat@navercorp.com>2018-08-16 19:32:20 +0900
committerTobrun <tobrun@mapbox.com>2018-08-21 11:53:05 +0200
commit5297f563a4dd6a9d25c7f45714d54d45897f3bb0 (patch)
treea0a029564babb80675c143b7fb12b748896cc7c6 /platform/android/src/android_renderer_frontend.cpp
parent7fc872b797679ae033a32246206efb06c98a0fd5 (diff)
downloadqtlocation-mapboxgl-5297f563a4dd6a9d25c7f45714d54d45897f3bb0.tar.gz
[android] Make AndroidRendererFrontend to request render once per event loop (#12586)
When AndroidRendererFrontend::update() called multiple times in a single loop, updateAsyncTask->send() will perform nothing, thus MapRenderer::update()/requestRender() will be coalesced.
Diffstat (limited to 'platform/android/src/android_renderer_frontend.cpp')
-rw-r--r--platform/android/src/android_renderer_frontend.cpp11
1 files changed, 8 insertions, 3 deletions
diff --git a/platform/android/src/android_renderer_frontend.cpp b/platform/android/src/android_renderer_frontend.cpp
index 2a03d9de9e..8b4a25a4d9 100644
--- a/platform/android/src/android_renderer_frontend.cpp
+++ b/platform/android/src/android_renderer_frontend.cpp
@@ -4,6 +4,7 @@
#include <mbgl/renderer/renderer.hpp>
#include <mbgl/renderer/renderer_observer.hpp>
#include <mbgl/storage/file_source.hpp>
+#include <mbgl/util/async_task.hpp>
#include <mbgl/util/thread.hpp>
#include <mbgl/util/run_loop.hpp>
@@ -56,7 +57,11 @@ private:
AndroidRendererFrontend::AndroidRendererFrontend(MapRenderer& mapRenderer_)
: mapRenderer(mapRenderer_)
- , mapRunLoop(util::RunLoop::Get()) {
+ , mapRunLoop(util::RunLoop::Get())
+ , updateAsyncTask(std::make_unique<util::AsyncTask>([this]() {
+ mapRenderer.update(std::move(updateParams));
+ mapRenderer.requestRender();
+ })) {
}
AndroidRendererFrontend::~AndroidRendererFrontend() = default;
@@ -73,8 +78,8 @@ void AndroidRendererFrontend::setObserver(RendererObserver& observer) {
}
void AndroidRendererFrontend::update(std::shared_ptr<UpdateParameters> params) {
- mapRenderer.update(std::move(params));
- mapRenderer.requestRender();
+ updateParams = std::move(params);
+ updateAsyncTask->send();
}
void AndroidRendererFrontend::reduceMemoryUse() {