From f1ac3f29c3f1255299db6cf19f7a28d66014593d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C5=81ukasz=20Paczos?= Date: Thu, 14 Mar 2019 18:37:54 +0100 Subject: [android] text-color option for formatted sections --- platform/android/src/style/formatted.cpp | 40 ++++++++++++++++++-------------- 1 file changed, 22 insertions(+), 18 deletions(-) (limited to 'platform/android/src/style/formatted.cpp') diff --git a/platform/android/src/style/formatted.cpp b/platform/android/src/style/formatted.cpp index 8659e6961e..69c3454e23 100644 --- a/platform/android/src/style/formatted.cpp +++ b/platform/android/src/style/formatted.cpp @@ -1,5 +1,7 @@ #include "formatted.hpp" #include "formatted_section.hpp" +#include "../conversion/conversion.hpp" +#include "../conversion/constant.hpp" namespace mbgl { namespace android { @@ -11,36 +13,38 @@ void Formatted::registerNative(jni::JNIEnv& env) { jni::Local> Formatted::New(jni::JNIEnv& env, const style::expression::Formatted& value) { static auto& formatted = jni::Class::Singleton(env); static auto formattedConstructor = formatted.GetConstructor>>(env); - static auto& formattedSection = jni::Class::Singleton(env); + static auto& formattedSectionClass = jni::Class::Singleton(env); auto sections = jni::Array>::New(env, value.sections.size()); for (std::size_t i = 0; i < value.sections.size(); i++) { auto section = value.sections.at(i); auto text = jni::Make(env, section.text); + static auto formattedSectionConstructor = formattedSectionClass.GetConstructor(env); + auto formattedSection = formattedSectionClass.New(env, formattedSectionConstructor, text); - if (section.fontStack && section.fontScale) { + if (section.fontScale) { double fontScale = section.fontScale.value(); + static auto method = formattedSectionClass.GetMethod(env, "setFontScale"); + formattedSection.Call(env, method, jni::Box(env, fontScale)); + } + + if (section.fontStack) { auto fontStack = jni::Array::New(env, section.fontStack.value().size()); for (std::size_t j = 0; j < section.fontStack.value().size(); j++) { fontStack.Set(env, j, jni::Make(env, section.fontStack.value().at(j))); } - static auto formattedSectionConstructor = formattedSection.GetConstructor>(env); - sections.Set(env, i, formattedSection.New(env, formattedSectionConstructor, text, jni::Box(env, fontScale), fontStack)); - } else if (section.fontScale) { - double fontScale = section.fontScale.value(); - static auto formattedSectionConstructor = formattedSection.GetConstructor(env); - sections.Set(env, i, formattedSection.New(env, formattedSectionConstructor, text, jni::Box(env, fontScale))); - } else if (section.fontStack) { - auto fontStack = jni::Array::New(env, section.fontStack.value().size()); - for (std::size_t j = 0; j < section.fontStack.value().size(); j++) { - fontStack.Set(env, j, jni::Make(env, section.fontStack.value().at(j))); - } - static auto formattedSectionConstructor = formattedSection.GetConstructor>(env); - sections.Set(env, i, formattedSection.New(env, formattedSectionConstructor, text, fontStack)); - } else { - static auto formattedSectionConstructor = formattedSection.GetConstructor(env); - sections.Set(env, i, formattedSection.New(env, formattedSectionConstructor, text)); + static auto method = formattedSectionClass.GetMethod)>(env, "setFontStack"); + formattedSection.Call(env, method, fontStack); } + + if (section.textColor) { + using namespace mbgl::android::conversion; + auto textColor = std::move(*convert>>(env, *section.textColor)); + static auto method = formattedSectionClass.GetMethod)>(env, "setTextColor"); + formattedSection.Call(env, method, textColor); + } + + sections.Set(env, i, formattedSection); } return formatted.New(env, formattedConstructor, sections); -- cgit v1.2.1