# HG changeset patch # User oc # Date 1403093788 -32400 # Node ID 86289e56263c5e418c61b86d8fb1383a085ca7a4 # Parent c850c2fce0392f1ae75cce2282ce23427e81af87 Send initData in server change diff -r c850c2fce039 -r 86289e56263c src/main/java/com/glavsoft/rfb/encoding/EncodingType.java --- a/src/main/java/com/glavsoft/rfb/encoding/EncodingType.java Tue Jun 17 09:56:47 2014 +0900 +++ b/src/main/java/com/glavsoft/rfb/encoding/EncodingType.java Wed Jun 18 21:16:28 2014 +0900 @@ -65,6 +65,11 @@ ZRLEE(15, "ZRLEE"), /** + * Transmit initial data of new display + */ + INIT_DATA(0xFFFFFF10, "InitData"), + + /** * Rich Cursor pseudo encoding which allows to transfer cursor shape * with transparency */ diff -r c850c2fce039 -r 86289e56263c src/main/java/com/glavsoft/rfb/protocol/ReceiverTask.java --- a/src/main/java/com/glavsoft/rfb/protocol/ReceiverTask.java Tue Jun 17 09:56:47 2014 +0900 +++ b/src/main/java/com/glavsoft/rfb/protocol/ReceiverTask.java Wed Jun 18 21:16:28 2014 +0900 @@ -43,6 +43,7 @@ import java.io.PrintWriter; import java.io.StringWriter; +import java.nio.ByteBuffer; import java.util.logging.Logger; import jp.ac.u_ryukyu.treevnc.MyRfbProto; @@ -237,10 +238,16 @@ } else if (rect.getEncodingType() == EncodingType.CURSOR_POS) { renderer.decodeCursorPosition(rect); repaintController.repaintCursor(); - } else if (rect.getEncodingType() == EncodingType.DESKTOP_SIZE) { + } else if (rect.getEncodingType() == EncodingType.DESKTOP_SIZE || rect.getEncodingType() == EncodingType.INIT_DATA ) { fullscreenFbUpdateIncrementalRequest = new FramebufferUpdateRequestMessage(0, 0, rect.width, rect.height, true); rfb.setCuiVersion(false); + if (rect.getEncodingType() == EncodingType.INIT_DATA) { + int length = reader.readInt32(); + byte[] initData = new byte[length]; + reader.read(initData); + rfb.getContext().setInitData(initData); + } synchronized (renderer.getLock()) { if(!(rfb.getCuiVersion())) renderer = repaintController.createRenderer(reader, rect.width, rect.height,context.getPixelFormat()); diff -r c850c2fce039 -r 86289e56263c src/main/java/jp/ac/u_ryukyu/treevnc/MyRfbProto.java --- a/src/main/java/jp/ac/u_ryukyu/treevnc/MyRfbProto.java Tue Jun 17 09:56:47 2014 +0900 +++ b/src/main/java/jp/ac/u_ryukyu/treevnc/MyRfbProto.java Wed Jun 18 21:16:28 2014 +0900 @@ -58,6 +58,10 @@ abstract public boolean isRoot() ; + public ProtocolContext getContext() { + return context; + } + /** * handle new client accept * it also handle TreeVNC Command @@ -362,7 +366,7 @@ LinkedList<ByteBuffer> desktopSize = new LinkedList<ByteBuffer>(); int width = context.getFbWidth(); int height = context.getFbHeight(); - desktopSize.add(new UpdateRectangleMessage(0,0, width, height, EncodingType.DESKTOP_SIZE).getMessage()); + desktopSize.add(new UpdateRectangleMessage(width, height, EncodingType.INIT_DATA, context.getInitData()).getMessage()); addSerialNumber(desktopSize); multicastqueue.put(desktopSize); } @@ -571,5 +575,5 @@ } - + } diff -r c850c2fce039 -r 86289e56263c src/main/java/jp/ac/u_ryukyu/treevnc/TreeVncCommandChannelListener.java --- a/src/main/java/jp/ac/u_ryukyu/treevnc/TreeVncCommandChannelListener.java Tue Jun 17 09:56:47 2014 +0900 +++ b/src/main/java/jp/ac/u_ryukyu/treevnc/TreeVncCommandChannelListener.java Wed Jun 18 21:16:28 2014 +0900 @@ -211,7 +211,7 @@ in.readBytes(b); } - byte initData[] = {7, -128, 4, 56, 32, 24, 0, 1, 0, -1, 0, -1, 0, -1, 16, 8, 0, 0, 0, 0, 0, 0, 0, 7, 102, 105, 114, 101, 102, 108, 121}; + byte initData[] = {7, -128, 4, 56, 32, 24, 0, 1, 0, -1, 0, -1, 0, -1, 16, 8, 0, 0, 0, 0, 0, 0, 0, 7, 103, 105, 114, 101, 102, 108, 121}; void sendInitData(Writer os) throws TransportException { // In case of "-d" we have no context ProtocolContext context = rfb.context; diff -r c850c2fce039 -r 86289e56263c src/main/java/jp/ac/u_ryukyu/treevnc/UpdateRectangleMessage.java --- a/src/main/java/jp/ac/u_ryukyu/treevnc/UpdateRectangleMessage.java Tue Jun 17 09:56:47 2014 +0900 +++ b/src/main/java/jp/ac/u_ryukyu/treevnc/UpdateRectangleMessage.java Wed Jun 18 21:16:28 2014 +0900 @@ -7,11 +7,11 @@ public class UpdateRectangleMessage { - private ByteBuffer msg = ByteBuffer.allocate(16).order(ByteOrder.BIG_ENDIAN); + private ByteBuffer msg; public UpdateRectangleMessage(int i, int j, int width, int height, EncodingType desktopSize) { - + msg = ByteBuffer.allocate(16).order(ByteOrder.BIG_ENDIAN); msg.put((byte) 0); // FrameBufferUpdate msg.put((byte) 0); // padding msg.putShort((short) 1); // number of rectangle @@ -25,6 +25,24 @@ } + public UpdateRectangleMessage(int width, int height, + EncodingType desktopSize, byte[] initData) { + msg = ByteBuffer.allocate(16+4+initData.length).order(ByteOrder.BIG_ENDIAN); + msg.put((byte) 0); // FrameBufferUpdate + msg.put((byte) 0); // padding + msg.putShort((short) 1); // number of rectangle + msg.putShort((short) 0); + msg.putShort((short) 0); + msg.putShort((short) width); + msg.putShort((short) height); + msg.putInt(desktopSize.getId()); + msg.putInt(initData.length); + msg.put(initData); + + msg.flip(); + + } + public ByteBuffer getMessage(){ return msg; }