summaryrefslogtreecommitdiff
path: root/vcl/android
diff options
context:
space:
mode:
authorTor Lillqvist <tml@iki.fi>2013-02-27 21:00:02 +0200
committerTor Lillqvist <tml@iki.fi>2013-02-27 21:00:53 +0200
commit7cf5fea49991cce9198d43d63a5fb403234f6d4c (patch)
tree99cb6def8167de9c1f90642e5661d3b6d6bcc464 /vcl/android
parent86d734c03bcb57d11347404e2cbc7586981bc6e4 (diff)
Send text input to the LO code
Change-Id: I28070fb1a8b85c9737d2a78a8a713243ce47dde9
Diffstat (limited to 'vcl/android')
-rw-r--r--vcl/android/androidinst.cxx29
1 files changed, 28 insertions, 1 deletions
diff --git a/vcl/android/androidinst.cxx b/vcl/android/androidinst.cxx
index 2bdcf8a61508..b94855df1c75 100644
--- a/vcl/android/androidinst.cxx
+++ b/vcl/android/androidinst.cxx
@@ -39,6 +39,7 @@
#define LOGTAG "LibreOffice/androidinst"
#define LOGI(...) ((void)__android_log_print(ANDROID_LOG_INFO, LOGTAG, __VA_ARGS__))
+#define LOGW(...) ((void)__android_log_print(ANDROID_LOG_WARN, LOGTAG, __VA_ARGS__))
#define LOGE(...) ((void)__android_log_print(ANDROID_LOG_ERROR, LOGTAG, __VA_ARGS__))
static bool bHitIdle = false;
@@ -463,6 +464,8 @@ void AndroidSalInstance::onAppCmd (struct android_app* app, int32_t cmd)
}
}
+#endif
+
/*
* Try too hard to get a frame, in the absence of anything better to do
*/
@@ -486,6 +489,8 @@ SalFrame *AndroidSalInstance::getFocusFrame() const
return pFocus;
}
+#if 0
+
int32_t AndroidSalInstance::onInputEvent (struct android_app* app, AInputEvent* event)
{
bool bHandled = false;
@@ -960,7 +965,7 @@ typedef struct ANativeWindow_Buffer {
extern "C" SAL_JNI_EXPORT void JNICALL
Java_org_libreoffice_experimental_desktop_Desktop_setViewSize(JNIEnv * /* env */,
- jobject /* object */,
+ jobject /* clazz */,
jint width,
jint height)
{
@@ -969,4 +974,26 @@ Java_org_libreoffice_experimental_desktop_Desktop_setViewSize(JNIEnv * /* env */
viewHeight = height;
}
+extern "C" SAL_JNI_EXPORT void JNICALL
+Java_org_libreoffice_experimental_desktop_Desktop_key(JNIEnv * /* env */,
+ jobject /* clazz */,
+ jchar c,
+ jshort timestamp)
+{
+ SalKeyEvent aEvent;
+
+ aEvent.mnCharCode = c;
+ aEvent.mnTime = timestamp;
+ aEvent.mnCode = c;
+ aEvent.mnRepeat = 0;
+
+ SalFrame *pFocus = AndroidSalInstance::getInstance()->getFocusFrame();
+ if (pFocus) {
+ pFocus->CallCallback( SALEVENT_KEYINPUT, &aEvent );
+ pFocus->CallCallback( SALEVENT_KEYUP, &aEvent );
+ }
+ else
+ LOGW("No focused frame to emit event on");
+}
+
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */