From 8c01123a48b0e6d5c14584fde274964bfae3d161 Mon Sep 17 00:00:00 2001 From: Daniele Gobbetti Date: Sun, 4 Dec 2016 19:10:58 +0100 Subject: [PATCH] Liveview: addressed the first feedback. - centralized string encoding and byte order - replaced printStrackTrace with LOG.error --- .../devices/liveview/LiveviewConstants.java | 10 +++ .../devices/liveview/LiveviewIoThread.java | 13 ++-- .../devices/liveview/LiveviewProtocol.java | 72 ++++++++----------- 3 files changed, 45 insertions(+), 50 deletions(-) diff --git a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/devices/liveview/LiveviewConstants.java b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/devices/liveview/LiveviewConstants.java index 3b9fd03d5..48786c241 100644 --- a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/devices/liveview/LiveviewConstants.java +++ b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/devices/liveview/LiveviewConstants.java @@ -1,6 +1,10 @@ package nodomain.freeyourgadget.gadgetbridge.devices.liveview; //Changed by Renze: Fixed brightness constants +import java.nio.ByteOrder; +import java.nio.charset.Charset; +import java.nio.charset.StandardCharsets; + /** * Message constants reverse-engineered by Andrew de Quincey (http://adq.livejournal.com). @@ -9,6 +13,12 @@ package nodomain.freeyourgadget.gadgetbridge.devices.liveview; */ public final class LiveviewConstants { + public static Charset ENCODING = StandardCharsets.ISO_8859_1; + public static ByteOrder BYTE_ORDER = ByteOrder.BIG_ENDIAN; + + public static final byte CLOCK_24H = 0; + public static final byte CLOCK_12H = 1; + public static final byte MSG_GETCAPS = 1; public static final byte MSG_GETCAPS_RESP = 2; diff --git a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/liveview/LiveviewIoThread.java b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/liveview/LiveviewIoThread.java index b3dea9dd4..9f6c2c752 100644 --- a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/liveview/LiveviewIoThread.java +++ b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/liveview/LiveviewIoThread.java @@ -14,10 +14,10 @@ import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.nio.ByteBuffer; -import java.nio.ByteOrder; import java.util.UUID; import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEvent; +import nodomain.freeyourgadget.gadgetbridge.devices.liveview.LiveviewConstants; import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice; import nodomain.freeyourgadget.gadgetbridge.service.serial.GBDeviceIoThread; import nodomain.freeyourgadget.gadgetbridge.service.serial.GBDeviceProtocol; @@ -45,7 +45,7 @@ public class LiveviewIoThread extends GBDeviceIoThread { try { mBtSocket.close(); } catch (IOException e) { - e.printStackTrace(); + LOG.error(e.getMessage()); } } } @@ -99,6 +99,7 @@ public class LiveviewIoThread extends GBDeviceIoThread { } } catch (IOException e) { + if (e.getMessage() != null && e.getMessage().contains("socket closed")) { //FIXME: this does not feel right LOG.info(e.getMessage()); mIsConnected = false; @@ -116,7 +117,7 @@ public class LiveviewIoThread extends GBDeviceIoThread { try { mBtSocket.close(); } catch (IOException e) { - e.printStackTrace(); + LOG.error(e.getMessage()); } mBtSocket = null; } @@ -143,8 +144,8 @@ public class LiveviewIoThread extends GBDeviceIoThread { mOutStream = mBtSocket.getOutputStream(); setUpdateState(GBDevice.State.CONNECTED); } catch (IOException e) { - e.printStackTrace(); - LOG.error("Server socket cannot be started"); + LOG.error("Server socket cannot be started."); + //LOG.error(e.getMessage()); setUpdateState(originalState); mInStream = null; mOutStream = null; @@ -214,7 +215,7 @@ public class LiveviewIoThread extends GBDeviceIoThread { private int getLastInt(ByteArrayOutputStream stream) { byte[] array = stream.toByteArray(); ByteBuffer buffer = ByteBuffer.wrap(array, array.length - 4, 4); - buffer.order(ByteOrder.BIG_ENDIAN); + buffer.order(LiveviewConstants.BYTE_ORDER); return buffer.getInt(); } } diff --git a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/liveview/LiveviewProtocol.java b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/liveview/LiveviewProtocol.java index 061aadb7f..27d38d7cd 100644 --- a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/liveview/LiveviewProtocol.java +++ b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/liveview/LiveviewProtocol.java @@ -1,8 +1,6 @@ package nodomain.freeyourgadget.gadgetbridge.service.devices.liveview; -import java.io.UnsupportedEncodingException; import java.nio.ByteBuffer; -import java.nio.ByteOrder; import java.util.Calendar; import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEvent; @@ -14,11 +12,6 @@ import nodomain.freeyourgadget.gadgetbridge.service.serial.GBDeviceProtocol; public class LiveviewProtocol extends GBDeviceProtocol { - @Override - public GBDevice getDevice() { - return super.getDevice(); - } - @Override public byte[] encodeFindDevice(boolean start) { return encodeVibrateRequest((short) 100, (short) 200); @@ -67,8 +60,9 @@ public class LiveviewProtocol extends GBDeviceProtocol { time += Calendar.getInstance().get(Calendar.ZONE_OFFSET) / 1000; time += Calendar.getInstance().get(Calendar.DST_OFFSET) / 1000; ByteBuffer buffer = ByteBuffer.allocate(5); + buffer.order(LiveviewConstants.BYTE_ORDER); buffer.putInt(time); - buffer.put((byte) 0); // 24 hour + buffer.put(LiveviewConstants.CLOCK_24H); return constructMessage(LiveviewConstants.MSG_GETTIME_RESP, buffer.array()); } @@ -85,30 +79,25 @@ public class LiveviewProtocol extends GBDeviceProtocol { String footerText = (null != notificationSpec.sourceName) ? notificationSpec.sourceName : ""; String bodyText = (null != notificationSpec.body) ? notificationSpec.body : ""; - try { - byte[] headerTextArray = headerText.getBytes("iso-8859-1"); - byte[] footerTextArray = footerText.getBytes("iso-8859-1"); - byte[] bodyTextArray = bodyText.getBytes("iso-8859-1"); - int size = 15 + headerTextArray.length + bodyTextArray.length + footerTextArray.length; - ByteBuffer buffer = ByteBuffer.allocate(size); - buffer.put((byte) 1); - buffer.putShort((short) 0); - buffer.putShort((short) 0); - buffer.putShort((short) 0); - buffer.put((byte) 80); //should alert but it doesn't make the liveview vibrate + byte[] headerTextArray = headerText.getBytes(LiveviewConstants.ENCODING); + byte[] footerTextArray = footerText.getBytes(LiveviewConstants.ENCODING); + byte[] bodyTextArray = bodyText.getBytes(LiveviewConstants.ENCODING); + int size = 15 + headerTextArray.length + bodyTextArray.length + footerTextArray.length; + ByteBuffer buffer = ByteBuffer.allocate(size); + buffer.put((byte) 1); + buffer.putShort((short) 0); + buffer.putShort((short) 0); + buffer.putShort((short) 0); + buffer.put((byte) 80); //should alert but it doesn't make the liveview vibrate - buffer.put((byte) 0); //0 is for plaintext vs bitmapimage (1) strings - buffer.putShort((short) headerTextArray.length); - buffer.put(headerTextArray); - buffer.putShort((short) bodyTextArray.length); - buffer.put(bodyTextArray); - buffer.putShort((short) footerTextArray.length); - buffer.put(footerTextArray); - return constructMessage(LiveviewConstants.MSG_DISPLAYPANEL, buffer.array()); - } catch (UnsupportedEncodingException e) { - e.printStackTrace(); - return encodeVibrateRequest((short) 100, (short) 200); - } + buffer.put((byte) 0); //0 is for plaintext vs bitmapimage (1) strings + buffer.putShort((short) headerTextArray.length); + buffer.put(headerTextArray); + buffer.putShort((short) bodyTextArray.length); + buffer.put(bodyTextArray); + buffer.putShort((short) footerTextArray.length); + buffer.put(footerTextArray); + return constructMessage(LiveviewConstants.MSG_DISPLAYPANEL, buffer.array()); } @@ -116,7 +105,7 @@ public class LiveviewProtocol extends GBDeviceProtocol { public static byte[] constructMessage(byte messageType, byte[] payload) { ByteBuffer msgBuffer = ByteBuffer.allocate(payload.length + 6); - msgBuffer.order(ByteOrder.BIG_ENDIAN); + msgBuffer.order(LiveviewConstants.BYTE_ORDER); msgBuffer.put(messageType); msgBuffer.put((byte) 4); msgBuffer.putInt(payload.length); @@ -126,23 +115,18 @@ public class LiveviewProtocol extends GBDeviceProtocol { public byte[] encodeVibrateRequest(short delay, short time) { ByteBuffer buffer = ByteBuffer.allocate(4); - buffer.order(ByteOrder.BIG_ENDIAN); + buffer.order(LiveviewConstants.BYTE_ORDER); buffer.putShort(delay); buffer.putShort(time); return constructMessage(LiveviewConstants.MSG_SETVIBRATE, buffer.array()); } public byte[] encodeCapabilitiesRequest() { - try { - byte[] version = LiveviewConstants.CLIENT_SOFTWARE_VERSION.getBytes("iso-8859-1"); - ByteBuffer buffer = ByteBuffer.allocate(version.length + 1); - buffer.order(ByteOrder.BIG_ENDIAN); - buffer.put((byte) version.length); - buffer.put(version); - return constructMessage(LiveviewConstants.MSG_GETCAPS, buffer.array()); - } catch (UnsupportedEncodingException e) { - e.printStackTrace(); - } - return null; + byte[] version = LiveviewConstants.CLIENT_SOFTWARE_VERSION.getBytes(LiveviewConstants.ENCODING); + ByteBuffer buffer = ByteBuffer.allocate(version.length + 1); + buffer.order(LiveviewConstants.BYTE_ORDER); + buffer.put((byte) version.length); + buffer.put(version); + return constructMessage(LiveviewConstants.MSG_GETCAPS, buffer.array()); } }