Now uses static number of cursors and works. Needs clean up.
[xf86-input-tuio.git] / src / tuio.h
blobb52d725bc17feacf4f0af41a947a78b62ba54ad4
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 /**
35 * Tuio device information, including list of current object
37 typedef struct _TuioDevice {
38 lo_server server;
40 int fseq_new, fseq_old;
41 int processed;
43 struct _Object *obj_list;
45 /* List of unused devices that can be allocated for use
46 * by ObjectPtr. */
47 struct _ObjectDev *unused_device_list;
49 } TuioDeviceRec, *TuioDevicePtr;
51 /**
52 * An "Object" can represent a tuio blob or cursor (/tuio/2Dcur or
53 * /tuio/blob
55 typedef struct _Object {
56 int id;
57 float x, y;
58 int alive;
59 struct _ObjectDev *objdev;
61 /* Stores pending information about this object */
62 struct {
63 Bool alive;
64 Bool set;
65 float x, y;
66 } pending;
68 struct _Object *next;
70 } ObjectRec, *ObjectPtr;
72 /**
73 * Object devices are special devices created at the creation of the first
74 * tuio device (aka "core device). They are tuio devices but are only used
75 * to route object movements through.
77 typedef struct _ObjectDev {
78 InputInfoPtr pInfo;
79 struct _ObjectDev *next;
80 } ObjectDevRec, *ObjectDevPtr;
82 #endif