mirror of
https://github.com/shagr4th/droid48
synced 2025-01-20 22:26:57 +01:00
Added multitouch support
- Bug fix for keycode mismatch 25 != 26 between up and down events from hardware keyboard - Multitouch support in order to allow the ability to press multiple keys simultaneously.
This commit is contained in:
parent
ce38fb6c90
commit
ca5733f5d0
1 changed files with 48 additions and 46 deletions
|
@ -38,7 +38,7 @@ public class HPView extends SurfaceView implements SurfaceHolder.Callback, Runna
|
||||||
boolean ann [];
|
boolean ann [];
|
||||||
int ann_pos [] = { 62, 105, 152, 197, 244, 287 };
|
int ann_pos [] = { 62, 105, 152, 197, 244, 287 };
|
||||||
private List<Integer> queuedCodes;
|
private List<Integer> queuedCodes;
|
||||||
private boolean touches [] = new boolean [MAX_TOUCHES];
|
private int touches [] = new int [MAX_TOUCHES];
|
||||||
protected boolean needFlip;
|
protected boolean needFlip;
|
||||||
private short buf [];
|
private short buf [];
|
||||||
private int currentOrientation;
|
private int currentOrientation;
|
||||||
|
@ -449,7 +449,7 @@ public class HPView extends SurfaceView implements SurfaceHolder.Callback, Runna
|
||||||
mainScreen.copyPixelsFromBuffer(ShortBuffer.wrap(data));
|
mainScreen.copyPixelsFromBuffer(ShortBuffer.wrap(data));
|
||||||
c.drawBitmap(mainScreen, matrixScreen, screenPaint);
|
c.drawBitmap(mainScreen, matrixScreen, screenPaint);
|
||||||
for(int i=0;i<MAX_TOUCHES;i++) {
|
for(int i=0;i<MAX_TOUCHES;i++) {
|
||||||
if (touches[i]) {
|
if (touches[i] != 0) {
|
||||||
c.drawRoundRect(new RectF(new Rect(buttons_coords[i][0], buttons_coords[i][1], buttons_coords[i][2], buttons_coords[i][3])), 12f, 12f, paint);
|
c.drawRoundRect(new RectF(new Rect(buttons_coords[i][0], buttons_coords[i][1], buttons_coords[i][2], buttons_coords[i][3])), 12f, 12f, paint);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -473,34 +473,53 @@ public class HPView extends SurfaceView implements SurfaceHolder.Callback, Runna
|
||||||
}
|
}
|
||||||
//Log.i("x48", "data: " + data.length);
|
//Log.i("x48", "data: " + data.length);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onTouchEvent(MotionEvent event) {
|
public boolean onTouchEvent(MotionEvent event) {
|
||||||
synchronized (mSurfaceHolder) {
|
synchronized (mSurfaceHolder) {
|
||||||
|
float x, y;
|
||||||
int action = event.getAction();
|
int action = event.getAction();
|
||||||
float x = event.getX();
|
int actionCode = action & MotionEvent.ACTION_MASK;
|
||||||
float y = event.getY();
|
|
||||||
//Log.i("x48", "action: " + action + " / x: " + x + " / y:" + y);
|
|
||||||
if (action != MotionEvent.ACTION_DOWN && action != MotionEvent.ACTION_UP)
|
|
||||||
return false;
|
|
||||||
int code = -1;
|
int code = -1;
|
||||||
|
int pointerID = 1;
|
||||||
|
|
||||||
|
if (actionCode == MotionEvent.ACTION_DOWN || actionCode == MotionEvent.ACTION_UP) {
|
||||||
|
x = event.getX();
|
||||||
|
y = event.getY();
|
||||||
|
} else if(actionCode == MotionEvent.ACTION_POINTER_DOWN || actionCode == MotionEvent.ACTION_POINTER_UP) {
|
||||||
|
pointerID = (action & MotionEvent.ACTION_POINTER_INDEX_MASK) >> MotionEvent.ACTION_POINTER_INDEX_SHIFT;
|
||||||
|
x = event.getX(pointerID);
|
||||||
|
y = event.getY(pointerID);
|
||||||
|
pointerID = event.getPointerId(pointerID) + 1;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
for(int i=0;i<MAX_TOUCHES;i++) {
|
// *_DOWN : lookup by coordinates
|
||||||
if (x >= buttons_coords[i][0] && x < buttons_coords[i][2] && y >= buttons_coords[i][1] && y < buttons_coords[i][3])
|
// *_UP : lookup by pointer pressed
|
||||||
{
|
if( actionCode != MotionEvent.ACTION_UP && actionCode != MotionEvent.ACTION_POINTER_UP ) {
|
||||||
code = i;
|
for(int i=0;i<MAX_TOUCHES;i++) {
|
||||||
break;
|
if (x >= buttons_coords[i][0] && x < buttons_coords[i][2] && y >= buttons_coords[i][1] && y < buttons_coords[i][3])
|
||||||
}
|
{
|
||||||
}
|
code = i;
|
||||||
if (code == -1 && action == MotionEvent.ACTION_DOWN && currentOrientation != Configuration.ORIENTATION_LANDSCAPE ) {
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for(int i=0;i<MAX_TOUCHES;i++) {
|
||||||
|
if(touches[i] == pointerID)
|
||||||
|
code = i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (code == -1 && actionCode == MotionEvent.ACTION_DOWN && currentOrientation != Configuration.ORIENTATION_LANDSCAPE ) {
|
||||||
//x48.flipkeyboard();
|
//x48.flipkeyboard();
|
||||||
((X48) getContext()).changeKeybLite();
|
((X48) getContext()).changeKeybLite();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (code > -1) {
|
if (code > -1) {
|
||||||
key(code, action == MotionEvent.ACTION_DOWN);
|
key(code, actionCode == MotionEvent.ACTION_DOWN || actionCode == MotionEvent.ACTION_POINTER_DOWN, pointerID);
|
||||||
return action == MotionEvent.ACTION_DOWN;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -517,51 +536,35 @@ public class HPView extends SurfaceView implements SurfaceHolder.Callback, Runna
|
||||||
this.keybLite = keybLite;
|
this.keybLite = keybLite;
|
||||||
}
|
}
|
||||||
|
|
||||||
public synchronized void key(int code, boolean down) {
|
public void key(int code, boolean down) {
|
||||||
|
key(code, down, 255); // Use pointerID 255 for keyboard
|
||||||
|
}
|
||||||
|
|
||||||
|
public synchronized void key(int code, boolean down, int pointerID) {
|
||||||
//Log.i("x48", "code: " + code + " / " + down);
|
//Log.i("x48", "code: " + code + " / " + down);
|
||||||
if (code < MAX_TOUCHES) {
|
if (code < MAX_TOUCHES) {
|
||||||
if (down) {
|
if (down) {
|
||||||
for(int i=0;i<MAX_TOUCHES;i++) {
|
|
||||||
if (touches[i]) {
|
|
||||||
Log.i("x48", "no multitouch !, force up of " + i);
|
|
||||||
queuedCodes.add(i + 100);
|
|
||||||
touches [i] = false;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Integer cI = code+1;
|
Integer cI = code+1;
|
||||||
if (!queuedCodes.contains(cI)) {
|
if (!queuedCodes.contains(cI)) {
|
||||||
queuedCodes.add(cI);
|
queuedCodes.add(cI);
|
||||||
touches [code] = true;
|
touches [code] = pointerID;
|
||||||
performHapticFeedback(HapticFeedbackConstants.LONG_PRESS,
|
performHapticFeedback(HapticFeedbackConstants.LONG_PRESS,
|
||||||
HapticFeedbackConstants.FLAG_IGNORE_GLOBAL_SETTING );
|
HapticFeedbackConstants.FLAG_IGNORE_GLOBAL_SETTING );
|
||||||
/*x48.flipScreen();*/
|
|
||||||
} else {
|
} else {
|
||||||
Log.i("x48", "rejected down");
|
Log.i("x48", "rejected down");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
Integer cI = code+100;
|
Integer cI = code+100;
|
||||||
if (!queuedCodes.contains(cI) && touches [code]) {
|
if (!queuedCodes.contains(cI) && touches [code] != 0) {
|
||||||
queuedCodes.add(cI);
|
queuedCodes.add(cI);
|
||||||
touches [code] = false;
|
touches [code] = 0;
|
||||||
/*x48.flipScreen();*/
|
|
||||||
} else {
|
} else {
|
||||||
Log.i("x48", "rejected up");
|
Log.i("x48", "rejected up");
|
||||||
for(int i=0;i<MAX_TOUCHES;i++) {
|
|
||||||
if (touches[i]) {
|
|
||||||
Log.i("x48", "forced up of " + i);
|
|
||||||
queuedCodes.add(i + 100);
|
|
||||||
touches [i] = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
//queuedCodes.add(code + 1);
|
|
||||||
//queuedCodes.add(cI);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
x48.flipScreen();
|
x48.flipScreen();
|
||||||
this.notify();
|
this.notify();
|
||||||
//pressed++;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -686,7 +689,7 @@ public class HPView extends SurfaceView implements SurfaceHolder.Callback, Runna
|
||||||
while (mRun) {
|
while (mRun) {
|
||||||
try {
|
try {
|
||||||
Thread.sleep(40);
|
Thread.sleep(40);
|
||||||
|
|
||||||
} catch (InterruptedException e) {
|
} catch (InterruptedException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
|
@ -768,11 +771,10 @@ public class HPView extends SurfaceView implements SurfaceHolder.Callback, Runna
|
||||||
case KeyEvent.KEYCODE_V: if (d) key(21, true); else key(21, false); return true;
|
case KeyEvent.KEYCODE_V: if (d) key(21, true); else key(21, false); return true;
|
||||||
case KeyEvent.KEYCODE_W: if (d) key(22, true); else key(22, false); return true;
|
case KeyEvent.KEYCODE_W: if (d) key(22, true); else key(22, false); return true;
|
||||||
case KeyEvent.KEYCODE_X: if (d) key(23, true); else key(23, false); return true;
|
case KeyEvent.KEYCODE_X: if (d) key(23, true); else key(23, false); return true;
|
||||||
case KeyEvent.KEYCODE_Y: if (d) key(25, true); else key(26, false); return true;
|
case KeyEvent.KEYCODE_Y: if (d) key(25, true); else key(25, false); return true;
|
||||||
case KeyEvent.KEYCODE_Z: if (d) key(26, true); else key(25, false); return true;
|
case KeyEvent.KEYCODE_Z: if (d) key(26, true); else key(26, false); return true;
|
||||||
case KeyEvent.KEYCODE_SPACE: if (d) key(47, true); else key(47, false); return true;
|
case KeyEvent.KEYCODE_SPACE: if (d) key(47, true); else key(47, false); return true;
|
||||||
|
|
||||||
|
|
||||||
//case KeyEvent.KEYCODE_SHIFT_LEFT: if (d) key(34, true); else key(34, false); return true;
|
//case KeyEvent.KEYCODE_SHIFT_LEFT: if (d) key(34, true); else key(34, false); return true;
|
||||||
//case KeyEvent.KEYCODE_SHIFT_RIGHT: if (d) key(39, true); else key(39, false); return true;
|
//case KeyEvent.KEYCODE_SHIFT_RIGHT: if (d) key(39, true); else key(39, false); return true;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue