Mercurial > hg > Members > nobuyasu > tightVNCClient
changeset 45:413df87d6f8f
modify MyRfbProto.java. create multicastqueue
author | e085711 |
---|---|
date | Sat, 09 Jul 2011 14:09:19 +0900 |
parents | 034528dfb650 |
children | da5d82180bc2 |
files | src/myVncClient/MyRfbProto.java |
diffstat | 1 files changed, 173 insertions(+), 127 deletions(-) [+] |
line wrap: on
line diff
--- a/src/myVncClient/MyRfbProto.java Sat Jul 09 13:51:38 2011 +0900 +++ b/src/myVncClient/MyRfbProto.java Sat Jul 09 14:09:19 2011 +0900 @@ -1,4 +1,5 @@ package myVncClient; + import java.awt.Graphics; import java.awt.Image; import java.awt.image.BufferedImage; @@ -16,6 +17,8 @@ import javax.imageio.ImageIO; +import myVncClient.MulticastQueue.Client; + import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.io.OutputStream; @@ -23,8 +26,7 @@ class MyRfbProto extends RfbProto { final static String versionMsg_3_998 = "RFB 003.998\n"; - - + private int messageType; private int rectangles; private int rectX; @@ -37,44 +39,43 @@ private ServerSocket servSock; private int acceptPort; private byte initData[]; - private LinkedList <Socket> cliListTmp; - private LinkedList <Socket> cliList; - private LinkedList <Thread> sendThreads; + private LinkedList<Socket> cliListTmp; + private LinkedList<Socket> cliList; + private LinkedList<Thread> sendThreads; boolean createBimgFlag; - - echoClient echo; ExecutorService executor; - - + byte[] pngBytes; - - MyRfbProto(String h, int p, VncViewer v ) throws IOException { + + private MulticastQueue<byte[]> multicastqueue = new MulticastQueue<byte[]>(); + + MyRfbProto(String h, int p, VncViewer v) throws IOException { super(h, p, v); - cliList = new LinkedList <Socket>(); - cliListTmp = new LinkedList <Socket>(); + cliList = new LinkedList<Socket>(); + cliListTmp = new LinkedList<Socket>(); createBimgFlag = false; - sendThreads = new LinkedList <Thread>(); -// executor = Executors.newCachedThreadPool(); - executor = Executors.newSingleThreadExecutor(); + // sendThreads = new LinkedList<Thread>(); + // executor = Executors.newCachedThreadPool(); + // executor = Executors.newSingleThreadExecutor(); } MyRfbProto(String h, int p) throws IOException { super(h, p); - cliList = new LinkedList <Socket>(); - cliListTmp = new LinkedList <Socket>(); + cliList = new LinkedList<Socket>(); + cliListTmp = new LinkedList<Socket>(); createBimgFlag = false; - sendThreads = new LinkedList <Thread>(); -// executor = Executors.newCachedThreadPool(); - executor = Executors.newSingleThreadExecutor(); + // sendThreads = new LinkedList<Thread>(); + // executor = Executors.newCachedThreadPool(); + // executor = Executors.newSingleThreadExecutor(); } // over write void writeVersionMsg() throws IOException { clientMajor = 3; if (serverMinor >= 9) { - clientMinor = 9; - os.write(versionMsg_3_998.getBytes()); + clientMinor = 9; + os.write(versionMsg_3_998.getBytes()); } else if (serverMajor > 3 || serverMinor >= 8) { clientMinor = 8; os.write(versionMsg_3_8.getBytes()); @@ -92,71 +93,74 @@ initCapabilities(); } - - - void initServSock(int port) throws IOException{ + void initServSock(int port) throws IOException { servSock = new ServerSocket(port); acceptPort = port; } - void selectPort(){ + + // 5550を開けるが、開いてないなら+1のポートを開ける。 + void selectPort() { int i = 5550; - while(true){ - try{ + while (true) { + try { initServSock(i); break; - }catch(BindException e){ + } catch (BindException e) { i++; continue; - }catch(IOException e){ + } catch (IOException e) { } } - System.out.println("accept port = "+i); + System.out.println("accept port = " + i); } - int getAcceptPort(){ + + int getAcceptPort() { return acceptPort; } + void setSoTimeout(int num) throws IOException { servSock.setSoTimeout(num); } - + Socket accept() throws IOException { return servSock.accept(); } - void addSock(Socket sock){ + void addSock(Socket sock) { cliList.add(sock); } - void addSockTmp(Socket sock){ - System.out.println("connected "+sock.getInetAddress()); + + void addSockTmp(Socket sock) { + System.out.println("connected " + sock.getInetAddress()); cliListTmp.add(sock); } - + void mark(int len) throws IOException { is.mark(len); } void reset() throws IOException { is.reset(); - } + } boolean markSupported() { return is.markSupported(); } - + void readServerInit() throws IOException { - + mark(255); skipBytes(20); int nlen = readU32(); - int blen = 20+4+nlen; + int blen = 20 + 4 + nlen; initData = new byte[blen]; reset(); mark(blen); readFully(initData); reset(); - + framebufferWidth = readU16(); framebufferHeight = readU16(); bitsPerPixel = readU8(); @@ -190,9 +194,10 @@ inNormalProtocol = true; } - void sendRfbVersion(OutputStream os) throws IOException{ - os.write(versionMsg_3_998.getBytes()); + void sendRfbVersion(OutputStream os) throws IOException { + os.write(versionMsg_3_998.getBytes()); } + void readVersionMsg(InputStream is) throws IOException { byte[] b = new byte[12]; @@ -214,99 +219,95 @@ if (serverMajor < 3) { throw new IOException( "RFB server does not support protocol version 3"); - } - - } + } + + } + void sendSecurityType(OutputStream os) throws IOException { // number-of-security-types os.write(1); - // security-types + // security-types // 1:None os.write(1); } + void readSecType(InputStream is) throws IOException { byte[] b = new byte[1]; is.read(b); } + void sendSecResult(OutputStream os) throws IOException { byte[] b = castIntByte(0); os.write(b); } - + void readClientInit(InputStream in) throws IOException { byte[] b = new byte[0]; in.read(b); } - - void sendInitData(OutputStream os) throws IOException{ - os.write(initData); + + void sendInitData(OutputStream os) throws IOException { + os.write(initData); } - void sendData(byte b[]){ - try{ - for(Socket cli : cliList){ - try{ - cli.getOutputStream().write(b, 0, b.length); - }catch(IOException e){ - //insert + void sendData(byte b[]) { + try { + multicastqueue.put(b); - System.out.println("lostchild"); - if("1".equals(echoClient.value.leaderflag)){ - echo = new echoClient(); - echo.openport(); - echo.lostchild(); - } - // if socket closed - cliList.remove(cli); - } - } -// System.out.println("cliSize="+cliSize()); - }catch(Exception e){ + /* + * // for(Socket cli : cliList){ // try{ // + * cli.getOutputStream().write(b, 0, b.length); // + * }catch(IOException e){ // // if socket closed // + * cliList.remove(cli); // } // } + */ + // System.out.println("cliSize="+cliSize()); + } catch (Exception e) { } } - - void sendPngImage(){ - try{ - for(Socket cli : cliListTmp){ - try{ + + void sendPngImage() { + try { + for (Socket cli : cliListTmp) { + try { sendPngData(cli); addSock(cli); - }catch(IOException e){ + } catch (IOException e) { // if socket closed cliListTmp.remove(cli); } } -// System.out.println("cliSize="+cliSize()); - }catch(Exception e){ + // System.out.println("cliSize="+cliSize()); + } catch (Exception e) { } cliListTmp.clear(); } - - boolean ready() throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(is)); return br.ready(); - } + } - int cliSize(){ + int cliSize() { return cliList.size(); - } - void printNumBytesRead(){ - System.out.println("numBytesRead="+numBytesRead); - } + } + + void printNumBytesRead() { + System.out.println("numBytesRead=" + numBytesRead); + } + void bufResetSend(int size) throws IOException { reset(); int len = size; - if(available() < size ) + if (available() < size) len = available(); byte buffer[] = new byte[len]; readFully(buffer); sendData(buffer); } - void regiFramebufferUpdate()throws IOException{ + + void regiFramebufferUpdate() throws IOException { mark(20); messageType = readU8(); skipBytes(1); @@ -316,53 +317,57 @@ rectW = readU16(); rectH = readU16(); encoding = readU32(); - if(encoding == 16) + if (encoding == 16) zLen = readU32(); reset(); } - int checkAndMark() throws IOException{ + + int checkAndMark() throws IOException { int dataLen; - switch(encoding){ + switch (encoding) { case RfbProto.EncodingRaw: dataLen = rectW * rectH * 4 + 16; mark(dataLen); break; case RfbProto.EncodingZRLE: - dataLen = zLen+20; + dataLen = zLen + 20; mark(dataLen); break; default: dataLen = 1000000; mark(1000000); - } + } return dataLen; } - void readSendData(int dataLen)throws IOException{ + void readSendData(int dataLen) throws IOException { byte buffer[] = new byte[dataLen]; readFully(buffer); + multicastqueue.put(buffer); reset(); - - for(Socket cli : cliList){ - try{ +/* + for (Socket cli : cliList) { + try { OutputStream out = cli.getOutputStream(); executor.execute(new SendThread(out, buffer)); - }catch(IOException e){ + } catch (IOException e) { // if client socket closed cliListTmp.remove(cli); - }catch(Exception e){ - + } catch (Exception e) { + } + } - } +*/ + } void sendDataToClient() throws IOException { regiFramebufferUpdate(); int dataLen = checkAndMark(); readSendData(dataLen); } - - - BufferedImage createBufferedImage(Image img){ - BufferedImage bimg = new BufferedImage(img.getWidth(null), img.getHeight(null), BufferedImage.TYPE_INT_RGB ); + + BufferedImage createBufferedImage(Image img) { + BufferedImage bimg = new BufferedImage(img.getWidth(null), + img.getHeight(null), BufferedImage.TYPE_INT_RGB); Graphics g = bimg.getGraphics(); g.drawImage(img, 0, 0, null); @@ -370,15 +375,17 @@ return bimg; } - void createPngBytes(BufferedImage bimg)throws IOException { - pngBytes = getImageBytes(bimg , "png"); + void createPngBytes(BufferedImage bimg) throws IOException { + pngBytes = getImageBytes(bimg, "png"); } - byte[] getBytes(BufferedImage img)throws IOException { + + byte[] getBytes(BufferedImage img) throws IOException { byte[] b = getImageBytes(img, "png"); return b; } - - byte[] getImageBytes(BufferedImage image, String imageFormat) throws IOException { + + byte[] getImageBytes(BufferedImage image, String imageFormat) + throws IOException { ByteArrayOutputStream bos = new ByteArrayOutputStream(); BufferedOutputStream os = new BufferedOutputStream(bos); image.flush(); @@ -388,40 +395,79 @@ return bos.toByteArray(); } - void sendPngData(Socket sock)throws IOException{ + void sendPngData(Socket sock) throws IOException { byte[] dataLength = castIntByte(pngBytes.length); sock.getOutputStream().write(dataLength); sock.getOutputStream().write(pngBytes); } - byte[] castIntByte(int len){ + + byte[] castIntByte(int len) { byte[] b = new byte[4]; - b[0] = (byte)((len >>> 24 ) & 0xFF); - b[1] = (byte)((len >>> 16 ) & 0xFF); - b[2] = (byte)((len >>> 8 ) & 0xFF); - b[3] = (byte)((len >>> 0 ) & 0xFF); + b[0] = (byte) ((len >>> 24) & 0xFF); + b[1] = (byte) ((len >>> 16) & 0xFF); + b[2] = (byte) ((len >>> 8) & 0xFF); + b[3] = (byte) ((len >>> 0) & 0xFF); return b; } - - BufferedImage createBimg()throws IOException{ + + BufferedImage createBimg() throws IOException { BufferedImage bimg = ImageIO.read(new ByteArrayInputStream(pngBytes)); return bimg; } - void readPngData()throws IOException{ + + void readPngData() throws IOException { pngBytes = new byte[is.available()]; readFully(pngBytes); } - void printFramebufferUpdate(){ - + + void printFramebufferUpdate() { + System.out.println("messageType=" + messageType); - System.out.println("rectangles="+rectangles); + System.out.println("rectangles=" + rectangles); System.out.println("encoding=" + encoding); - switch(encoding){ + switch (encoding) { case RfbProto.EncodingRaw: - System.out.println("rectW * rectH * 4 + 16 =" + rectW * rectH * 4 + 16); + System.out.println("rectW * rectH * 4 + 16 =" + rectW * rectH * 4 + + 16); break; default: } } -} + + void newClient(acceptThread acceptThread, final Socket newCli, + final OutputStream os, final InputStream is) throws IOException { + // createBimgFlag = true; + // rfb.addSockTmp(newCli); + // addSock(newCli); + final Client<byte[]> c = multicastqueue.newClient(); + Runnable sender = new Runnable() { + public void run() { + try { + // 初期接続確立の部分 + sendRfbVersion(os); + readVersionMsg(is); + sendSecurityType(os); + readSecType(is); + sendSecResult(os); + readClientInit(is); + sendInitData(os); + for (;;) { + byte[] b = c.poll(); + os.write(b, 0, b.length); + } + } catch (IOException e) { + /** + * if socket closed + */ + // cliList.remove(newCli); + } + + } + + }; + new Thread(sender).start(); + + } +}