annotate main.cc @ 0:1478aad947a6

init
author kazz <kazz@cr.ie.u-ryukyu.ac.jp>
date Mon, 31 Jan 2011 03:46:10 +0900
parents
children 2afd5c6cc8d2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 #include <stdio.h>
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 #include <XnOpenNI.h>
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 #include <XnCppWrapper.h>
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 #include <XnVNite.h>
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
5
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 #define INIT_XML_PATH "./kinect.xml"
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
7
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 typedef enum {
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 IN_SESSION,
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 NOT_IN_SESSION,
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
11 QUICK_REFOCUS
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
12 } SessionState;
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
13
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
14 void checkRC(const XnStatus &rc, const char *what) {
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 if (rc != XN_STATUS_OK) {
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
16 printf("%s faild: %s\n", what, xnGetStatusString(rc));
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
17 }
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
18 }
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
19
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
20 void checkErrors(XnStatus &rc, xn::EnumerationErrors &errors, const char *what) {
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
21 if (rc == XN_STATUS_NO_NODE_PRESENT) {
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
22 XnChar strError[1024];
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
23 errors.ToString(strError, 1024);
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
24 printf("%s\n", strError);
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
25 }
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
26 }
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
27
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
28 class NIState {
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
29 public:
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
30 static SessionState gSessionState;
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
31 static void XN_CALLBACK_TYPE sessionStarting(const XnPoint3D &ptPosition, void *userCxt);
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
32 static void XN_CALLBACK_TYPE sessionEnding(void *userCxt);
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
33 static void XN_CALLBACK_TYPE focusProgress(const XnChar *strFocus, const XnPoint3D &ptPosition,
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
34 XnFloat fProgress, void *userCxt);
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
35 };
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
36 SessionState NIState::gSessionState = NOT_IN_SESSION;
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 void NIState::XN_CALLBACK_TYPE sessionStarting(const XnPoint3D &ptPosition, void *userCxt) {
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
38 printf("Session start: (%f, %f, %f)\n)", ptPosition.X, ptPosition.Y, ptPosition.Z);
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
39 gSessionState = IN_SESSION;
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
40 }
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 void NIState::XN_CALLBACK_TYPE sessionEnding(void *userCxt) {
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
42 printf("Session end\n");
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
43 gSessionState = NOT_IN_SESSION;
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
44 }
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 void NIState::XN_CALLBACK_TYPE focusProgress(const XnChar *strFocus, const XnPoint3D &ptPosition,
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
46 XnFloat fProgress, void *userCxt) {
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 //printf("Focus progress: %s @(%f, %f, %f): %f\n)", strFocus, ptPosition.X, ptPosition.Y, ptPosition.Z, fProgress);
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
48 }
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
49
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
50 int main(int argc, char *argv[]) {
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 xn::Context gContext;
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
52 xn::EnumerationErrors errors;
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
53 XnStatus rc = gContext.InitFromXmlFile(INIT_XML_PATH, &errors);
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
54 checkErrors(rc, errors, "InitFromXMLFile");
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
55 checkRC(rc, "InitFromXMLFile");
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
56
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
57 xn::DepthGenerator gDepthGenerator;
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
58 rc = gContext.FindExistingNode(XN_NODE_TYPE_DEPTH, gDepthGenerator);
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
59 checkRC(rc, "Find depth generator");
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
60
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
61 xn::HandsGenerator gHandsGenerator;
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
62 rc = gContext.FindExistingNode(XN_NODE_TYPE_HANDS, gHandsGenerator);
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
63 checkRC(rc, "Find hands generator");
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
64 XnVSessionManager *gPSessionManager = new XnVSessionManager();
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
65 rc = gPSessionManager->Initialize(&gContext, "Click,Wave", "RaiseHand");
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
66 checkRC(rc, "SessionManager::Initialize");
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
67 gPSessionManager->RegisterSession(NULL, NIState::sessionStarting, NIState::sessionEnding, NIState::focusProgress);
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
68
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
69 return 0;
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
70 }