mirror of
https://github.com/dgis/emu48android
synced 2025-01-27 07:58:07 +01:00
Put Setting/Auto Zoom the default.
Improve the physical keyboard support.
This commit is contained in:
parent
c11edfc8d1
commit
74c362d374
4 changed files with 25 additions and 59 deletions
|
@ -54,13 +54,14 @@ NOT WORKING YET
|
||||||
|
|
||||||
CHANGES
|
CHANGES
|
||||||
|
|
||||||
Version 1.7beta2 (2019-11-03)
|
Version 1.7beta3 (2019-11-24)
|
||||||
|
|
||||||
- Updated source code from Eric Rechlin's Emu48 version 1.61+ that was merged from Christoph Gießelink's Emu48 version 1.62.
|
- Updated source code from Eric Rechlin's Emu48 version 1.61+ that was merged from Christoph Gießelink's Emu48 version 1.62.
|
||||||
- Allow to take a screenshot of the fullscreen including the skin.
|
- Allow to take a screenshot of the fullscreen including the skin.
|
||||||
- Add the KML Icon if present in the navigation menu header (only support PNG or 32bits BMP in the ICO file).
|
- Add the KML Icon if present in the navigation menu header (only support PNG or 32bits BMP in the ICO file).
|
||||||
- Add an optional overlapping LCD part stuck to the screen when swiping the 2 calc parts (Experimental).
|
- Add an optional overlapping LCD part stuck to the screen when swiping the 2 calc parts (Experimental).
|
||||||
- Improve loading speed by caching the KML folder.
|
- Improve loading speed by caching the KML folder.
|
||||||
|
- Support the transparency in the KML Global Color.
|
||||||
|
|
||||||
|
|
||||||
Version 1.6 (2019-07-15)
|
Version 1.6 (2019-07-15)
|
||||||
|
|
|
@ -54,13 +54,14 @@ NOT WORKING YET
|
||||||
|
|
||||||
CHANGES
|
CHANGES
|
||||||
|
|
||||||
Version 1.7beta2 (2019-11-03)
|
Version 1.7beta3 (2019-11-24)
|
||||||
|
|
||||||
- Updated source code from Eric Rechlin's Emu48 version 1.61+ that was merged from Christoph Gießelink's Emu48 version 1.62.
|
- Updated source code from Eric Rechlin's Emu48 version 1.61+ that was merged from Christoph Gießelink's Emu48 version 1.62.
|
||||||
- Allow to take a screenshot of the fullscreen including the skin.
|
- Allow to take a screenshot of the fullscreen including the skin.
|
||||||
- Add the KML Icon if present in the navigation menu header (only support PNG or 32bits BMP in the ICO file).
|
- Add the KML Icon if present in the navigation menu header (only support PNG or 32bits BMP in the ICO file).
|
||||||
- Add an optional overlapping LCD part stuck to the screen when swiping the 2 calc parts (Experimental).
|
- Add an optional overlapping LCD part stuck to the screen when swiping the 2 calc parts (Experimental).
|
||||||
- Improve loading speed by caching the KML folder.
|
- Improve loading speed by caching the KML folder.
|
||||||
|
- Support the transparency in the KML Global Color.
|
||||||
|
|
||||||
|
|
||||||
Version 1.6 (2019-07-15)
|
Version 1.6 (2019-07-15)
|
||||||
|
|
|
@ -159,7 +159,6 @@ public class LCDOverlappingView extends View {
|
||||||
previousY1 = -1.0f;
|
previousY1 = -1.0f;
|
||||||
break;
|
break;
|
||||||
case MotionEvent.ACTION_CANCEL:
|
case MotionEvent.ACTION_CANCEL:
|
||||||
break;
|
|
||||||
case MotionEvent.ACTION_OUTSIDE:
|
case MotionEvent.ACTION_OUTSIDE:
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -187,7 +186,6 @@ public class LCDOverlappingView extends View {
|
||||||
return -1;
|
return -1;
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case NativeLib.CALLBACK_TYPE_INVALIDATE:
|
case NativeLib.CALLBACK_TYPE_INVALIDATE:
|
||||||
//if(debug) Log.d(TAG, "PAINT updateCallback() postInvalidate()");
|
|
||||||
if(debug) Log.d(TAG, "updateCallback() CALLBACK_TYPE_INVALIDATE");
|
if(debug) Log.d(TAG, "updateCallback() CALLBACK_TYPE_INVALIDATE");
|
||||||
if(bitmapLCD.getWidth() > 1)
|
if(bitmapLCD.getWidth() > 1)
|
||||||
postInvalidate();
|
postInvalidate();
|
||||||
|
|
|
@ -66,46 +66,12 @@ public class MainScreenView extends PanAndScaleView {
|
||||||
enableZoomKeyboard = false;
|
enableZoomKeyboard = false;
|
||||||
|
|
||||||
charmap = new HashMap<>();
|
charmap = new HashMap<>();
|
||||||
charmap.put('A', 0x41); // A
|
|
||||||
charmap.put('B', 0x42); // B
|
|
||||||
charmap.put('C', 0x43); // C
|
|
||||||
charmap.put('D', 0x44); // D
|
|
||||||
charmap.put('E', 0x45); // E
|
|
||||||
charmap.put('F', 0x46); // F
|
|
||||||
charmap.put('G', 0x47); // G
|
|
||||||
charmap.put('H', 0x48); // H
|
|
||||||
charmap.put('I', 0x49); // I
|
|
||||||
charmap.put('J', 0x4A); // J
|
|
||||||
charmap.put('K', 0x4B); // K
|
|
||||||
charmap.put('L', 0x4C); // L
|
|
||||||
charmap.put('M', 0x4D); // M
|
|
||||||
charmap.put('N', 0x4E); // N
|
|
||||||
charmap.put('O', 0x4F); // O
|
|
||||||
charmap.put('P', 0x50); // P
|
|
||||||
charmap.put('Q', 0x51); // Q
|
|
||||||
charmap.put('R', 0x52); // R
|
|
||||||
charmap.put('S', 0x53); // S
|
|
||||||
charmap.put('T', 0x54); // T
|
|
||||||
charmap.put('U', 0x55); // U
|
|
||||||
charmap.put('V', 0x56); // V
|
|
||||||
charmap.put('W', 0x57); // W
|
|
||||||
charmap.put('X', 0x58); // X
|
|
||||||
charmap.put('Y', 0x59); // Y
|
|
||||||
charmap.put('Z', 0x5A); // Z
|
|
||||||
charmap.put('0', 0x60); // VK_0
|
|
||||||
charmap.put('1', 0x61); // VK_1
|
|
||||||
charmap.put('2', 0x62); // VK_2
|
|
||||||
charmap.put('3', 0x63); // VK_3
|
|
||||||
charmap.put('4', 0x64); // VK_4
|
|
||||||
charmap.put('5', 0x65); // VK_5
|
|
||||||
charmap.put('6', 0x66); // VK_6
|
|
||||||
charmap.put('7', 0x67); // VK_7
|
|
||||||
charmap.put('8', 0x68); // VK_8
|
|
||||||
charmap.put('9', 0x69); // VK_9
|
|
||||||
charmap.put('+', 0x6B); // VK_ADD
|
charmap.put('+', 0x6B); // VK_ADD
|
||||||
charmap.put('-', 0x6D); // VK_SUBTRACT
|
charmap.put('-', 0x6D); // VK_SUBTRACT
|
||||||
charmap.put('*', 0x6A); // VK_MULTIPLY
|
charmap.put('*', 0x6A); // VK_MULTIPLY
|
||||||
charmap.put('/', 0x6F); // VK_DIVIDE
|
charmap.put('/', 0x6F); // VK_DIVIDE
|
||||||
|
charmap.put('[', 0xDB); // VK_OEM_4
|
||||||
|
charmap.put(']', 0xDD); // VK_OEM_6
|
||||||
|
|
||||||
vkmap = new SparseIntArray();
|
vkmap = new SparseIntArray();
|
||||||
//vkmap.put(KeyEvent.KEYCODE_BACK, 0x08); // VK_BACK
|
//vkmap.put(KeyEvent.KEYCODE_BACK, 0x08); // VK_BACK
|
||||||
|
@ -151,16 +117,16 @@ public class MainScreenView extends PanAndScaleView {
|
||||||
vkmap.put(KeyEvent.KEYCODE_X, 0x58); // X
|
vkmap.put(KeyEvent.KEYCODE_X, 0x58); // X
|
||||||
vkmap.put(KeyEvent.KEYCODE_Y, 0x59); // Y
|
vkmap.put(KeyEvent.KEYCODE_Y, 0x59); // Y
|
||||||
vkmap.put(KeyEvent.KEYCODE_Z, 0x5A); // Z
|
vkmap.put(KeyEvent.KEYCODE_Z, 0x5A); // Z
|
||||||
vkmap.put(KeyEvent.KEYCODE_0, 0x60); // VK_NUMPAD0
|
vkmap.put(KeyEvent.KEYCODE_0, 0x30); //VK_0 0x60); // VK_NUMPAD0
|
||||||
vkmap.put(KeyEvent.KEYCODE_1, 0x61); // VK_NUMPAD1
|
vkmap.put(KeyEvent.KEYCODE_1, 0x31); //VK_1 0x61); // VK_NUMPAD1
|
||||||
vkmap.put(KeyEvent.KEYCODE_2, 0x62); // VK_NUMPAD2
|
vkmap.put(KeyEvent.KEYCODE_2, 0x32); //VK_2 0x62); // VK_NUMPAD2
|
||||||
vkmap.put(KeyEvent.KEYCODE_3, 0x63); // VK_NUMPAD3
|
vkmap.put(KeyEvent.KEYCODE_3, 0x33); //VK_3 0x63); // VK_NUMPAD3
|
||||||
vkmap.put(KeyEvent.KEYCODE_4, 0x64); // VK_NUMPAD4
|
vkmap.put(KeyEvent.KEYCODE_4, 0x34); //VK_4 0x64); // VK_NUMPAD4
|
||||||
vkmap.put(KeyEvent.KEYCODE_5, 0x65); // VK_NUMPAD5
|
vkmap.put(KeyEvent.KEYCODE_5, 0x35); //VK_5 0x65); // VK_NUMPAD5
|
||||||
vkmap.put(KeyEvent.KEYCODE_6, 0x66); // VK_NUMPAD6
|
vkmap.put(KeyEvent.KEYCODE_6, 0x36); //VK_6 0x66); // VK_NUMPAD6
|
||||||
vkmap.put(KeyEvent.KEYCODE_7, 0x67); // VK_NUMPAD7
|
vkmap.put(KeyEvent.KEYCODE_7, 0x37); //VK_7 0x67); // VK_NUMPAD7
|
||||||
vkmap.put(KeyEvent.KEYCODE_8, 0x68); // VK_NUMPAD8
|
vkmap.put(KeyEvent.KEYCODE_8, 0x38); //VK_8 0x68); // VK_NUMPAD8
|
||||||
vkmap.put(KeyEvent.KEYCODE_9, 0x69); // VK_NUMPAD9
|
vkmap.put(KeyEvent.KEYCODE_9, 0x39); //VK_9 0x69); // VK_NUMPAD9
|
||||||
vkmap.put(KeyEvent.KEYCODE_NUMPAD_0, 0x60); // VK_NUMPAD0
|
vkmap.put(KeyEvent.KEYCODE_NUMPAD_0, 0x60); // VK_NUMPAD0
|
||||||
vkmap.put(KeyEvent.KEYCODE_NUMPAD_1, 0x61); // VK_NUMPAD1
|
vkmap.put(KeyEvent.KEYCODE_NUMPAD_1, 0x61); // VK_NUMPAD1
|
||||||
vkmap.put(KeyEvent.KEYCODE_NUMPAD_2, 0x62); // VK_NUMPAD2
|
vkmap.put(KeyEvent.KEYCODE_NUMPAD_2, 0x62); // VK_NUMPAD2
|
||||||
|
@ -179,13 +145,11 @@ public class MainScreenView extends PanAndScaleView {
|
||||||
vkmap.put(KeyEvent.KEYCODE_NUMPAD_DOT, 0x6E); // VK_DECIMAL
|
vkmap.put(KeyEvent.KEYCODE_NUMPAD_DOT, 0x6E); // VK_DECIMAL
|
||||||
vkmap.put(KeyEvent.KEYCODE_SLASH, 0x6F); // VK_DIVIDE
|
vkmap.put(KeyEvent.KEYCODE_SLASH, 0x6F); // VK_DIVIDE
|
||||||
vkmap.put(KeyEvent.KEYCODE_NUMPAD_DIVIDE, 0x6F); // VK_DIVIDE
|
vkmap.put(KeyEvent.KEYCODE_NUMPAD_DIVIDE, 0x6F); // VK_DIVIDE
|
||||||
// vkmap.put(KeyEvent.KEYCODE_SEMICOLON, 0xBA); // VK_OEM_1 (:);)
|
|
||||||
vkmap.put(KeyEvent.KEYCODE_COMMA, 0xBC); // VK_OEM_COMMA
|
vkmap.put(KeyEvent.KEYCODE_COMMA, 0xBC); // VK_OEM_COMMA
|
||||||
vkmap.put(KeyEvent.KEYCODE_PERIOD, 0xBE); // VK_OEM_PERIOD
|
vkmap.put(KeyEvent.KEYCODE_PERIOD, 0xBE); // VK_OEM_PERIOD
|
||||||
// vkmap.put(KeyEvent.0x2C, 0xBF); // VK_OEM_2 (?)
|
vkmap.put(KeyEvent.KEYCODE_SEMICOLON, 0xBA); // VK_OEM_1 (:);)
|
||||||
// vkmap.put(KeyEvent.0x32, 0xC0); // VK_OEM_3 (~)
|
vkmap.put(KeyEvent.KEYCODE_APOSTROPHE, 0xDE); // VK_OEM_7 (‘ »)
|
||||||
// vkmap.put(KeyEvent.KEYCODE_LEFT_BRACKET, 0xDB); // VK_OEM_4 ([{)
|
vkmap.put(KeyEvent.KEYCODE_BACKSLASH, 0xDC); // VK_OEM_5 (\|)
|
||||||
// vkmap.put(KeyEvent.0x27, 0xDE); // VK_OEM_7 (‘ »)
|
|
||||||
|
|
||||||
this.setFocusable(true);
|
this.setFocusable(true);
|
||||||
this.setFocusableInTouchMode(true);
|
this.setFocusableInTouchMode(true);
|
||||||
|
@ -234,14 +198,15 @@ public class MainScreenView extends PanAndScaleView {
|
||||||
public boolean onKeyDown(int keyCode, KeyEvent event) {
|
public boolean onKeyDown(int keyCode, KeyEvent event) {
|
||||||
if((event.getFlags() & KeyEvent.FLAG_VIRTUAL_HARD_KEY) == 0) {
|
if((event.getFlags() & KeyEvent.FLAG_VIRTUAL_HARD_KEY) == 0) {
|
||||||
char pressedKey = (char) event.getUnicodeChar();
|
char pressedKey = (char) event.getUnicodeChar();
|
||||||
if(debug) Log.d(TAG, "onKeyDown is: " + pressedKey);
|
|
||||||
Integer windowsKeycode = charmap.get(pressedKey);
|
Integer windowsKeycode = charmap.get(pressedKey);
|
||||||
if(windowsKeycode == null)
|
if(windowsKeycode == null)
|
||||||
windowsKeycode = vkmap.get(keyCode);
|
windowsKeycode = vkmap.get(keyCode);
|
||||||
|
if(debug) Log.d(TAG, String.format("onKeyDown keyCode: 0x%x (%d), unicodeChar: '%c' 0x%x (%d) -> windowsKeycode: 0x%x (%d)",
|
||||||
|
keyCode, keyCode, pressedKey, (int)pressedKey, (int)pressedKey, windowsKeycode, windowsKeycode));
|
||||||
if (windowsKeycode != 0)
|
if (windowsKeycode != 0)
|
||||||
NativeLib.keyDown(windowsKeycode);
|
NativeLib.keyDown(windowsKeycode);
|
||||||
else if(debug) Log.e(TAG, String.format("Unknown keyCode: %d", keyCode));
|
else if(debug) Log.e(TAG, String.format("Unknown keyCode: %d", keyCode));
|
||||||
if(keyCode == KeyEvent.KEYCODE_BACK)
|
if(keyCode == KeyEvent.KEYCODE_BACK || keyCode == KeyEvent.KEYCODE_TAB)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return super.onKeyDown(keyCode, event);
|
return super.onKeyDown(keyCode, event);
|
||||||
|
@ -251,14 +216,15 @@ public class MainScreenView extends PanAndScaleView {
|
||||||
public boolean onKeyUp(int keyCode, KeyEvent event) {
|
public boolean onKeyUp(int keyCode, KeyEvent event) {
|
||||||
if((event.getFlags() & KeyEvent.FLAG_VIRTUAL_HARD_KEY) == 0) {
|
if((event.getFlags() & KeyEvent.FLAG_VIRTUAL_HARD_KEY) == 0) {
|
||||||
char pressedKey = (char) event.getUnicodeChar();
|
char pressedKey = (char) event.getUnicodeChar();
|
||||||
if(debug) Log.d(TAG, "onKeyUp is: " + pressedKey);
|
|
||||||
Integer windowsKeycode = charmap.get(pressedKey);
|
Integer windowsKeycode = charmap.get(pressedKey);
|
||||||
if(windowsKeycode == null)
|
if(windowsKeycode == null)
|
||||||
windowsKeycode = vkmap.get(keyCode);
|
windowsKeycode = vkmap.get(keyCode);
|
||||||
|
if(debug) Log.d(TAG, String.format("onKeyUp keyCode: 0x%x (%d), unicodeChar: '%c' 0x%x (%d) -> windowsKeycode: 0x%x (%d)",
|
||||||
|
keyCode, keyCode, pressedKey, (int)pressedKey, (int)pressedKey, windowsKeycode, windowsKeycode));
|
||||||
if (windowsKeycode != 0)
|
if (windowsKeycode != 0)
|
||||||
NativeLib.keyUp(windowsKeycode);
|
NativeLib.keyUp(windowsKeycode);
|
||||||
else if(debug) Log.e(TAG, String.format("Unknown keyCode: %d", keyCode));
|
else if(debug) Log.e(TAG, String.format("Unknown keyCode: %d", keyCode));
|
||||||
if(keyCode == KeyEvent.KEYCODE_BACK)
|
if(keyCode == KeyEvent.KEYCODE_BACK || keyCode == KeyEvent.KEYCODE_TAB)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return super.onKeyUp(keyCode, event);
|
return super.onKeyUp(keyCode, event);
|
||||||
|
|
Loading…
Add table
Reference in a new issue