changeset 226:b7247e31b5ba

send checkdelay sample.
author oc
date Sun, 05 Oct 2014 16:09:23 +0900 (2014-10-05)
parents 5e3594021e79
children 2cb2279ca95c
files src/main/java/com/glavsoft/rfb/encoding/EncodingType.java src/main/java/com/glavsoft/rfb/encoding/decoder/FramebufferUpdateRectangle.java src/main/java/com/glavsoft/rfb/protocol/ReceiverTask.java src/main/java/jp/ac/u_ryukyu/treevnc/TreeRFBProto.java src/main/java/jp/ac/u_ryukyu/treevnc/UpdateRectangleMessage.java
diffstat 5 files changed, 41 insertions(+), 12 deletions(-) [+]
line wrap: on
line diff
--- a/src/main/java/com/glavsoft/rfb/encoding/EncodingType.java	Tue Jul 15 07:18:13 2014 +0900
+++ b/src/main/java/com/glavsoft/rfb/encoding/EncodingType.java	Sun Oct 05 16:09:23 2014 +0900
@@ -63,6 +63,11 @@
 	 * ZRLEE Encoding is extends ZRLE. ZRLEE have flush().   
 	 */
     ZRLEE(15, "ZRLEE"),
+
+    /**
+     * TreeVNC check delay protocol number.
+     */
+    CHECK_DELAY(17, "CHECK_DELAY"),
     
     /**
      * Transmit initial data of new display
--- a/src/main/java/com/glavsoft/rfb/encoding/decoder/FramebufferUpdateRectangle.java	Tue Jul 15 07:18:13 2014 +0900
+++ b/src/main/java/com/glavsoft/rfb/encoding/decoder/FramebufferUpdateRectangle.java	Sun Oct 05 16:09:23 2014 +0900
@@ -59,7 +59,11 @@
         width = reader.readUInt16();
         height = reader.readUInt16();
         int encoding = reader.readInt32();
+        
         encodingType = EncodingType.byId(encoding);
+        if (encoding == 17) {
+            System.out.println("checkdelay~~~~~~");
+        }
     }
 
     public EncodingType getEncodingType() {
--- a/src/main/java/com/glavsoft/rfb/protocol/ReceiverTask.java	Tue Jul 15 07:18:13 2014 +0900
+++ b/src/main/java/com/glavsoft/rfb/protocol/ReceiverTask.java	Sun Oct 05 16:09:23 2014 +0900
@@ -44,17 +44,20 @@
 import java.io.PrintWriter;
 import java.io.StringWriter;
 import java.io.UnsupportedEncodingException;
+import java.nio.ByteBuffer;
+import java.util.LinkedList;
 import java.util.logging.Logger;
 
 import jp.ac.u_ryukyu.treevnc.TreeRFBProto;
 import jp.ac.u_ryukyu.treevnc.TreeVncProtocol;
+import jp.ac.u_ryukyu.treevnc.UpdateRectangleMessage;
 
 public class ReceiverTask implements Runnable {
     private static final byte FRAMEBUFFER_UPDATE = 0;
     private static final byte SET_COLOR_MAP_ENTRIES = 1;
     private static final byte BELL = 2;
     private static final byte SERVER_CUT_TEXT = 3;
-    private static final byte  Check_Delay = 11;
+    private static final byte CHECK_DELAY = 11;
 
 
     private static Logger logger = Logger.getLogger("com.glavsoft.rfb.protocol.ReceiverTask");
@@ -127,7 +130,7 @@
                     logger.fine("Server message: CutText (3)");
                     serverCutText();
                     break;
-                case Check_Delay:
+                case CHECK_DELAY:
                     ZRLEESender sender = new ZRLEESender(rfb);
                     sender.readCheckDelay(reader);
                     /*	
@@ -215,6 +218,11 @@
     public void framebufferUpdateMessage() throws CommonException, UnsupportedEncodingException {
         reader.readByte(); // padding
         int numberOfRectangles = reader.readUInt16();
+        
+        if (numberOfRectangles == 1234) {
+            System.out.println("1~~~~~~~~");
+        }
+        
         while (numberOfRectangles-- > 0) {
             FramebufferUpdateRectangle rect = new FramebufferUpdateRectangle();
             rect.fill(reader);
@@ -259,9 +267,13 @@
                 }
                 context.sendMessage(new FramebufferUpdateRequestMessage(0, 0, rect.width, rect.height, false));
                 //				repaintController.repaintCursor();
+            } else if (rect.getEncodingType() == EncodingType.CHECK_DELAY ) {
+                readCheckDelay(reader);
             } else
                 throw new CommonException("Unprocessed encoding: " + rect.toString());
         }
+
+        
         if (!rfb.isTreeManager()) return; 
         synchronized (this) {
             if (needSendPixelFormat) {
@@ -277,6 +289,10 @@
         }
     }
 
+    private void readCheckDelay(Reader reader) {
+        System.out.println("read check delay.");
+    }
+
     public synchronized void queueUpdatePixelFormat(PixelFormat pf) {
         pixelFormat = pf;
         needSendPixelFormat = true;
--- a/src/main/java/jp/ac/u_ryukyu/treevnc/TreeRFBProto.java	Tue Jul 15 07:18:13 2014 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/treevnc/TreeRFBProto.java	Sun Oct 05 16:09:23 2014 +0900
@@ -207,19 +207,11 @@
 
                     for (;;) {
                         LinkedList<ByteBuffer> bufs = c.poll();
+
                         int inputIndex = 0;
                         ByteBuffer header = bufs.get(inputIndex);
                         if (header == null)
                             continue;
-                        else if (header.get(0) == CheckDelay) {
-                            writeToClient(os, bufs, inputIndex);
-                            continue;
-                        } else if (header.get(0) == FramebufferUpdate) {
-                            //System.out.println("client "+ myId);
-                        }
-                        /*
-                         * if(i%20==0){ sendDataCheckDelay(); } i++;
-                         */
                         writeToClient(os, bufs, inputIndex);
                         writerRunning.set(1); // yes my client is awaking.
                     }
@@ -549,6 +541,13 @@
         header.limit(16);
         if (header.get(0) == FramebufferUpdate) {
             int encoding = header.getInt(12);
+
+            LinkedList<ByteBuffer> checkdelay = new LinkedList<ByteBuffer>();
+            checkdelay.add(new UpdateRectangleMessage(0, 0, 0, 0, EncodingType.CHECK_DELAY).getMessage());
+            this.addSerialNumber(checkdelay);
+            multicastqueue.put(checkdelay);
+
+            
             if (encoding == EncodingType.ZRLE.getId()
                     || encoding == EncodingType.ZLIB.getId()) { 
                 // recompress into ZREE
@@ -598,6 +597,11 @@
             }
             this.addSerialNumber(bufs);
             multicastqueue.put(bufs);
+            
+            
+
+            
+            
             return;
         }
         // It may be compressed. We can inflate here to avoid repeating clients
--- a/src/main/java/jp/ac/u_ryukyu/treevnc/UpdateRectangleMessage.java	Tue Jul 15 07:18:13 2014 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/treevnc/UpdateRectangleMessage.java	Sun Oct 05 16:09:23 2014 +0900
@@ -14,7 +14,7 @@
 		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
+		msg.putShort((short) 1234); // number of rectangle
 		msg.putShort((short) i);
 		msg.putShort((short) j);
 		msg.putShort((short) width);