From a1c5a011421840f4b2f9d8b6cc9b9724cf333168 Mon Sep 17 00:00:00 2001 From: Loic Blot Date: Sun, 11 Mar 2018 17:45:58 +0100 Subject: [PATCH] Fix Android build, but there is a remaining linking issue in guiConfirmRegistration * Also fix variable name overloading in guiConfirmRegistration --- build/android/jni/Android.mk | 2 +- src/gui/guiConfirmRegistration.cpp | 35 +++++++++++++++--------------- src/gui/guiFormSpecMenu.cpp | 2 +- src/gui/intlGUIEditBox.h | 12 ++++++++++ 4 files changed, 31 insertions(+), 20 deletions(-) diff --git a/build/android/jni/Android.mk b/build/android/jni/Android.mk index 6aa658af3..a69c96465 100644 --- a/build/android/jni/Android.mk +++ b/build/android/jni/Android.mk @@ -160,12 +160,12 @@ LOCAL_SRC_FILES := \ jni/src/gui/guiTable.cpp \ jni/src/guiscalingfilter.cpp \ jni/src/gui/guiVolumeChange.cpp \ + jni/src/gui/intlGUIEditBox.cpp \ jni/src/gui/profilergraph.cpp \ jni/src/gui/touchscreengui.cpp \ jni/src/httpfetch.cpp \ jni/src/hud.cpp \ jni/src/imagefilters.cpp \ - jni/src/gui/intlGUIEditBox.cpp \ jni/src/inventory.cpp \ jni/src/inventorymanager.cpp \ jni/src/itemdef.cpp \ diff --git a/src/gui/guiConfirmRegistration.cpp b/src/gui/guiConfirmRegistration.cpp index 3e6fd96c2..6228ea29b 100644 --- a/src/gui/guiConfirmRegistration.cpp +++ b/src/gui/guiConfirmRegistration.cpp @@ -20,12 +20,11 @@ with this program; if not, write to the Free Software Foundation, Inc., #include "guiConfirmRegistration.h" #include "client.h" -#include "intlGUIEditBox.h" #include -#include #include #include #include +#include "intlGUIEditBox.h" #include "gettext.h" @@ -86,8 +85,8 @@ void GUIConfirmRegistration::regenerateGui(v2u32 screensize) std::string address = m_address; if (address.empty()) address = "localhost"; - core::rect rect(0, 0, 540, 180); - rect += topleft_client + v2s32(30, ypos); + core::rect rect2(0, 0, 540, 180); + rect2 += topleft_client + v2s32(30, ypos); static const std::string info_text_template = strgettext( "You are about to join the server at %1$s with the " "name \"%2$s\" for the first time. If you proceed, a " @@ -100,9 +99,9 @@ void GUIConfirmRegistration::regenerateGui(v2u32 screensize) snprintf(info_text_buf, sizeof(info_text_buf), info_text_template.c_str(), address.c_str(), m_playername.c_str()); - gui::intlGUIEditBox *e = new gui::intlGUIEditBox( + gui::IGUIEditBox *e = new gui::intlGUIEditBox( utf8_to_wide_c(info_text_buf), true, Environment, this, - ID_message, rect, false, true); + ID_message, rect2, false, true); e->drop(); e->setMultiLine(true); e->setWordWrap(true); @@ -111,34 +110,34 @@ void GUIConfirmRegistration::regenerateGui(v2u32 screensize) ypos += 210; { - core::rect rect(0, 0, 540, 30); - rect += topleft_client + v2s32(30, ypos); + core::rect rect2(0, 0, 540, 30); + rect2 += topleft_client + v2s32(30, ypos); gui::IGUIEditBox *e = Environment->addEditBox(m_pass_confirm.c_str(), - rect, true, this, ID_confirmPassword); + rect2, true, this, ID_confirmPassword); e->setPasswordBox(true); } ypos += 60; { - core::rect rect(0, 0, 230, 35); - rect = rect + v2s32(size.X / 2 - 220, ypos); + core::rect rect2(0, 0, 230, 35); + rect2 = rect2 + v2s32(size.X / 2 - 220, ypos); text = wgettext("Register and Join"); - Environment->addButton(rect, this, ID_confirm, text); + Environment->addButton(rect2, this, ID_confirm, text); delete[] text; } { - core::rect rect(0, 0, 120, 35); - rect = rect + v2s32(size.X / 2 + 70, ypos); + core::rect rect2(0, 0, 120, 35); + rect2 = rect2 + v2s32(size.X / 2 + 70, ypos); text = wgettext("Cancel"); - Environment->addButton(rect, this, ID_cancel, text); + Environment->addButton(rect2, this, ID_cancel, text); delete[] text; } { - core::rect rect(0, 0, 200, 20); - rect += topleft_client + v2s32(30, ypos - 40); + core::rect rect2(0, 0, 200, 20); + rect2 += topleft_client + v2s32(30, ypos - 40); text = wgettext("Passwords do not match!"); IGUIElement *e = Environment->addStaticText( - text, rect, false, true, this, ID_message); + text, rect2, false, true, this, ID_message); e->setVisible(false); delete[] text; } diff --git a/src/gui/guiFormSpecMenu.cpp b/src/gui/guiFormSpecMenu.cpp index dfb167ce7..eb80f6ed7 100644 --- a/src/gui/guiFormSpecMenu.cpp +++ b/src/gui/guiFormSpecMenu.cpp @@ -1039,7 +1039,7 @@ void GUIFormSpecMenu::createTextField(parserData *data, FieldSpec &spec, } if (e) { - if (is_editable && spec.fname == data->focused_fieldname) + if (is_editable && spec.fname == data->focused_fieldname) Environment->setFocus(e); if (is_multiline) { diff --git a/src/gui/intlGUIEditBox.h b/src/gui/intlGUIEditBox.h index aa35e2e71..7ebdaf1b7 100644 --- a/src/gui/intlGUIEditBox.h +++ b/src/gui/intlGUIEditBox.h @@ -57,9 +57,13 @@ namespace gui //! Sets whether to draw the background virtual void setDrawBackground(bool draw); + virtual bool isDrawBackgroundEnabled() const { return true; } + //! Turns the border on or off virtual void setDrawBorder(bool border); + virtual bool isDrawBorderEnabled() const { return Border; } + //! Enables or disables word wrap for using the edit box as multiline text editor. virtual void setWordWrap(bool enable); @@ -129,6 +133,14 @@ namespace gui //! Reads attributes of the element virtual void deserializeAttributes(io::IAttributes* in, io::SAttributeReadWriteOptions* options); + virtual void setCursorChar(const wchar_t cursorChar) {} + + virtual wchar_t getCursorChar() const { return L'|'; } + + virtual void setCursorBlinkTime(u32 timeMs) {} + + virtual u32 getCursorBlinkTime() const { return 500; } + protected: //! Breaks the single text line. void breakText();