本文整理匯總了C++中AKeyEvent_getKeyCode函數的典型用法代碼示例。如果您正苦於以下問題:C++ AKeyEvent_getKeyCode函數的具體用法?C++ AKeyEvent_getKeyCode怎麽用?C++ AKeyEvent_getKeyCode使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了AKeyEvent_getKeyCode函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。
示例1: key_ascii
/**
* Convert an Android key event to ASCII.
*/
static unsigned char key_ascii(struct android_app* app, AInputEvent* event) {
int32_t code = AKeyEvent_getKeyCode(event);
/* Handle a few special cases: */
switch (code) {
case AKEYCODE_DEL:
return 8;
case AKEYCODE_FORWARD_DEL:
return 127;
case AKEYCODE_ESCAPE:
return 27;
}
/* Get usable JNI context */
JNIEnv* env = app->activity->env;
JavaVM* vm = app->activity->vm;
(*vm)->AttachCurrentThread(vm, &env, NULL);
jclass KeyEventClass = (*env)->FindClass(env, "android/view/KeyEvent");
jmethodID KeyEventConstructor = (*env)->GetMethodID(env, KeyEventClass, "<init>", "(II)V");
jobject keyEvent = (*env)->NewObject(env, KeyEventClass, KeyEventConstructor,
AKeyEvent_getAction(event), AKeyEvent_getKeyCode(event));
jmethodID KeyEvent_getUnicodeChar = (*env)->GetMethodID(env, KeyEventClass, "getUnicodeChar", "(I)I");
int ascii = (*env)->CallIntMethod(env, keyEvent, KeyEvent_getUnicodeChar, AKeyEvent_getMetaState(event));
/* LOGI("getUnicodeChar(%d) = %d ('%c')", AKeyEvent_getKeyCode(event), ascii, ascii); */
return ascii;
}
示例2: packt_Log_debug
bool InputService::onKeyboardEvent(AInputEvent* pEvent) {
#ifdef INPUTSERVICE_LOG_EVENTS
packt_Log_debug("AKeyEvent_getAction=%d", AKeyEvent_getAction(pEvent));
packt_Log_debug("AKeyEvent_getFlags=%d", AKeyEvent_getFlags(pEvent));
packt_Log_debug("AKeyEvent_getKeyCode=%d", AKeyEvent_getKeyCode(pEvent));
packt_Log_debug("AKeyEvent_getScanCode=%d", AKeyEvent_getScanCode(pEvent));
packt_Log_debug("AKeyEvent_getMetaState=%d", AKeyEvent_getMetaState(pEvent));
packt_Log_debug("AKeyEvent_getRepeatCount=%d", AKeyEvent_getRepeatCount(pEvent));
packt_Log_debug("AKeyEvent_getDownTime=%lld", AKeyEvent_getDownTime(pEvent));
packt_Log_debug("AKeyEvent_getEventTime=%lld", AKeyEvent_getEventTime(pEvent));
#endif
const float ORTHOGONAL_MOVE = 1.0f;
if (AKeyEvent_getAction(pEvent) == AKEY_EVENT_ACTION_DOWN) {
switch (AKeyEvent_getKeyCode(pEvent)) {
case AKEYCODE_DPAD_LEFT:
mHorizontal = -ORTHOGONAL_MOVE;
break;
case AKEYCODE_DPAD_RIGHT:
mHorizontal = ORTHOGONAL_MOVE;
break;
case AKEYCODE_DPAD_DOWN:
mVertical = -ORTHOGONAL_MOVE;
break;
case AKEYCODE_DPAD_UP:
mVertical = ORTHOGONAL_MOVE;
break;
case AKEYCODE_BACK:
return false;
}
} else {
switch (AKeyEvent_getKeyCode(pEvent)) {
case AKEYCODE_DPAD_LEFT:
case AKEYCODE_DPAD_RIGHT:
mHorizontal = 0.0f;
break;
case AKEYCODE_DPAD_DOWN:
case AKEYCODE_DPAD_UP:
mVertical = 0.0f;
break;
case AKEYCODE_MENU:
mMenuKey = true;
break;
case AKEYCODE_BACK:
return false;
}
}
return true;
}
示例3: input
static int32_t input(struct android_app * app, AInputEvent * e) {
int handled = 1;
int kc;
cvkey cvkc;
int action;
switch (AInputEvent_getType(e)) {
case AINPUT_EVENT_TYPE_KEY:
kc = AKeyEvent_getKeyCode(e);
action = AKeyEvent_getAction(e);
cvkc = mapkey(kc);
handled = kc != CVK_NONE;
if (handled) {
if (action == AKEY_EVENT_ACTION_DOWN)
cvInject(CVE_DOWN, cvkc, 0);
if (action == AKEY_EVENT_ACTION_UP)
cvInject(CVE_UP, cvkc, 0);
}
break;
case AINPUT_EVENT_TYPE_MOTION:
cvInject(CVE_MOTION,
AMotionEvent_getX(e, 0), AMotionEvent_getY(e, 0));
break;
default:
handled = 0;
}
return handled;
}
示例4: _process_keys
static bool _process_keys(bool isJoy, AInputEvent *event, CookedEventCallback callback) {
if (AInputEvent_getType(event) == AINPUT_EVENT_TYPE_KEY) {
int action = AKeyEvent_getAction(event);
int code = _translate_keycode(AKeyEvent_getKeyCode(event));
bool handled = code >= 0;
if (code >= 0 && action == AKEY_EVENT_ACTION_DOWN) {
_report_key_state(code, true, callback);
} else if (code >= 0 && action == AKEY_EVENT_ACTION_UP) {
_report_key_state(code, false, callback);
}
return handled;
} else if (isJoy) {
// use joystick axes to emulate directional key events (we could leave this
// up to the platform, but joystick-to-dpad conversion doesn't work
// on NDK on older devices, so we implement manually for maximum compatibility)
float x = AMotionEvent_getX(event, 0);
float y = AMotionEvent_getY(event, 0);
if (_getAxisValue) {
// take the hat switches into account too, so that either the
// regular axes or the hat axes can be used to navigate UIs
x += _getAxisValue(event, AXIS_HAT_X, 0);
y += _getAxisValue(event, AXIS_HAT_Y, 0);
x = Clamp(x, -1.0f, 1.0f);
y = Clamp(y, -1.0f, 1.0f);
}
_report_key_states_from_axes(x, y, callback);
return true;
}
}
示例5: handle_input_events
int32_t handle_input_events(struct android_app* app, AInputEvent* event) {
int etype = AInputEvent_getType(event);
switch (etype) {
case AINPUT_EVENT_TYPE_KEY:
int32_t eaction, eflags, ekeycode, escancode;
eaction = AKeyEvent_getAction(event);
eflags = AKeyEvent_getFlags(event);
ekeycode = AKeyEvent_getKeyCode(event);
// LOGI(2, "%s", get_key_event_str(eaction, eflags, ekeycode));
break;
case AINPUT_EVENT_TYPE_MOTION:
int32_t action, posX, pointer_index;
action = AMotionEvent_getAction(event);
pointer_index = (action&AMOTION_EVENT_ACTION_POINTER_INDEX_MASK) >> AMOTION_EVENT_ACTION_POINTER_INDEX_SHIFT;
posX = AMotionEvent_getX(event, pointer_index);
//write a command to the activity lifecycle event queue (pipe)
if (action == AMOTION_EVENT_ACTION_MOVE) {
int xMove = posX - mPreviousX;
USERDATA* userData = (USERDATA*)app->userData;
userData->xMove = xMove;
app->redrawNeeded = 1;
}
mPreviousX = posX;
// LOGI(2, "action: %d, posX: %d, mPreviousX: %d, posX: %d", action, posX, mPreviousX, posX);
break;
default:
LOGI(2, "other input event");
break;
}
}
示例6: CookEvent
bool CookEvent(AInputEvent *event, CookedEventCallback callback) {
int type = AInputEvent_getType(event);
int src = AInputEvent_getSource(event);
bool isJoy = (type == AINPUT_EVENT_TYPE_MOTION) && (src & AINPUT_SOURCE_CLASS_MASK) ==
SOURCE_CLASS_JOYSTICK;
if (!_init_done) {
_init();
_init_done = true;
}
if (isJoy) {
return CookEvent_Joy(event, callback);
} else if (type == AINPUT_EVENT_TYPE_KEY) {
bool handled = _process_keys(false, event, callback);
if (AKeyEvent_getKeyCode(event) == AKEYCODE_BACK && 0 == AKeyEvent_getAction(event)) {
// back key was pressed
struct CookedEvent ev;
memset(&ev, 0, sizeof(ev));
ev.type = COOKED_EVENT_TYPE_BACK;
return callback(&ev);
}
// Note: if you want to handle other keys, add code here. For now we only
// handle DPAD keys as indicated in _process_keys.
return handled;
} else if (type == AINPUT_EVENT_TYPE_MOTION) {
return CookEvent_Motion(event, callback);
}
return false;
}
示例7: AKeyEvent_getKeyCode
/**
* @brief
* Call this to process the next key input event
*/
void AndroidKeyboardDevice::OnKeyInputEvent(const struct AInputEvent &cAKeyInputEvent)
{
// Check if input device is valid
if (m_pDevice) {
// Get Android key code
const int32_t nKeyCode = AKeyEvent_getKeyCode(&cAKeyInputEvent);
// Lookout! The virtual keyboard of Android sends "down" and "up" directly one after another
// -> This is really a problem and we have to delay further keys...
if (m_lstProcessedKeys.IsElement(nKeyCode)) {
// Add key for later processing
KeyInfo sKeyInfo;
sKeyInfo.nKeyCode = nKeyCode;
sKeyInfo.bPressed = (AKeyEvent_getAction(&cAKeyInputEvent) == AKEY_EVENT_ACTION_DOWN);
m_lstDelayedKeys.Add(sKeyInfo);
} else {
// Get keyboard device
Keyboard *pKeyboard = static_cast<Keyboard*>(m_pDevice);
// Get button
Button *pButton = GetKeyboardKey(*pKeyboard, nKeyCode);
if (pButton) {
// Get button state
const bool bPressed = (AKeyEvent_getAction(&cAKeyInputEvent) == AKEY_EVENT_ACTION_DOWN);
// Propagate changes
if (pButton->IsPressed() != bPressed)
pButton->SetPressed(bPressed);
}
// Add this key to the processed keys
m_lstProcessedKeys.Add(nKeyCode);
}
}
}
示例8: AKeyEvent_getKeyCode
event_result message_dispatcher::fire_on_dpad(app& the_app, AInputEvent *ie)
{
int kcode = AKeyEvent_getKeyCode(ie);
int type = AKeyEvent_getAction(ie);
bool h = false;
switch (kcode) {
case AKEYCODE_DPAD_UP:
h = the_app.on_dpad_up(type == AKEY_EVENT_ACTION_DOWN ? button_event::down : button_event::up);
break;
case AKEYCODE_DPAD_DOWN:
h = the_app.on_dpad_down(type == AKEY_EVENT_ACTION_DOWN ? button_event::down : button_event::up);
break;
case AKEYCODE_DPAD_LEFT:
h = the_app.on_dpad_left(type == AKEY_EVENT_ACTION_DOWN ? button_event::down : button_event::up);
break;
case AKEYCODE_DPAD_RIGHT:
h = the_app.on_dpad_right(type == AKEY_EVENT_ACTION_DOWN ? button_event::down : button_event::up);
break;
case AKEYCODE_DPAD_CENTER:
h = the_app.on_dpad_center(type == AKEY_EVENT_ACTION_DOWN ? button_event::down : button_event::up);
break;
default:
break;
}
return h ? event_result::handled : event_result::unhandled;
}
示例9: get_key_event
///// キー入力イベント処理
void get_key_event(struct android_app* app, AInputEvent* event) {
struct engine* engine = (struct engine*) app->userData;
int keyaction;
// キーコードを取得
int keycode = AKeyEvent_getKeyCode(event); /////-----(1) ここから
// 音量キー(上)の入力が変化した
if (keycode == AKEYCODE_VOLUME_UP) { /////-----(1) ここまで
keyaction = AKeyEvent_getAction(event); /////-----(2) ここから
if (keyaction == AKEY_EVENT_ACTION_DOWN) { /////-----(2) ここまで
// キーを押した
engine->volumeup_keydown = TRUE;
} else {
// キーを離した
engine->volumeup_keydown = FALSE;
}
}
// 音量キー(下)の入力変化した
if (keycode == AKEYCODE_VOLUME_DOWN) {
keyaction = AKeyEvent_getAction(event);
if (keyaction == AKEY_EVENT_ACTION_DOWN) {
// キーを押した
engine->volumedown_keydown = TRUE;
} else {
// キーを離した
engine->volumedown_keydown = FALSE;
}
}
}
示例10: handle_key_input
/*
* Handle Key Inputs
*/
static int32_t handle_key_input(AInputEvent *event)
{
if (AKeyEvent_getAction(event) == AKEY_EVENT_ACTION_UP)
{
auto dispatcher = cocos2d::Director::getInstance()->getEventDispatcher();
switch (AKeyEvent_getKeyCode(event))
{
case AKEYCODE_BACK:
{
cocos2d::EventKeyboard event(cocos2d::EventKeyboard::KeyCode::KEY_BACKSPACE, false);
dispatcher->dispatchEvent(&event);
}
return 1;
case AKEYCODE_MENU:
{
cocos2d::EventKeyboard event(cocos2d::EventKeyboard::KeyCode::KEY_MENU, false);
dispatcher->dispatchEvent(&event);
}
return 1;
default:
break;
}
}
return 0;
}
示例11: handleInput
static int32_t handleInput(struct android_app* app, AInputEvent* event)
{
if (okit.getInput())
{
if (AInputEvent_getType(event) == AINPUT_EVENT_TYPE_MOTION)
{
int action = (int)(AMOTION_EVENT_ACTION_MASK & AMotionEvent_getAction(event));
if (action == 0)
okit.injectTouch(2, AMotionEvent_getRawX(event, 0), AMotionEvent_getRawY(event, 0));
okit.injectTouch(action, AMotionEvent_getRawX(event, 0), AMotionEvent_getRawY(event, 0));
}
else
{
int action = AKeyEvent_getAction(event);
int unicodeChar = 0;
okit.injectKey(action, unicodeChar, AKeyEvent_getKeyCode(event));
//mInputInjector->injectKeyEvent(AKeyEvent_getAction(event), AKeyEvent_getKeyCode(event));
}
return 1;
}
return 0;
}
示例12: process_input
static void process_input(struct android_app* app, struct android_poll_source* source) {
AInputEvent* event = NULL;
if (AInputQueue_getEvent(app->inputQueue, &event) >= 0) {
// HACK: Override back buttom to show / hide keyboard.
int type = AInputEvent_getType(event);
if(type == AINPUT_EVENT_TYPE_KEY) {
if(AKeyEvent_getAction(event) == AKEY_EVENT_ACTION_DOWN) {
static bool keyboard_shown = false;
if( AKeyEvent_getKeyCode(event) == AKEYCODE_BACK ) {
displayKeyboard(app,!keyboard_shown);
keyboard_shown = !keyboard_shown;
AInputQueue_finishEvent(app->inputQueue, event, 1);
return;
}
}
}
if (AInputQueue_preDispatchEvent(app->inputQueue, event)) {
return;
}
int32_t handled = 0;
if (app->onInputEvent != NULL) handled = app->onInputEvent(app, event);
AInputQueue_finishEvent(app->inputQueue, event, handled);
} else {
LOGE("Failure reading next input event: %s\n", strerror(errno));
}
}
示例13: input_eventcallback
static int32_t input_eventcallback(struct android_app* app, AInputEvent* event)
{
int32_t type = AInputEvent_getType(event);
AndroidApplication* a = (AndroidApplication*)app->userData;
switch (type)
{
case AINPUT_EVENT_TYPE_MOTION:
switch (AInputEvent_getSource(event))
{
case AINPUT_SOURCE_TOUCHSCREEN:
return a->eventManager()->processTouchEvent(event);
break;
}
break;
case AINPUT_EVENT_TYPE_KEY:
Log::debug("EVENT INPUT OK");
switch(AKeyEvent_getKeyCode(event))
{
case AKEYCODE_BACK:
return 1;
break;
}
return 0;
break;
}
}
示例14: AMotionEvent_getAction
int32_t AndroidAppHelper::handleInput (struct android_app* app, AInputEvent* event)
{
if (mInputInjector)
{
if (AInputEvent_getType (event) == AINPUT_EVENT_TYPE_MOTION)
{
int action = (int) (AMOTION_EVENT_ACTION_MASK & AMotionEvent_getAction (event));
if (action == 0)
{
mInputInjector->injectTouchEvent (2, AMotionEvent_getRawX (event, 0),
AMotionEvent_getRawY (event, 0));
}
mInputInjector->injectTouchEvent (action, AMotionEvent_getRawX (event, 0),
AMotionEvent_getRawY (event, 0));
}
else
{
mInputInjector->injectKeyEvent (AKeyEvent_getAction (event), AKeyEvent_getKeyCode (event));
}
return 1;
}
return 0;
}
示例15: IN_Android_KeyEvent2UCS
/*
* IN_Android_KeyEvent2UCS
*/
static wchar_t IN_Android_KeyEvent2UCS( const AInputEvent *event )
{
JNIEnv *env = Sys_Android_GetJNIEnv();
static jclass mapClass;
static jmethodID load, get;
jobject map;
unsigned int ucs;
if( !mapClass )
{
jclass mapClassRef;
mapClassRef = (*env)->FindClass( env, "android/view/KeyCharacterMap" );
mapClass = (*env)->NewGlobalRef( env, mapClassRef );
load = (*env)->GetStaticMethodID( env, mapClass, "load", "(I)Landroid/view/KeyCharacterMap;" );
get = (*env)->GetMethodID( env, mapClass, "get", "(II)I" );
(*env)->DeleteLocalRef( env, mapClassRef );
}
map = (*env)->CallStaticObjectMethod( env, mapClass, load, AInputEvent_getDeviceId( event ) );
ucs = (*env)->CallIntMethod( env, map, get, AKeyEvent_getKeyCode( event ), AKeyEvent_getMetaState( event ) );
(*env)->DeleteLocalRef( env, map );
return ucs;
}