front_processing/extern/TUIO_JAVA/src/com/illposed/osc/OSCPortIn.java
author bastiena
Fri, 23 Mar 2012 16:24:36 +0100
changeset 10 925b7ee746e3
parent 9 0f44b7360c8d
child 28 9ccef81f02ab
permissions -rw-r--r--
Front Processing : Changed utf-8 to utf-8 without BOM
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
10
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     1
/**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     2
 * @author cramakrishnan
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     3
 *
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     4
 * Copyright (C) 2004, C. Ramakrishnan / Illposed Software
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     5
 * All rights reserved.
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     6
 * 
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     7
 * See license.txt (or license.rtf) for license information.
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     8
 * 
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     9
 * 
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    10
 * OSCPortIn is the class that listens for OSC messages.
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    11
 *     
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    12
 * To receive OSC, you need to construct the OSCPort with a 
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    13
 *
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    14
 * An example based on com.illposed.osc.test.OSCPortTest::testReceiving() :
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    15
 
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    16
        receiver = new OSCPort(OSCPort.defaultSCOSCPort());
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    17
        OSCListener listener = new OSCListener() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    18
            public void acceptMessage(java.util.Date time, OSCMessage message) {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    19
                System.out.println("Message received!");
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    20
            }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    21
        };
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    22
        receiver.addListener("/message/receiving", listener);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    23
        receiver.startListening();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    24
        
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    25
 * Then, using a program such as SuperCollider or sendOSC, send a message
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    26
 * to this computer, port 57110 (defaultSCOSCPort), with the address /message/receiving
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    27
 */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    28
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    29
package com.illposed.osc;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    30
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    31
import java.net.*;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    32
import java.io.IOException;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    33
import com.illposed.osc.utility.OSCByteArrayToJavaConverter;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    34
import com.illposed.osc.utility.OSCPacketDispatcher;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    35
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    36
public class OSCPortIn extends OSCPort implements Runnable {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    37
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    38
    // state for listening
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    39
    protected boolean isListening;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    40
    protected OSCByteArrayToJavaConverter converter = new OSCByteArrayToJavaConverter();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    41
    protected OSCPacketDispatcher dispatcher = new OSCPacketDispatcher();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    42
    
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    43
    /**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    44
     * Create an OSCPort that listens on port
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    45
     * @param port
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    46
     * @throws SocketException
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    47
     */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    48
    public OSCPortIn(int port) throws SocketException {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    49
        socket = new DatagramSocket(port);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    50
        this.port = port;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    51
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    52
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    53
    /**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    54
     * @see java.lang.Runnable#run()
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    55
     */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    56
    public void run() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    57
        //maximum UDP packet size
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    58
        byte[] buffer = new byte[65536];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    59
        DatagramPacket packet = new DatagramPacket(buffer, 65536);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    60
        while (isListening) {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    61
            try {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    62
                packet.setLength(65536);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    63
                socket.receive(packet);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    64
                OSCPacket oscPacket = converter.convert(buffer, packet.getLength());
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    65
                dispatcher.dispatchPacket(oscPacket);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    66
            } catch (java.net.SocketException e) {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    67
                if (isListening) e.printStackTrace();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    68
            } catch (IOException e) {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    69
                if (isListening) e.printStackTrace();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    70
            } 
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    71
        }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    72
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    73
    
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    74
    /**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    75
     * Start listening for incoming OSCPackets
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    76
     */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    77
    public void startListening() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    78
        isListening = true;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    79
        Thread thread = new Thread(this);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    80
        thread.start();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    81
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    82
    
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    83
    /**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    84
     * Stop listening for incoming OSCPackets
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    85
     */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    86
    public void stopListening() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    87
        isListening = false;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    88
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    89
    
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    90
    /**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    91
     * Am I listening for packets?
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    92
     */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    93
    public boolean isListening() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    94
        return isListening;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    95
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    96
    
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    97
    /**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    98
     * Register the listener for incoming OSCPackets addressed to an Address
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    99
     * @param anAddress  the address to listen for
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   100
     * @param listener   the object to invoke when a message comes in
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   101
     */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   102
    public void addListener(String anAddress, OSCListener listener) {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   103
        dispatcher.addListener(anAddress, listener);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   104
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   105
    
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   106
    /**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   107
     * Close the socket and free-up resources. It's recommended that clients call
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   108
     * this when they are done with the port.
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   109
     */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   110
    public void close() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   111
        socket.close();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   112
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   113
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   114
}