df6eb82f51
Target that have a touchpad/touchscreen should disable it while being locked (In order to avoid LCD to drain battery power due to "key locked" constant reporting messages. If they a have a keylock button this was already handled at driver level. If not (e.g. fuze+), they will have to implement a switch at driver level that action.c can operate on softlock. This patch does the following for any target having a touchpad or a touchscreen and no HAS_BUTTON_HOLD (ie any softlock target) 1) it implements the code to call button_enable_touch(bool en) in action.c. 2) button_enable_touch is implemented in button.c and call either touchpad_enable or touchscreen_enable 3) those two function are implemented respectively in touchscreen.c and a new touchpad.c file. They provide a generic way to silents touch's device and call a function at driver level where target specific code can be implemented if possible/needed (for power saving for instance). Those function name are touchpad_enable_device and touchscreen_enable_device 4) we implement an empty function at driver level of targets that need it to have them still being able to compiled. Change-Id: I9ead78a25bd33466a8533f5b9f259b395cb5ce49 Reviewed-on: http://gerrit.rockbox.org/569 Reviewed-by: Thomas Martitz <kugel@rockbox.org> Reviewed-by: Amaury Pouly <amaury.pouly@gmail.com>
172 lines
4.8 KiB
C
172 lines
4.8 KiB
C
/***************************************************************************
|
|
* __________ __ ___.
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
* \/ \/ \/ \/ \/
|
|
* $Id$
|
|
*
|
|
* Copyright (c) 2010 Thomas Martitz
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version 2
|
|
* of the License, or (at your option) any later version.
|
|
*
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
* KIND, either express or implied.
|
|
*
|
|
****************************************************************************/
|
|
|
|
|
|
#include <jni.h>
|
|
#include <stdbool.h>
|
|
#include "button.h"
|
|
#include "buttonmap.h"
|
|
#include "config.h"
|
|
#include "kernel.h"
|
|
#include "system.h"
|
|
#include "touchscreen.h"
|
|
#include "powermgmt.h"
|
|
|
|
extern JNIEnv *env_ptr;
|
|
extern jclass RockboxService_class;
|
|
extern jobject RockboxService_instance;
|
|
|
|
static int last_y, last_x;
|
|
static int last_btns;
|
|
|
|
static enum {
|
|
STATE_UNKNOWN,
|
|
STATE_UP,
|
|
STATE_DOWN,
|
|
} last_touch_state = STATE_UNKNOWN;
|
|
|
|
/*
|
|
* this notifies us in an interrupt-like fashion whether the user just
|
|
* began or stopped the touch action + where (pixel coordinates) */
|
|
JNIEXPORT void JNICALL
|
|
Java_org_rockbox_RockboxFramebuffer_touchHandler(JNIEnv*env, jobject this,
|
|
jboolean down, jint x, jint y)
|
|
{
|
|
(void)env;
|
|
(void)this;
|
|
|
|
if (down)
|
|
last_touch_state = STATE_DOWN;
|
|
else
|
|
last_touch_state = STATE_UP;
|
|
|
|
last_x = x;
|
|
last_y = y;
|
|
}
|
|
|
|
/*
|
|
* this writes in an interrupt-like fashion the button events that the user
|
|
* generated by pressing/releasing them to a variable */
|
|
JNIEXPORT bool JNICALL
|
|
Java_org_rockbox_RockboxFramebuffer_buttonHandler(JNIEnv*env, jclass class,
|
|
jint keycode, jboolean state)
|
|
{
|
|
(void)env;
|
|
(void)class;
|
|
|
|
unsigned button = 0;
|
|
|
|
if (!state)
|
|
{
|
|
button = multimedia_to_button((int)keycode);
|
|
if (!button)
|
|
button = dpad_to_button((int)keycode);
|
|
if (button)
|
|
{
|
|
/* ensure button_queue can be safely posted to */
|
|
wait_rockbox_ready();
|
|
reset_poweroff_timer();
|
|
queue_post(&button_queue, button, 0);
|
|
return true;
|
|
}
|
|
}
|
|
|
|
if (!button)
|
|
{
|
|
button = key_to_button(keycode);
|
|
}
|
|
|
|
if (button == BUTTON_NONE)
|
|
{
|
|
last_btns = button;
|
|
return false;
|
|
}
|
|
|
|
if (state)
|
|
{
|
|
last_btns |= button;
|
|
}
|
|
else
|
|
{
|
|
last_btns &= (~button);
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
void button_init_device(void)
|
|
{
|
|
JNIEnv e = *env_ptr;
|
|
jclass class = e->FindClass(env_ptr, "org/rockbox/monitors/HeadphoneMonitor");
|
|
jmethodID constructor = e->GetMethodID(env_ptr, class,
|
|
"<init>",
|
|
"(Landroid/content/Context;)V");
|
|
e->NewObject(env_ptr, class,
|
|
constructor,
|
|
RockboxService_instance);
|
|
/* when reaching this point, rockbox can be considered ready because the
|
|
* input system (button.c) is initialized. This implies the kernel and threading
|
|
* is up and running */
|
|
set_rockbox_ready();
|
|
}
|
|
|
|
void touchscreen_enable_device(bool en)
|
|
{
|
|
(void)en; /* FIXME: do something smart */
|
|
}
|
|
|
|
int button_read_device(int *data)
|
|
{
|
|
int btn = last_btns;
|
|
/* Get grid button/coordinates based on the current touchscreen mode
|
|
*
|
|
* Caveat: the caller seemingly depends on *data always being filled with
|
|
* the last known touchscreen position, so always call
|
|
* touchscreen_to_pixels() */
|
|
int touch = touchscreen_to_pixels(last_x, last_y, data);
|
|
|
|
if (last_touch_state == STATE_DOWN)
|
|
btn |= touch;
|
|
|
|
return btn;
|
|
}
|
|
|
|
static int hp_state;
|
|
JNIEXPORT void JNICALL
|
|
Java_org_rockbox_monitors_HeadphoneMonitor_postHpStateChanged(JNIEnv *env,
|
|
jobject this,
|
|
jint state)
|
|
{
|
|
(void)env; (void)this;
|
|
hp_state = state;
|
|
}
|
|
/* Tell if anything is in the jack.
|
|
*
|
|
* since this is called from the tick task, which isn't attached to
|
|
* the dalvik VM, it's not permitted to make JNI calls (therefore
|
|
* we need the above callback) */
|
|
bool headphones_inserted(void)
|
|
{
|
|
/* 0 is disconnected, 1 and 2 are connected */
|
|
return (hp_state == 0) ? false : true;
|
|
}
|
|
|