diff options
-rw-r--r-- | wiimote.c | 362 |
1 files changed, 205 insertions, 157 deletions
@@ -1,5 +1,5 @@ // =================================================================== -// Wiiremote external for Puredata +// Wiimote external for Puredata // Written by Mike Wozniewki (Feb 2007), www.mikewoz.com // // Requires the CWiid library (version 0.6.00) by L. Donnie Smith @@ -22,7 +22,7 @@ // ChangeLog: // 2008-04-14 Florian Krebs -// * adapt wiiremote external for the actual version of cwiid (0.6.00) +// * adapt wiimote external for the actual version of cwiid (0.6.00) // 2009-09-14 IOhannes m zmölnig // * made it compile without private cwiid-headers @@ -43,61 +43,62 @@ struct acc { unsigned char z; }; -// class and struct declarations for wiiremote pd external: -static t_class *wiiremote_class; -typedef struct _wiiremote +// class and struct declarations for wiimote pd external: +static t_class *wiimote_class; +typedef struct _wiimote { t_object x_obj; // standard pd object (must be first in struct) - cwiid_wiimote_t *wiiremote; // individual wiiremote handle per pd object, represented in libcwiid + cwiid_wiimote_t *wiimote; // individual wiimote handle per pd object, represented in libcwiid t_float connected; - int wiiremoteID; + int wiimoteID; int reportMode; struct acc_cal acc_cal; /* calibration for built-in accelerometer */ struct acc_cal nc_acc_cal; /* calibration for nunchuk accelerometer */ + struct balance_cal balance_cal; // outlets: t_outlet *outlet_data; -} t_wiiremote; +} t_wiimote; -// For now, we make one global t_wiiremote pointer that we can refer to +// For now, we make one global t_wiimote pointer that we can refer to // in the cwiid_callback. This means we can support maximum of ONE -// wiiremote. ARGH. We'll have to figure out how to have access to the +// wiimote. ARGH. We'll have to figure out how to have access to the // pd object from the callback (without modifying the CWiid code): -#define MAX_WIIREMOTES 14 +#define MAX_WIIMOTES 14 -typedef struct _wiiremoteList { - t_wiiremote*x; +typedef struct _wiimoteList { + t_wiimote*x; int id; - struct _wiiremoteList*next; -} t_wiiremoteList; + struct _wiimoteList*next; +} t_wiimoteList; -t_wiiremoteList*g_wiiremoteList=NULL; +t_wiimoteList*g_wiimoteList=NULL; -static int addWiiremoteObject(t_wiiremote*x, int id) { - t_wiiremoteList*wl=g_wiiremoteList; - t_wiiremoteList*newentry=NULL; +static int addWiimoteObject(t_wiimote*x, int id) { + t_wiimoteList*wl=g_wiimoteList; + t_wiimoteList*newentry=NULL; if(NULL!=wl) { while(wl->next) { if(wl->x == x) { - pd_error(x, "[wiiremote]: already bound to Wii%02d", wl->id); + pd_error(x, "[wiimote]: already bound to Wii%02d", wl->id); return 0; } if(wl->id == id) { - pd_error(x, "[wiiremote]: another object is already bound to Wii%02d", wl->id); + pd_error(x, "[wiimote]: another object is already bound to Wii%02d", wl->id); return 0; } wl=wl->next; } } - newentry=(t_wiiremoteList*)getbytes(sizeof(t_wiiremoteList)); + newentry=(t_wiimoteList*)getbytes(sizeof(t_wiimoteList)); newentry->next=NULL; newentry->x=x; newentry->id=id; @@ -105,13 +106,13 @@ static int addWiiremoteObject(t_wiiremote*x, int id) { if(wl) wl->next=newentry; else - g_wiiremoteList=newentry; + g_wiimoteList=newentry; return 1; } -static t_wiiremote*getWiiremoteObject(const int id) { - t_wiiremoteList*wl=g_wiiremoteList; +static t_wiimote*getWiimoteObject(const int id) { + t_wiimoteList*wl=g_wiimoteList; if(NULL==wl) return NULL; @@ -124,9 +125,9 @@ static t_wiiremote*getWiiremoteObject(const int id) { return NULL; } -static void removeWiiremoteObject(const t_wiiremote*x) { - t_wiiremoteList*wl=g_wiiremoteList; - t_wiiremoteList*last=NULL; +static void removeWiimoteObject(const t_wiimote*x) { + t_wiimoteList*wl=g_wiimoteList; + t_wiimoteList*last=NULL; if(NULL==wl) return; @@ -135,12 +136,12 @@ static void removeWiiremoteObject(const t_wiiremote*x) { if(last) { last->next=wl->next; } else { - g_wiiremoteList=wl->next; + g_wiimoteList=wl->next; } wl->x=NULL; wl->id=0; wl->next=NULL; - freebytes(wl, sizeof(t_wiiremoteList)); + freebytes(wl, sizeof(t_wiimoteList)); return; } @@ -152,11 +153,11 @@ static void removeWiiremoteObject(const t_wiiremote*x) { // ============================================================== -static void wiiremote_debug(t_wiiremote *x) +static void wiimote_debug(t_wiimote *x) { post("\n======================"); - if (x->connected) post("Wiiremote (id: %d) is connected.", x->wiiremoteID); - else post("Wiiremote (id: %d) is NOT connected.", x->wiiremoteID); + if (x->connected) post("Wiimote (id: %d) is connected.", x->wiimoteID); + else post("Wiimote (id: %d) is NOT connected.", x->wiimoteID); post("acceleration: %s", (x->reportMode & CWIID_RPT_ACC)?"ON":"OFF"); post("IR: %s", (x->reportMode & CWIID_RPT_IR)?"ON":"OFF"); post("extensions: %s", (x->reportMode & CWIID_RPT_EXT)?"ON":"OFF"); @@ -174,7 +175,7 @@ static void wiiremote_debug(t_wiiremote *x) // ============================================================== -static void wiiremote_cwiid_battery(t_wiiremote *x, int battery) +static void wiimote_cwiid_battery(t_wiimote *x, int battery) { t_atom ap[1]; t_float bat=(1.f*battery) / CWIID_BATTERY_MAX; @@ -187,7 +188,7 @@ static void wiiremote_cwiid_battery(t_wiiremote *x, int battery) } // Button handler: -static void wiiremote_cwiid_btn(t_wiiremote *x, struct cwiid_btn_mesg *mesg) +static void wiimote_cwiid_btn(t_wiimote *x, struct cwiid_btn_mesg *mesg) { t_atom ap[2]; SETFLOAT(ap+0, (mesg->buttons & 0xFF00)>>8); @@ -196,7 +197,7 @@ static void wiiremote_cwiid_btn(t_wiiremote *x, struct cwiid_btn_mesg *mesg) } -static void wiiremote_cwiid_acc(t_wiiremote *x, struct cwiid_acc_mesg *mesg) +static void wiimote_cwiid_acc(t_wiimote *x, struct cwiid_acc_mesg *mesg) { double a_x, a_y, a_z; t_atom ap[3]; @@ -222,7 +223,7 @@ static void wiiremote_cwiid_acc(t_wiiremote *x, struct cwiid_acc_mesg *mesg) } -static void wiiremote_cwiid_ir(t_wiiremote *x, struct cwiid_ir_mesg *mesg) +static void wiimote_cwiid_ir(t_wiimote *x, struct cwiid_ir_mesg *mesg) { unsigned int i; @@ -239,7 +240,7 @@ static void wiiremote_cwiid_ir(t_wiiremote *x, struct cwiid_ir_mesg *mesg) } } -static void wiiremote_cwiid_nunchuk(t_wiiremote *x, struct cwiid_nunchuk_mesg *mesg) +static void wiimote_cwiid_nunchuk(t_wiimote *x, struct cwiid_nunchuk_mesg *mesg) { t_atom ap[4]; double a_x, a_y, a_z; @@ -280,7 +281,7 @@ static void wiiremote_cwiid_nunchuk(t_wiiremote *x, struct cwiid_nunchuk_mesg *m } #ifdef CWIID_RPT_CLASSIC -static void wiiremote_cwiid_classic(t_wiiremote *x, struct cwiid_classic_mesg *mesg) +static void wiimote_cwiid_classic(t_wiimote *x, struct cwiid_classic_mesg *mesg) { t_atom ap[3]; @@ -318,32 +319,43 @@ static void wiiremote_cwiid_classic(t_wiiremote *x, struct cwiid_classic_mesg *m #ifdef CWIID_RPT_BALANCE #warning Balance ignores calibration data -static void wiiremote_cwiid_balance_output(t_wiiremote *x, t_symbol*s, uint16_t value[3], t_float scale) + +static void wiimote_cwiid_balance_output(t_wiimote *x, t_symbol*s, uint16_t value, uint16_t calibration[3]) { - t_atom ap[4]; - t_float a = scale*value[CWIID_X]; - t_float b = scale*value[CWIID_Y]; - t_float c = scale*value[CWIID_Z]; + /* + 1700 appears to be the step the calibrations are against. + 17kg per sensor is 68kg, 1/2 of the advertised Japanese weight limit. + */ +#define WIIMOTE_BALANCE_CALWEIGHT 1700.f + t_atom ap[2]; + t_float weight=0; + t_float falue=value; + if(calibration) { + if(value<calibration[1]) { + weight = WIIMOTE_BALANCE_CALWEIGHT * (falue - calibration[0]) / (calibration[1]-calibration[0]); + } else { + weight = WIIMOTE_BALANCE_CALWEIGHT * (1 + (falue - calibration[1]) / (calibration[2]-calibration[1])); + } + } else { + weight=falue; + } SETSYMBOL(ap+0, s); - SETFLOAT (ap+1, a); - SETFLOAT (ap+2, b); - SETFLOAT (ap+3, c); - outlet_anything(x->outlet_data, gensym("balance"), 4, ap); + SETFLOAT (ap+1, weight); + outlet_anything(x->outlet_data, gensym("balance"), 2, ap); } -static void wiiremote_cwiid_balance(t_wiiremote *x, struct cwiid_balance_mesg *mesg) +static void wiimote_cwiid_balance(t_wiimote *x, struct cwiid_balance_mesg *mesg) { - t_float scale = 1.f / ((uint16_t)0xFFFF); - wiiremote_cwiid_balance_output(x, gensym("right_top"), &mesg->right_top, scale); - wiiremote_cwiid_balance_output(x, gensym("right_bottom"), &mesg->right_bottom, scale); - wiiremote_cwiid_balance_output(x, gensym("left_top"), &mesg->left_top, scale); - wiiremote_cwiid_balance_output(x, gensym("left_bottom"), &mesg->left_bottom, scale); + wiimote_cwiid_balance_output(x, gensym("right_top"), mesg->right_top, x->balance_cal.right_top); + wiimote_cwiid_balance_output(x, gensym("right_bottom"), mesg->right_bottom, x->balance_cal.right_bottom); + wiimote_cwiid_balance_output(x, gensym("left_top"), mesg->left_top, x->balance_cal.left_top); + wiimote_cwiid_balance_output(x, gensym("left_bottom"), mesg->left_bottom, x->balance_cal.left_bottom); } #endif #ifdef CWIID_RPT_MOTIONPLUS -static void wiiremote_cwiid_motionplus(t_wiiremote *x, struct cwiid_motionplus_mesg *mesg) +static void wiimote_cwiid_motionplus(t_wiimote *x, struct cwiid_motionplus_mesg *mesg) { t_atom ap[4]; t_float scale = 1.f;// / ((uint16_t)0xFFFF); @@ -379,17 +391,18 @@ static void wiiremote_cwiid_motionplus(t_wiiremote *x, struct cwiid_motionplus_m -static void wiiremote_cwiid_message(t_wiiremote *x, union cwiid_mesg mesg) { +static void wiimote_cwiid_message(t_wiimote *x, union cwiid_mesg mesg) { switch (mesg.type) { case CWIID_MESG_STATUS: - wiiremote_cwiid_battery(x, mesg.status_mesg.battery); + wiimote_cwiid_battery(x, mesg.status_mesg.battery); switch (mesg.status_mesg.ext_type) { case CWIID_EXT_NONE: post("No extension attached"); break; case CWIID_EXT_NUNCHUK: +#ifdef CWIID_RPT_NUNCHCUK post("Nunchuk extension attached"); - if(cwiid_get_acc_cal(x->wiiremote, CWIID_EXT_NUNCHUK, &x->nc_acc_cal)) { + if(cwiid_get_acc_cal(x->wiimote, CWIID_EXT_NUNCHUK, &x->nc_acc_cal)) { post("Unable to retrieve nunchuk calibration"); } else { post("Retrieved nunchuk calibration: zero=(%02d,%02d,%02d) one=(%02d,%02d,%02d)", @@ -401,16 +414,25 @@ static void wiiremote_cwiid_message(t_wiiremote *x, union cwiid_mesg mesg) { x->nc_acc_cal.one [CWIID_Z]); } break; +#endif +#ifdef CWIID_RPT_CLASSIC case CWIID_EXT_CLASSIC: post("Classic controller attached. There is no support for this yet."); break; +#endif +#ifdef CWIID_RPT_BALANCE case CWIID_EXT_BALANCE: - post("Balance controller attached. There is no support for this yet."); + if(cwiid_get_balance_cal(x->wiimote, &x->balance_cal)) { + post("Unable to retrieve balance calibration"); + } break; +#endif +#ifdef CWIID_RPT_MOTIONPLUS case CWIID_EXT_MOTIONPLUS: post("MotionPlus controller attached."); /* no calibration needed for MotionPlus */ break; +#endif case CWIID_EXT_UNKNOWN: post("Unknown extension attached"); break; @@ -420,33 +442,33 @@ static void wiiremote_cwiid_message(t_wiiremote *x, union cwiid_mesg mesg) { } break; case CWIID_MESG_BTN: - wiiremote_cwiid_btn(x, &mesg.btn_mesg); + wiimote_cwiid_btn(x, &mesg.btn_mesg); break; case CWIID_MESG_ACC: - wiiremote_cwiid_acc(x, &mesg.acc_mesg); + wiimote_cwiid_acc(x, &mesg.acc_mesg); break; case CWIID_MESG_IR: - wiiremote_cwiid_ir(x, &mesg.ir_mesg); + wiimote_cwiid_ir(x, &mesg.ir_mesg); break; #ifdef CWIID_RPT_NUNCHUK case CWIID_MESG_NUNCHUK: - wiiremote_cwiid_nunchuk(x, &mesg.nunchuk_mesg); + wiimote_cwiid_nunchuk(x, &mesg.nunchuk_mesg); break; #endif #ifdef CWIID_RPT_CLASSIC case CWIID_MESG_CLASSIC: - wiiremote_cwiid_classic(x, &mesg.classic_mesg); + wiimote_cwiid_classic(x, &mesg.classic_mesg); // todo break; #endif #ifdef CWIID_RPT_MOTIONPLUS case CWIID_MESG_MOTIONPLUS: - wiiremote_cwiid_motionplus(x, &mesg.motionplus_mesg); + wiimote_cwiid_motionplus(x, &mesg.motionplus_mesg); break; #endif #ifdef CWIID_RPT_BALANCE case CWIID_MESG_BALANCE: - wiiremote_cwiid_balance(x, &mesg.balance_mesg); + wiimote_cwiid_balance(x, &mesg.balance_mesg); break; #endif default: @@ -472,24 +494,24 @@ static void print_timestamp(struct timespec*timestamp, struct timespec*reference // The CWiid library invokes a callback function whenever events are -// generated by the wiiremote. This function is specified when connecting -// to the wiiremote (in the cwiid_open function). +// generated by the wiimote. This function is specified when connecting +// to the wiimote (in the cwiid_open function). // Unfortunately, the mesg struct passed as an argument to the -// callback does not have a pointer to the wiiremote instance, and it -// is thus impossible to know which wiiremote-object has invoked the callback. +// callback does not have a pointer to the wiimote instance, and it +// is thus impossible to know which wiimote-object has invoked the callback. // For this case we provide a hard-coded set of wrapper callbacks to -// indicate which Pd wiiremote instance to control. +// indicate which Pd wiimote instance to control. -// So far I have only checked with one wiiremote +// So far I have only checked with one wiimote -/*void cwiid_callback(cwiid_wiiremote_t *wiimt, int mesg_count, union cwiid_mesg *mesg[], struct timespec *timestamp) +/*void cwiid_callback(cwiid_wiimote_t *wiimt, int mesg_count, union cwiid_mesg *mesg[], struct timespec *timestamp) */ -static void cwiid_callback(cwiid_wiimote_t *wiiremote, int mesg_count, +static void cwiid_callback(cwiid_wiimote_t *wiimote, int mesg_count, union cwiid_mesg mesg_array[], struct timespec *timestamp) { int i; - t_wiiremote *x=NULL; + t_wiimote *x=NULL; static struct timespec*ts=NULL; if(NULL==ts) { @@ -498,111 +520,135 @@ static void cwiid_callback(cwiid_wiimote_t *wiiremote, int mesg_count, ts->tv_nsec =timestamp->tv_nsec; } - if(g_wiiremoteList==NULL||wiiremote==NULL) { + if(g_wiimoteList==NULL||wiimote==NULL) { post("no wii's known"); return; } - x=getWiiremoteObject(cwiid_get_id(wiiremote)); + x=getWiimoteObject(cwiid_get_id(wiimote)); if(NULL==x) { - post("no wiiremote loaded: %d%",cwiid_get_id(wiiremote)); + post("no wiimote loaded: %d%",cwiid_get_id(wiimote)); return; } //print_timestamp(timestamp, ts); for (i=0; i < mesg_count; i++) { - wiiremote_cwiid_message(x, mesg_array[i]); + wiimote_cwiid_message(x, mesg_array[i]); } } // ============================================================== -static void wiiremote_status(t_wiiremote *x) +static void wiimote_status(t_wiimote *x) { if(x->connected) { - if (cwiid_request_status(x->wiiremote)) { + if (cwiid_request_status(x->wiimote)) { pd_error(x, "error requesting status message"); } } } -static void wiiremote_resetReportMode(t_wiiremote *x) +static void wiimote_resetReportMode(t_wiimote *x) { if (x->connected) { - verbose(1, "changing report mode for Wii%02d to %d", x->wiiremoteID, x->reportMode); - if (cwiid_command(x->wiiremote, CWIID_CMD_RPT_MODE, x->reportMode)) { - post("wiiremote error: problem setting report mode."); + verbose(1, "changing report mode for Wii%02d to %d", x->wiimoteID, x->reportMode); + if (cwiid_command(x->wiimote, CWIID_CMD_RPT_MODE, x->reportMode)) { + post("wiimote error: problem setting report mode."); } } } -static void wiiremote_setReportMode(t_wiiremote *x, t_floatarg r) +static void wiimote_setReportMode(t_wiimote *x, t_floatarg r) { if (r >= 0) { x->reportMode = (int) r; - wiiremote_resetReportMode(x); + wiimote_resetReportMode(x); } else { return; } } -static void wiiremote_report(t_wiiremote*x, int flag, int onoff) +static void wiimote_report(t_wiimote*x, t_symbol*s, int onoff) { - if(onoff) { - x->reportMode |= flag; - } else { - x->reportMode &= ~flag; - } - wiiremote_resetReportMode(x); + int flag=-1; + if(gensym("status")==s) flag=CWIID_RPT_STATUS; + else if(gensym("button")==s) flag=CWIID_RPT_BTN; + else if(gensym("acceleration")==s) flag=CWIID_RPT_ACC; + else if(gensym("ir")==s) flag=CWIID_RPT_IR; +#ifdef CWIID_RPT_NUNCHUK + else if(gensym("nunchuk")==s) flag=CWIID_RPT_NUNCHUK; +#endif +#ifdef CWIID_RPT_CLASSIC + else if(gensym("classic")==s) flag=CWIID_RPT_CLASSIC; +#endif +#ifdef CWIID_RPT_BALANCE + else if(gensym("balance")==s) flag=CWIID_RPT_BALANCE; +#endif +#ifdef CWIID_RPT_MOTIONPLUS + else if(gensym("motionplus")==s) flag=CWIID_RPT_MOTIONPLUS; +#endif + else if(gensym("ext")==s) flag=CWIID_RPT_EXT; + else { + pd_error(x, "unknown report mode '%s'", s->s_name); + } + + if(flag!=-1) { + if(onoff) { + x->reportMode |= flag; + } else { + x->reportMode &= ~flag; + } + } + wiimote_resetReportMode(x); } -static void wiiremote_reportAcceleration(t_wiiremote *x, t_floatarg f) +static void wiimote_reportAcceleration(t_wiimote *x, t_floatarg f) { - wiiremote_report(x, CWIID_RPT_ACC, f); + wiimote_report(x, gensym("acceleration"), f); } -static void wiiremote_reportIR(t_wiiremote *x, t_floatarg f) +static void wiimote_reportIR(t_wiimote *x, t_floatarg f) { - wiiremote_report(x, CWIID_RPT_IR, f); + wiimote_report(x, gensym("ir"), f); } -static void wiiremote_reportNunchuk(t_wiiremote *x, t_floatarg f) +static void wiimote_reportNunchuk(t_wiimote *x, t_floatarg f) { - wiiremote_report(x, CWIID_RPT_EXT, f); + wiimote_report(x, gensym("nunchuck"), f); } -static void wiiremote_reportMotionplus(t_wiiremote *x, t_floatarg f) +static void wiimote_reportMotionplus(t_wiimote *x, t_floatarg f) { #ifdef CWIID_RPT_MOTIONPLUS int flag=f; if (x->connected) { - verbose(1, "changing motionplus report mode for Wii%02d to %d", x->wiiremoteID, flag); + verbose(1, "changing motionplus report mode for Wii%02d to %d", x->wiimoteID, flag); int err=0; if(flag) { - err=cwiid_enable(x->wiiremote, CWIID_FLAG_MOTIONPLUS); + err=cwiid_enable(x->wiimote, CWIID_FLAG_MOTIONPLUS); } else { - err=cwiid_disable(x->wiiremote, CWIID_FLAG_MOTIONPLUS); + err=cwiid_disable(x->wiimote, CWIID_FLAG_MOTIONPLUS); } if(err) { pd_error(x, "turning %s motionplus returned %d", (flag?"on":"off"), err); } else { - wiiremote_report(x, CWIID_RPT_MOTIONPLUS, f); + wiimote_report(x, gensym("motionplus"), f); } } #endif } -static void wiiremote_setRumble(t_wiiremote *x, t_floatarg f) +static void wiimote_setRumble(t_wiimote *x, t_floatarg f) { if (x->connected) { - if (cwiid_command(x->wiiremote, CWIID_CMD_RUMBLE, f)) post("wiiremote error: problem setting rumble."); + if (cwiid_command(x->wiimote, CWIID_CMD_RUMBLE, f)) post("wiimote error: problem setting rumble."); } } -static void wiiremote_setLED(t_wiiremote *x, t_floatarg f) +static void wiimote_setLED(t_wiimote *x, t_floatarg f) { // some possible values: // CWIID_LED0_ON 0x01 @@ -611,7 +657,7 @@ static void wiiremote_setLED(t_wiiremote *x, t_floatarg f) // CWIID_LED3_ON 0x08 if (x->connected) { - if (cwiid_command(x->wiiremote, CWIID_CMD_LED, f)) post("wiiremote error: problem setting LED."); + if (cwiid_command(x->wiimote, CWIID_CMD_LED, f)) post("wiimote error: problem setting LED."); } } @@ -620,13 +666,13 @@ static void wiiremote_setLED(t_wiiremote *x, t_floatarg f) // ============================================================== -// The following function attempts to connect to a wiiremote at a +// The following function attempts to connect to a wiimote at a // specific address, provided as an argument. eg, 00:19:1D:70:CE:72 // This address can be discovered by running the following command // in a console: // hcitool scan | grep Nintendo -static void wiiremote_doConnect(t_wiiremote *x, t_symbol *addr, t_symbol *dongaddr) +static void wiimote_doConnect(t_wiimote *x, t_symbol *addr, t_symbol *dongaddr) { bdaddr_t bdaddr; unsigned int flags = CWIID_FLAG_MESG_IFC; @@ -657,31 +703,31 @@ static void wiiremote_doConnect(t_wiiremote *x, t_symbol *addr, t_symbol *dongad #if 0 - x->wiiremote = cwiid_open(&bdaddr, dong_bdaddr_ptr, flags); + x->wiimote = cwiid_open(&bdaddr, dong_bdaddr_ptr, flags); #else -#warning multi-dongle support... - x->wiiremote = cwiid_open(&bdaddr, flags); +#warning multi-dongle support missing... + x->wiimote = cwiid_open(&bdaddr, flags); #endif - if(NULL==x->wiiremote) { - post("wiiremote error: unable to connect"); + if(NULL==x->wiimote) { + post("wiimote error: unable to connect"); return; } - if(!addWiiremoteObject(x, cwiid_get_id(x->wiiremote))) { - cwiid_close(x->wiiremote); - x->wiiremote=NULL; + if(!addWiimoteObject(x, cwiid_get_id(x->wiimote))) { + cwiid_close(x->wiimote); + x->wiimote=NULL; return; } - x->wiiremoteID= cwiid_get_id(x->wiiremote); + x->wiimoteID= cwiid_get_id(x->wiimote); - post("wiiremote %i is successfully connected", x->wiiremoteID); + post("wiimote %i is successfully connected", x->wiimoteID); - if(cwiid_get_acc_cal(x->wiiremote, CWIID_EXT_NONE, &x->acc_cal)) { + if(cwiid_get_acc_cal(x->wiimote, CWIID_EXT_NONE, &x->acc_cal)) { post("Unable to retrieve accelerometer calibration"); } else { - post("Retrieved wiiremote calibration: zero=(%02d,%02d,%02d) one=(%02d,%02d,%02d)", + post("Retrieved wiimote calibration: zero=(%02d,%02d,%02d) one=(%02d,%02d,%02d)", x->acc_cal.zero[CWIID_X], x->acc_cal.zero[CWIID_Y], x->acc_cal.zero[CWIID_Z], @@ -694,41 +740,41 @@ static void wiiremote_doConnect(t_wiiremote *x, t_symbol *addr, t_symbol *dongad x->reportMode |= CWIID_RPT_STATUS; x->reportMode |= CWIID_RPT_BTN; - wiiremote_resetReportMode(x); + wiimote_resetReportMode(x); - if (cwiid_set_mesg_callback(x->wiiremote, &cwiid_callback)) { + if (cwiid_set_mesg_callback(x->wiimote, &cwiid_callback)) { pd_error(x, "Unable to set message callback"); } } -// The following function attempts to discover a wiiremote. It requires -// that the user puts the wiiremote into 'discoverable' mode before being +// The following function attempts to discover a wiimote. It requires +// that the user puts the wiimote into 'discoverable' mode before being // called. This is done by pressing the red button under the battery // cover, or by pressing buttons 1 and 2 simultaneously. // TODO: Without pressing the buttons, I get a segmentation error. So far, I don't know why. -static void wiiremote_discover(t_wiiremote *x) +static void wiimote_discover(t_wiimote *x) { - post("Put the wiiremote into discover mode by pressing buttons 1 and 2 simultaneously."); + post("Put the wiimote into discover mode by pressing buttons 1 and 2 simultaneously."); - wiiremote_doConnect(x, NULL, gensym("NULL")); + wiimote_doConnect(x, NULL, gensym("NULL")); if (!(x->connected)) { - post("Error: could not find any wiiremotes. Please ensure that bluetooth is enabled, and that the 'hcitool scan' command lists your Nintendo device."); + post("Error: could not find any wiimotes. Please ensure that bluetooth is enabled, and that the 'hcitool scan' command lists your Nintendo device."); } } -static void wiiremote_doDisconnect(t_wiiremote *x) +static void wiimote_doDisconnect(t_wiimote *x) { if (x->connected) { - if (cwiid_close(x->wiiremote)) { - post("wiiremote error: problems when disconnecting."); + if (cwiid_close(x->wiimote)) { + post("wiimote error: problems when disconnecting."); } else { post("disconnect successfull, resetting values"); - removeWiiremoteObject(x); + removeWiimoteObject(x); x->connected = 0; } } @@ -740,16 +786,16 @@ static void wiiremote_doDisconnect(t_wiiremote *x) // ============================================================== // ============================================================== -static void *wiiremote_new(t_symbol*s, int argc, t_atom *argv) +static void *wiimote_new(t_symbol*s, int argc, t_atom *argv) { - t_wiiremote *x = (t_wiiremote *)pd_new(wiiremote_class); + t_wiimote *x = (t_wiimote *)pd_new(wiimote_class); // create outlets: x->outlet_data = outlet_new(&x->x_obj, NULL); // initialize toggles: x->connected = 0; - x->wiiremoteID = -1; + x->wiimoteID = -1; // connect if user provided an address as an argument: @@ -758,9 +804,9 @@ static void *wiiremote_new(t_symbol*s, int argc, t_atom *argv) post("[%s] connecting to provided address...", s->s_name); if (argv->a_type == A_SYMBOL) { - wiiremote_doConnect(x, NULL, atom_getsymbol(argv)); + wiimote_doConnect(x, NULL, atom_getsymbol(argv)); } else { - error("[wiiremote] expects either no argument, or a bluetooth address as an argument. eg, 00:19:1D:70:CE:72"); + error("[wiimote] expects either no argument, or a bluetooth address as an argument. eg, 00:19:1D:70:CE:72"); return NULL; } } @@ -768,38 +814,40 @@ static void *wiiremote_new(t_symbol*s, int argc, t_atom *argv) } -static void wiiremote_free(t_wiiremote* x) +static void wiimote_free(t_wiimote* x) { - wiiremote_doDisconnect(x); + wiimote_doDisconnect(x); } -void wiiremote_setup(void) +void wiimote_setup(void) { - wiiremote_class = class_new(gensym("wiiremote"), (t_newmethod)wiiremote_new, (t_method)wiiremote_free, sizeof(t_wiiremote), CLASS_DEFAULT, A_GIMME, 0); + wiimote_class = class_new(gensym("wiimote"), (t_newmethod)wiimote_new, (t_method)wiimote_free, sizeof(t_wiimote), CLASS_DEFAULT, A_GIMME, 0); - class_addmethod(wiiremote_class, (t_method) wiiremote_debug, gensym("debug"), 0); - class_addmethod(wiiremote_class, (t_method) wiiremote_status, gensym("status"), 0); + class_addmethod(wiimote_class, (t_method) wiimote_debug, gensym("debug"), 0); + class_addmethod(wiimote_class, (t_method) wiimote_status, gensym("status"), 0); /* connection settings */ - class_addmethod(wiiremote_class, (t_method) wiiremote_doConnect, gensym("connect"), A_DEFSYMBOL, A_DEFSYMBOL, 0); - class_addmethod(wiiremote_class, (t_method) wiiremote_doDisconnect, gensym("disconnect"), 0); - class_addmethod(wiiremote_class, (t_method) wiiremote_discover, gensym("discover"), 0); + class_addmethod(wiimote_class, (t_method) wiimote_doConnect, gensym("connect"), A_DEFSYMBOL, A_DEFSYMBOL, 0); + class_addmethod(wiimote_class, (t_method) wiimote_doDisconnect, gensym("disconnect"), 0); + class_addmethod(wiimote_class, (t_method) wiimote_discover, gensym("discover"), 0); /* query data */ - class_addmethod(wiiremote_class, (t_method) wiiremote_setReportMode, gensym("setReportMode"), A_DEFFLOAT, 0); - class_addmethod(wiiremote_class, (t_method) wiiremote_reportAcceleration, gensym("reportAcceleration"), A_DEFFLOAT, 0); - class_addmethod(wiiremote_class, (t_method) wiiremote_reportIR, gensym("reportIR"), A_DEFFLOAT, 0); + class_addmethod(wiimote_class, (t_method) wiimote_report, gensym("report"), A_SYMBOL, A_FLOAT, 0); + + class_addmethod(wiimote_class, (t_method) wiimote_setReportMode, gensym("setReportMode"), A_FLOAT, 0); + class_addmethod(wiimote_class, (t_method) wiimote_reportAcceleration, gensym("reportAcceleration"), A_FLOAT, 0); + class_addmethod(wiimote_class, (t_method) wiimote_reportIR, gensym("reportIR"), A_FLOAT, 0); - class_addmethod(wiiremote_class, (t_method) wiiremote_reportNunchuk, gensym("reportNunchuck"), A_DEFFLOAT, 0); - class_addmethod(wiiremote_class, (t_method) wiiremote_reportNunchuk, gensym("reportNunchuk"), A_DEFFLOAT, 0); - class_addmethod(wiiremote_class, (t_method) wiiremote_reportMotionplus, gensym("reportMotionplus"), A_DEFFLOAT, 0); + class_addmethod(wiimote_class, (t_method) wiimote_reportNunchuk, gensym("reportNunchuck"), A_FLOAT, 0); + class_addmethod(wiimote_class, (t_method) wiimote_reportNunchuk, gensym("reportNunchuk"), A_FLOAT, 0); + class_addmethod(wiimote_class, (t_method) wiimote_reportMotionplus, gensym("reportMotionplus"), A_FLOAT, 0); /* set things on the wiimote */ - class_addmethod(wiiremote_class, (t_method) wiiremote_setRumble, gensym("setRumble"), A_DEFFLOAT, 0); - class_addmethod(wiiremote_class, (t_method) wiiremote_setLED, gensym("setLED"), A_DEFFLOAT, 0); + class_addmethod(wiimote_class, (t_method) wiimote_setRumble, gensym("setRumble"), A_FLOAT, 0); + class_addmethod(wiimote_class, (t_method) wiimote_setLED, gensym("setLED"), A_FLOAT, 0); } |