From aaf315eae6c376342627380928127d493a4a377e Mon Sep 17 00:00:00 2001 From: Swift Kim Date: Tue, 29 Jun 2021 15:31:38 +0900 Subject: [PATCH 1/3] Remove device_profile --- .../tizen/channels/text_input_channel.cc | 22 +++---- shell/platform/tizen/flutter_tizen_engine.cc | 57 +++++++------------ shell/platform/tizen/flutter_tizen_engine.h | 4 -- 3 files changed, 34 insertions(+), 49 deletions(-) diff --git a/shell/platform/tizen/channels/text_input_channel.cc b/shell/platform/tizen/channels/text_input_channel.cc index 627be2a6c197e..20b364dc0e801 100644 --- a/shell/platform/tizen/channels/text_input_channel.cc +++ b/shell/platform/tizen/channels/text_input_channel.cc @@ -425,13 +425,13 @@ bool TextInputChannel::FilterEvent(Ecore_Event_Key* event) { imf_event.dev_name = is_ime ? "ime" : ""; imf_event.keycode = event->keycode; +#ifdef WEARABLE_PROFILE + // FIXME: Only for wearable. if (is_ime && strcmp(event->key, "Select") == 0) { - if (engine_->device_profile == DeviceProfile::kWearable) { - // FIXME: for wearable - in_select_mode_ = true; - FT_LOGI("Set select mode[true]"); - } + in_select_mode_ = true; + FT_LOGI("Set select mode[true]"); } +#endif if (is_ime) { if (!strcmp(event->key, "Left") || !strcmp(event->key, "Right") || @@ -458,24 +458,26 @@ bool TextInputChannel::FilterEvent(Ecore_Event_Key* event) { last_handled_ecore_event_keyname_ = event->keyname; } - if (!handled && !strcmp(event->key, "Return") && in_select_mode_ && - engine_->device_profile == DeviceProfile::kWearable) { +#ifdef WEARABLE_PROFILE + if (!handled && !strcmp(event->key, "Return") && in_select_mode_) { in_select_mode_ = false; handled = true; FT_LOGI("Set select mode[false]"); } +#endif return handled; } void TextInputChannel::NonIMFFallback(Ecore_Event_Key* event) { - // For mobile, fix me! - if (engine_->device_profile == DeviceProfile::kMobile && - edit_status_ == EditStatus::kPreeditEnd) { +#ifdef MOBILE_PROFILE + // FIXME: Only for mobile. + if (edit_status_ == EditStatus::kPreeditEnd) { SetEditStatus(EditStatus::kNone); FT_LOGW("Ignore key-event[%s]!", event->keyname); return; } +#endif bool select = !strcmp(event->key, "Select"); bool is_filtered = true; diff --git a/shell/platform/tizen/flutter_tizen_engine.cc b/shell/platform/tizen/flutter_tizen_engine.cc index 309182e1461ab..4ae538f102fb7 100644 --- a/shell/platform/tizen/flutter_tizen_engine.cc +++ b/shell/platform/tizen/flutter_tizen_engine.cc @@ -13,35 +13,29 @@ #include "flutter/shell/platform/tizen/tizen_log.h" +namespace flutter { + +namespace { + // Unique number associated with platform tasks. -static constexpr size_t kPlatformTaskRunnerIdentifier = 1; +constexpr size_t kPlatformTaskRunnerIdentifier = 1; #ifdef TIZEN_RENDERER_EVAS_GL -static constexpr size_t kRenderTaskRunnerIdentifier = 2; +constexpr size_t kRenderTaskRunnerIdentifier = 2; #endif -namespace flutter { +#if defined(MOBILE_PROFILE) +constexpr double kProfileFactor = 0.7; +#elif defined(WEARABLE_PROFILE) +constexpr double kProfileFactor = 0.4; +#elif defined(TV_PROFILE) +constexpr double kProfileFactor = 2.0; +#else +constexpr double kProfileFactor = 1.0; +#endif -static DeviceProfile GetDeviceProfile() { - char* feature_profile; - system_info_get_platform_string("http://tizen.org/feature/profile", - &feature_profile); - std::string profile(feature_profile); - free(feature_profile); - - if (profile == "mobile") { - return DeviceProfile::kMobile; - } else if (profile == "wearable") { - return DeviceProfile::kWearable; - } else if (profile == "tv") { - return DeviceProfile::kTV; - } else if (profile == "common") { - return DeviceProfile::kCommon; - } - return DeviceProfile::kUnknown; -} +} // namespace -FlutterTizenEngine::FlutterTizenEngine(bool headed) - : device_profile(GetDeviceProfile()) { +FlutterTizenEngine::FlutterTizenEngine(bool headed) { embedder_api_.struct_size = sizeof(FlutterEngineProcTable); FlutterEngineGetProcAddresses(&embedder_api_); @@ -341,19 +335,12 @@ void FlutterTizenEngine::SendWindowMetrics(int32_t width, // The scale factor is computed based on the display DPI and the current // profile. A fixed DPI value (72) is used on TVs. See: // https://docs.tizen.org/application/native/guides/ui/efl/multiple-screens +#ifdef TV_PROFILE double dpi = 72.0; - if (renderer && device_profile != DeviceProfile::kTV) { - dpi = static_cast(renderer->GetDpi()); - } - double profile_factor = 1.0; - if (device_profile == DeviceProfile::kWearable) { - profile_factor = 0.4; - } else if (device_profile == DeviceProfile::kMobile) { - profile_factor = 0.7; - } else if (device_profile == DeviceProfile::kTV) { - profile_factor = 2.0; - } - double scale_factor = dpi / 90.0 * profile_factor; +#else + double dpi = static_cast(renderer->GetDpi()); +#endif + double scale_factor = dpi / 90.0 * kProfileFactor; event.pixel_ratio = std::max(scale_factor, 1.0); } else { event.pixel_ratio = pixel_ratio; diff --git a/shell/platform/tizen/flutter_tizen_engine.h b/shell/platform/tizen/flutter_tizen_engine.h index 1ccdd63ac66a7..882cf931c0355 100644 --- a/shell/platform/tizen/flutter_tizen_engine.h +++ b/shell/platform/tizen/flutter_tizen_engine.h @@ -56,8 +56,6 @@ struct AOTDataDeleter { using UniqueAotDataPtr = std::unique_ptr<_FlutterEngineAOTData, AOTDataDeleter>; -enum DeviceProfile { kUnknown, kMobile, kWearable, kTV, kCommon }; - // Manages state associated with the underlying FlutterEngine. class FlutterTizenEngine : public TizenRenderer::Delegate { public: @@ -140,8 +138,6 @@ class FlutterTizenEngine : public TizenRenderer::Delegate { std::unique_ptr text_input_channel; std::unique_ptr platform_view_channel; - const DeviceProfile device_profile; - private: bool IsHeaded() { return renderer != nullptr; } UniqueAotDataPtr LoadAotData(std::string aot_data_path); From 3f1ec68977b1e97e114cafb46dbe1425cd5d90bd Mon Sep 17 00:00:00 2001 From: Swift Kim Date: Tue, 29 Jun 2021 20:54:49 +0900 Subject: [PATCH 2/3] Remove flutter:: from key_event_channel.cc --- shell/platform/tizen/channels/key_event_channel.cc | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/shell/platform/tizen/channels/key_event_channel.cc b/shell/platform/tizen/channels/key_event_channel.cc index ae91615b65ff4..c71c3685f12b8 100644 --- a/shell/platform/tizen/channels/key_event_channel.cc +++ b/shell/platform/tizen/channels/key_event_channel.cc @@ -257,8 +257,8 @@ void KeyEventChannel::SendKeyEvent(Ecore_Event_Key* key, channel_->Send(event, [callback = std::move(callback)](const uint8_t* reply, size_t reply_size) { if (reply != nullptr) { - auto decoded = flutter::JsonMessageCodec::GetInstance().DecodeMessage( - reply, reply_size); + auto decoded = + JsonMessageCodec::GetInstance().DecodeMessage(reply, reply_size); bool handled = (*decoded)[kHandledKey].GetBool(); callback(handled); } From 34c0a84dfe686d03d9ae48417e146ed0ef5af9ea Mon Sep 17 00:00:00 2001 From: Swift Kim Date: Tue, 29 Jun 2021 21:09:38 +0900 Subject: [PATCH 3/3] Remove system_info dependency --- shell/platform/tizen/BUILD.gn | 1 - shell/platform/tizen/flutter_tizen_engine.cc | 2 -- 2 files changed, 3 deletions(-) diff --git a/shell/platform/tizen/BUILD.gn b/shell/platform/tizen/BUILD.gn index 67c1ad08a5622..98981a99aadff 100644 --- a/shell/platform/tizen/BUILD.gn +++ b/shell/platform/tizen/BUILD.gn @@ -110,7 +110,6 @@ template("embedder_for_profile") { "base-utils-i18n", "capi-appfw-application", "capi-base-common", - "capi-system-info", "capi-system-system-settings", "dlog", "ecore", diff --git a/shell/platform/tizen/flutter_tizen_engine.cc b/shell/platform/tizen/flutter_tizen_engine.cc index 4ae538f102fb7..067ec0edf4c05 100644 --- a/shell/platform/tizen/flutter_tizen_engine.cc +++ b/shell/platform/tizen/flutter_tizen_engine.cc @@ -5,8 +5,6 @@ #include "flutter_tizen_engine.h" -#include - #include #include #include