Removed FseqCheck option and instead replaced with FseqThreshold option
[xf86-input-tuio.git] / src / tuio.h
blob7a7ba8beea530b157c3a65f87a2371cd0330bca5
1 /*
2 * Copyright (c) 2009 Ryan Huffman
3 *
4 * Permission is hereby granted, free of charge, to any person obtaining a copy
5 * of this software and associated documentation files (the "Software"), to deal
6 * in the Software without restriction, including without limitation the rights
7 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8 * copies of the Software, and to permit persons to whom the Software is
9 * furnished to do so, subject to the following conditions:
11 * The above copyright notice and this permission notice shall be included in
12 * all copies or substantial portions of the Software.
14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
20 * THE SOFTWARE.
22 * Authors:
23 * Ryan Huffman (ryanhuffman@gmail.com)
26 #ifndef TUIO_H
27 #define TUIO_H
29 #include <X11/extensions/XI.h>
30 #include <xf86Xinput.h>
31 #include <lo/lo.h>
32 #include <hal/libhal.h>
34 #define MIN_SUBDEVICES 0 /* min/max subdevices */
35 #define MAX_SUBDEVICES 20
37 #define DEFAULT_PORT 3333 /* Default UDP port to listen on */
39 /**
40 * Tuio device information, including list of current object
42 typedef struct _TuioDevice {
43 lo_server server;
45 int fseq_new, fseq_old;
46 int processed;
48 int tuio_port;
49 int num_subdev;
50 Bool check_fseq;
51 int fseq_threshold;
53 struct _Object *obj_list;
55 /* List of unused devices that can be allocated for use
56 * with ObjectPtr. */
57 struct _SubDevice *subdev_list;
59 } TuioDeviceRec, *TuioDevicePtr;
61 /**
62 * An "Object" can represent a tuio blob or cursor (/tuio/2Dcur or
63 * /tuio/blob
65 typedef struct _Object {
66 struct _Object *next;
68 int id;
69 float x, y;
70 int alive;
71 struct _SubDevice *subdev;
73 /* Stores pending information about this object */
74 struct {
75 Bool alive;
76 Bool set;
77 float x, y;
78 } pending;
79 } ObjectRec, *ObjectPtr;
81 /**
82 * Subdevices are special devices created at the creation of the first
83 * tuio device (aka "core" device). They are tuio devices but are only used
84 * to route object movements through.
86 typedef struct _SubDevice {
87 struct _SubDevice *next;
89 InputInfoPtr pInfo;
90 } SubDeviceRec, *SubDevicePtr;
92 #endif