libcm is a C development framework with an emphasis on audio signal processing applications.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

cmDspUi.c 19KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520
  1. #include "cmPrefix.h"
  2. #include "cmGlobal.h"
  3. #include "cmFloatTypes.h"
  4. #include "cmRpt.h"
  5. #include "cmErr.h"
  6. #include "cmCtx.h"
  7. #include "cmMem.h"
  8. #include "cmMallocDebug.h"
  9. #include "cmLinkedHeap.h"
  10. #include "cmJson.h"
  11. #include "cmSymTbl.h"
  12. #include "cmPrefs.h"
  13. #include "cmDspValue.h"
  14. #include "cmMsgProtocol.h"
  15. #include "cmProcObj.h"
  16. #include "cmDspCtx.h"
  17. #include "cmDspClass.h"
  18. #include "cmDspUi.h"
  19. #include "cmThread.h"
  20. #include "cmUdpPort.h"
  21. #include "cmUdpNet.h"
  22. #include "cmSerialPort.h"
  23. #include "cmTime.h"
  24. #include "cmAudioSys.h"
  25. /*
  26. // buffer layout is:
  27. // [ cmDspUiHdr_t <data> ]
  28. // The format of the <data> is determiend by hdr.value.
  29. // Since hdr.value is the last field in the cmDspUiHdr_t record
  30. // the data follows this value.
  31. cmDspRC_t cmDspMsgSend(
  32. cmErr_t* err,
  33. unsigned asSubIdx,
  34. unsigned msgTypeId,
  35. unsigned selId,
  36. unsigned flags,
  37. unsigned instId,
  38. unsigned instVarId,
  39. const cmDspValue_t* valPtr,
  40. cmRC_t (*sendFunc)(void* cbDataPtr, const void* msgArray[], unsigned msgByteCntArray[], unsigned segCnt ),
  41. void* cbDataPtr )
  42. {
  43. unsigned bufByteCnt = sizeof(cmDspUiHdr_t);
  44. unsigned dataByteCnt = 0;
  45. if( valPtr != NULL )
  46. dataByteCnt = cmDsvSerialDataByteCount(valPtr);
  47. bufByteCnt += dataByteCnt;
  48. char buf[ bufByteCnt ];
  49. cmDspUiHdr_t* hdr = (cmDspUiHdr_t*)buf;
  50. hdr->asSubIdx = asSubIdx;
  51. hdr->uiId = msgTypeId; // see kXXXSelAsId identifiers in cmAudioSys.h
  52. hdr->selId = selId; // if msgTypeId==kUiSelAsId then see kXXXDuId in cmDspUi.h
  53. hdr->flags = flags;
  54. hdr->instId = instId;
  55. hdr->instVarId = instVarId;
  56. if( valPtr == NULL )
  57. cmDsvSetNull(&hdr->value);
  58. else
  59. {
  60. // this function relies on the 'hdr.value' field being the last field in the 'hdr'.
  61. if( cmDsvSerialize( valPtr, &hdr->value, sizeof(cmDspValue_t) + dataByteCnt) != kOkDsvRC )
  62. return cmErrMsg(err,kSerializeUiMsgFailDspRC,"An attempt to serialize a UI msg failed.");
  63. }
  64. const void* vp = buf;
  65. if( sendFunc(cbDataPtr,&vp,&bufByteCnt,1) != cmOkRC )
  66. return cmErrMsg(err,kSendToHostFailDspRC,"An attempt to transmit a msg to the host failed.");
  67. return kOkDspRC;
  68. }
  69. */
  70. // This function is passed to cmDspMsgSend() by _cmDspUiMsg().
  71. // It is used to coerce the callback data ptr 'cbDataPtr' into a
  72. // cmAudioSysCtx_str* for calling back into cmDspSys. It then translates
  73. // the result code from a cmAsRC_t to a cmRC_t.
  74. cmMsgRC_t _cmDspUiDspToHostCb( void* cbDataPtr, unsigned msgByteCnt, const void* msg)
  75. {
  76. struct cmAudioSysCtx_str* asCtx = (struct cmAudioSysCtx_str*)cbDataPtr;
  77. cmMsgRC_t rc = kOkMsgRC;
  78. if(asCtx->dspToHostFunc(asCtx, &msg, &msgByteCnt, 1) != kOkAsRC )
  79. rc = kSendFailMsgRC;
  80. return rc;
  81. }
  82. cmDspRC_t _cmDspUiMsg(cmDspCtx_t* ctx, unsigned msgTypeId, unsigned selId, unsigned flags, cmDspInst_t* inst, unsigned instVarId, const cmDspValue_t* valPtr )
  83. {
  84. return cmMsgSend(
  85. &ctx->cmCtx->err,
  86. ctx->ctx->asSubIdx,
  87. msgTypeId,
  88. selId,
  89. flags,
  90. inst==NULL ? cmInvalidId : inst->id,
  91. instVarId,
  92. valPtr,
  93. _cmDspUiDspToHostCb,
  94. ctx->ctx );
  95. }
  96. // buffer layout is:
  97. // [ cmDspUiHdr_t <data> ]
  98. // The format of the <data> is determiend by hdr.value.
  99. // Since hdr.value is the last field in the cmDspUiHdr_t record
  100. // the data follows this value.
  101. /*
  102. cmDspRC_t _cmDspUiMsg(cmDspCtx_t* ctx, unsigned msgTypeId, unsigned selId, unsigned flags, cmDspInst_t* inst, unsigned instVarId, const cmDspValue_t* valPtr )
  103. {
  104. unsigned bufByteCnt = sizeof(cmDspUiHdr_t);
  105. unsigned dataByteCnt = 0;
  106. if( valPtr != NULL )
  107. dataByteCnt = cmDsvSerialDataByteCount(valPtr);
  108. bufByteCnt += dataByteCnt;
  109. char buf[ bufByteCnt ];
  110. cmDspUiHdr_t* hdr = (cmDspUiHdr_t*)buf;
  111. hdr->asSubIdx = ctx->ctx->asSubIdx;
  112. hdr->uiId = msgTypeId; // see kXXXSelAsId identifiers in cmAudioSys.h
  113. hdr->selId = selId; // if msgTypeId==kUiSelAsId then see kXXXDuId in cmDspUi.h
  114. hdr->flags = flags;
  115. hdr->instId = inst==NULL ? cmInvalidId : inst->id;
  116. hdr->instVarId = instVarId;
  117. if( valPtr == NULL )
  118. cmDsvSetNull(&hdr->value);
  119. else
  120. {
  121. // this function relies on the 'hdr.value' field being the last field in the 'hdr'.
  122. if( cmDsvSerialize( valPtr, &hdr->value, sizeof(cmDspValue_t) + dataByteCnt) != kOkDsvRC )
  123. {
  124. if( inst == NULL )
  125. return cmErrMsg(&ctx->cmCtx->err,kSerializeUiMsgFailDspRC,"An attempt to serialize a UI msg failed.");
  126. else
  127. return cmDspInstErr(ctx,inst,kSerializeUiMsgFailDspRC,"An attempt to serialize a msg for '%s' failed.",inst->classPtr->labelStr);
  128. }
  129. }
  130. const void* vp = buf;
  131. if( ctx->ctx->dspToHostFunc(ctx->ctx,&vp,&bufByteCnt,1) != kOkAsRC )
  132. {
  133. if( inst == NULL )
  134. return cmErrMsg(&ctx->cmCtx->err,kSendToHostFailDspRC,"An attempt to transmit a msg to the host failed.");
  135. else
  136. return cmDspInstErr(ctx,inst,kSendToHostFailDspRC,"An attempt to transmit a msg to the host failed.");
  137. }
  138. return kOkDspRC;
  139. }
  140. */
  141. cmDspRC_t _cmDspUiUseInstSymbolAsLabel( cmDspCtx_t* ctx, cmDspInst_t* inst, unsigned lblVarId, const cmChar_t* ctlTypeStr )
  142. {
  143. if( inst->symId != cmInvalidId )
  144. {
  145. cmDspValue_t v;
  146. // use the instance symbol as the default UI control label
  147. const cmChar_t* label = cmDspDefaultStrcz(inst,lblVarId);
  148. if( label == NULL )
  149. label = cmSymTblLabel(ctx->stH,inst->symId);
  150. if(label != NULL )
  151. {
  152. cmDsvSetStrcz(&v,label);
  153. if( _cmDspUiMsg(ctx, kUiSelAsId, kValueDuiId, 0, inst, lblVarId, &v ) != kOkDspRC )
  154. return cmDspInstErr(ctx,inst,kUiEleCreateFailDspRC,"%s label UI elment create failed.", ctlTypeStr);
  155. }
  156. }
  157. return kOkDspRC;
  158. }
  159. cmDspRC_t cmDspSendValueToAudioSys( cmDspCtx_t* ctx, unsigned msgTypeId, unsigned selId, unsigned valId, const cmDspValue_t* valPtr )
  160. { return _cmDspUiMsg(ctx, msgTypeId, selId, 0, NULL, valId, valPtr ); }
  161. cmDspRC_t cmDspProgramIsDone( cmDspCtx_t* ctx )
  162. { return _cmDspUiMsg(ctx, kUiSelAsId, kPgmDoneDuiId, 0, NULL, cmInvalidId, NULL ); }
  163. cmDspRC_t cmDspUiConsolePrint( cmDspCtx_t* ctx, cmChar_t* text )
  164. {
  165. cmDspValue_t v;
  166. cmDsvSetStrz(&v,text);
  167. return _cmDspUiMsg( ctx, kUiSelAsId, kPrintDuiId, 0, NULL, cmInvalidId, &v );
  168. }
  169. cmDspRC_t cmDspUiSendValue( cmDspCtx_t* ctx, cmDspInst_t* inst, unsigned varId, const cmDspValue_t* valPtr )
  170. { return _cmDspUiMsg(ctx, kUiSelAsId, kValueDuiId, 0, inst, varId, valPtr ); }
  171. cmDspRC_t cmDspUiSendVar( cmDspCtx_t* ctx, cmDspInst_t* inst, cmDspVar_t* var )
  172. { return _cmDspUiMsg(ctx, kUiSelAsId, kValueDuiId, 0, inst, var->constId, &var->value ); }
  173. cmDspRC_t cmDspUiScalarCreate( cmDspCtx_t* ctx, cmDspInst_t* inst, unsigned ctlDuiId, unsigned minVarId, unsigned maxVarId, unsigned stpVarId, unsigned valVarId, unsigned lblVarId )
  174. {
  175. cmDspRC_t rc;
  176. unsigned arr[] = { minVarId, maxVarId, stpVarId, valVarId, lblVarId };
  177. cmDspValue_t v;
  178. unsigned vn = sizeof(arr)/sizeof(arr[0]);
  179. cmDsvSetUIntMtx(&v,arr,vn,1);
  180. // tell the UI to create a slider control
  181. if((rc = _cmDspUiMsg( ctx, kUiSelAsId, ctlDuiId, 0, inst, cmInvalidId, &v )) != kOkDspRC )
  182. return cmDspInstErr(ctx,inst,kUiEleCreateFailDspRC,"Scalar UI element create failed.");
  183. // use instance symbol as default label
  184. if((rc = _cmDspUiUseInstSymbolAsLabel(ctx, inst, lblVarId, "Scalar")) != kOkDspRC )
  185. return rc;
  186. // Set the kUiDsvFl on the variables used for the min/max/def/val for this scalar
  187. // Setting this flag will cause their values to be sent to the UI whenever they change.
  188. cmDspInstVarSetFlags( ctx, inst, minVarId, kUiDsvFl );
  189. cmDspInstVarSetFlags( ctx, inst, maxVarId, kUiDsvFl );
  190. cmDspInstVarSetFlags( ctx, inst, stpVarId, kUiDsvFl );
  191. cmDspInstVarSetFlags( ctx, inst, valVarId, kUiDsvFl );
  192. return rc;
  193. }
  194. cmDspRC_t cmDspUiTextCreate( cmDspCtx_t* ctx, cmDspInst_t* inst, unsigned valVarId, unsigned lblVarId )
  195. {
  196. cmDspRC_t rc;
  197. unsigned arr[] = { valVarId, lblVarId };
  198. cmDspValue_t v;
  199. unsigned vn = sizeof(arr)/sizeof(arr[0]);
  200. cmDsvSetUIntMtx(&v,arr,vn,1);
  201. // tell the UI to create a text control
  202. if((rc = _cmDspUiMsg( ctx, kUiSelAsId, kTextDuiId, 0, inst, cmInvalidId, &v )) != kOkDspRC )
  203. return cmDspInstErr(ctx,inst,kUiEleCreateFailDspRC,"Text UI element create failed.");
  204. // use instance symbol as default label
  205. if((rc = _cmDspUiUseInstSymbolAsLabel(ctx, inst, lblVarId, "Text")) != kOkDspRC )
  206. return rc;
  207. // Set the kUiDsvFl on the variables used for the min/max/def/val for this scalar
  208. // Setting this flag will cause their values to be sent to the UI whenever they change.
  209. cmDspInstVarSetFlags( ctx, inst, valVarId, kUiDsvFl );
  210. return rc;
  211. }
  212. cmDspRC_t cmDspUiFnameCreate( cmDspCtx_t* ctx, cmDspInst_t* inst, unsigned valVarId, unsigned patVarId, unsigned dirVarId )
  213. {
  214. cmDspRC_t rc = kOkDspRC;
  215. unsigned arr[] = { valVarId, patVarId, dirVarId };
  216. unsigned vn = sizeof(arr)/sizeof(arr[0]);
  217. cmDspValue_t v;
  218. unsigned i;
  219. cmDsvSetUIntMtx(&v,arr,vn,1);
  220. if((rc = _cmDspUiMsg(ctx, kUiSelAsId, kFnameDuiId, 0, inst, cmInvalidId, &v )) != kOkDspRC )
  221. return cmDspInstErr(ctx,inst,kUiEleCreateFailDspRC,"File/Directory chooser UI element create failed.");
  222. // set the kDsvUiFl in the variabes which update the UI
  223. for(i=0; i<vn; ++i)
  224. cmDspInstVarSetFlags( ctx, inst, arr[i], kUiDsvFl );
  225. return rc;
  226. }
  227. cmDspRC_t cmDspUiMsgListCreate( cmDspCtx_t* ctx, cmDspInst_t* inst, unsigned height, unsigned listVarId, unsigned selVarId )
  228. {
  229. cmDspRC_t rc = kOkDspRC;
  230. unsigned arr[] = { height, selVarId, listVarId };
  231. unsigned vn = sizeof(arr)/sizeof(arr[0]);
  232. cmDspValue_t v;
  233. unsigned i;
  234. cmDsvSetUIntMtx(&v,arr,vn,1);
  235. if((rc = _cmDspUiMsg(ctx, kUiSelAsId, kMsgListDuiId, 0, inst, cmInvalidId, &v )) != kOkDspRC )
  236. return cmDspInstErr(ctx,inst,kUiEleCreateFailDspRC,"Msg List UI element create failed.");
  237. // set the kDsvUiFl in the variabes which update the UI
  238. for(i=1; i<vn; ++i)
  239. cmDspInstVarSetFlags( ctx, inst, arr[i], kUiDsvFl );
  240. return rc;
  241. }
  242. cmDspRC_t cmDspUiMeterCreate( cmDspCtx_t* ctx, cmDspInst_t* inst, unsigned minVarId, unsigned maxVarId, unsigned valVarId, unsigned lblVarId )
  243. {
  244. cmDspRC_t rc;
  245. unsigned arr[] = { minVarId, maxVarId, valVarId, lblVarId };
  246. cmDspValue_t v;
  247. unsigned vn = sizeof(arr)/sizeof(arr[0]);
  248. cmDsvSetUIntMtx(&v,arr,vn,1);
  249. // tell the UI to create a meter control
  250. if((rc = _cmDspUiMsg( ctx, kUiSelAsId, kMeterDuiId, 0, inst, cmInvalidId, &v )) != kOkDspRC )
  251. return cmDspInstErr(ctx,inst,kUiEleCreateFailDspRC,"Meter UI element create failed.");
  252. // use instance symbol as default label
  253. if((rc = _cmDspUiUseInstSymbolAsLabel(ctx, inst, lblVarId, "Meter")) != kOkDspRC )
  254. return rc;
  255. // Set the kUiDsvFl on the variables used for the min/max/val for this meter
  256. // Setting this flag will cause their values to be sent to the UI whenever they change.
  257. cmDspInstVarSetFlags( ctx, inst, minVarId, kUiDsvFl );
  258. cmDspInstVarSetFlags( ctx, inst, maxVarId, kUiDsvFl );
  259. cmDspInstVarSetFlags( ctx, inst, valVarId, kUiDsvFl );
  260. return rc;
  261. }
  262. cmDspRC_t cmDspUiButtonCreate( cmDspCtx_t* ctx, cmDspInst_t* inst, unsigned typeDuiId, unsigned outVarId, unsigned lblVarId )
  263. {
  264. cmDspRC_t rc;
  265. unsigned arr[] = { outVarId, lblVarId };
  266. cmDspValue_t v;
  267. unsigned vn = sizeof(arr)/sizeof(arr[0]);
  268. cmDsvSetUIntMtx(&v, arr, vn, 1);
  269. // tell the UI to create a button control
  270. if((rc = _cmDspUiMsg( ctx, kUiSelAsId, typeDuiId, 0, inst, cmInvalidId, &v )) != kOkDspRC )
  271. return cmDspInstErr(ctx,inst,kUiEleCreateFailDspRC,"Button UI element create failed.");
  272. // use instance symbol as default label
  273. if((rc = _cmDspUiUseInstSymbolAsLabel(ctx, inst, lblVarId, "Button" )) != kOkDspRC )
  274. return rc;
  275. // Set the kUiDsvFl on the variables used for the val for this button
  276. // Setting this flag will cause their values to be sent to the UI whenever they change.
  277. cmDspInstVarSetFlags( ctx, inst, outVarId, kUiDsvFl );
  278. return rc;
  279. }
  280. cmDspRC_t cmDspUiLabelCreate( cmDspCtx_t* ctx, cmDspInst_t* inst, unsigned lblVarId, unsigned alignVarId )
  281. {
  282. cmDspRC_t rc;
  283. unsigned arr[] = { lblVarId, alignVarId };
  284. cmDspValue_t v;
  285. unsigned vn = sizeof(arr)/sizeof(arr[0]);
  286. cmDsvSetUIntMtx(&v, arr, vn, 1);
  287. // tell the UI to create a button control
  288. if((rc = _cmDspUiMsg( ctx, kUiSelAsId, kLabelDuiId, 0, inst, cmInvalidId, &v )) != kOkDspRC )
  289. return cmDspInstErr(ctx,inst,kUiEleCreateFailDspRC,"Button UI element create failed.");
  290. // use instance symbol as default label
  291. if((rc = _cmDspUiUseInstSymbolAsLabel(ctx, inst, lblVarId, "Label" )) != kOkDspRC )
  292. return rc;
  293. // Set the kUiDsvFl on the variables used for the val for this button
  294. // Setting this flag will cause their values to be sent to the UI whenever they change.
  295. cmDspInstVarSetFlags( ctx, inst, lblVarId, kUiDsvFl );
  296. cmDspInstVarSetFlags( ctx, inst, alignVarId, kUiDsvFl );
  297. return rc;
  298. }
  299. cmDspRC_t cmDspUiTimeLineCreate( cmDspCtx_t* ctx, cmDspInst_t* inst, unsigned tlFileVarId, unsigned audPathVarId, unsigned selVarId, unsigned measVarId, unsigned cursVarId )
  300. {
  301. cmDspRC_t rc;
  302. unsigned arr[] = { tlFileVarId, audPathVarId, selVarId, measVarId, cursVarId };
  303. cmDspValue_t v;
  304. unsigned vn = sizeof(arr)/sizeof(arr[0]);
  305. cmDsvSetUIntMtx(&v,arr,vn,1);
  306. // tell the UI to create a time-line control
  307. if((rc = _cmDspUiMsg( ctx, kUiSelAsId, kTimeLineDuiId, 0, inst, cmInvalidId, &v )) != kOkDspRC )
  308. return cmDspInstErr(ctx,inst,kUiEleCreateFailDspRC,"Time Line UI element create failed.");
  309. // use instance symbol as default label
  310. //if((rc = _cmDspUiUseInstSymbolAsLabel(ctx, inst, lblVarId, "TimeLine")) != kOkDspRC )
  311. // return rc;
  312. // Set the kUiDsvFl on the variables used for the min/max/def/val for this scalar
  313. // Setting this flag will cause their values to be sent to the UI whenever they change.
  314. cmDspInstVarSetFlags( ctx, inst, tlFileVarId, kUiDsvFl );
  315. cmDspInstVarSetFlags( ctx, inst, audPathVarId, kUiDsvFl );
  316. cmDspInstVarSetFlags( ctx, inst, selVarId, kUiDsvFl );
  317. cmDspInstVarSetFlags( ctx, inst, measVarId, kUiDsvFl );
  318. cmDspInstVarSetFlags( ctx, inst, cursVarId, kUiDsvFl );
  319. return rc;
  320. }
  321. cmDspRC_t cmDspUiScoreCreate( cmDspCtx_t* ctx, cmDspInst_t* inst, unsigned scFileVarId, unsigned selVarId, unsigned smpIdxVarId, unsigned pitchVarId, unsigned velVarId, unsigned locIdxVarId, unsigned evtIdxVarId, unsigned dynVarId, unsigned valTypeVarId, unsigned valueVarId, unsigned measVarId )
  322. {
  323. cmDspRC_t rc;
  324. unsigned arr[] = { scFileVarId, selVarId, smpIdxVarId, pitchVarId, velVarId, locIdxVarId, evtIdxVarId, dynVarId, valTypeVarId, valueVarId, measVarId };
  325. cmDspValue_t v;
  326. unsigned vn = sizeof(arr)/sizeof(arr[0]);
  327. cmDsvSetUIntMtx(&v,arr,vn,1);
  328. // tell the UI to create a score control
  329. if((rc = _cmDspUiMsg( ctx, kUiSelAsId, kScoreDuiId, 0, inst, cmInvalidId, &v )) != kOkDspRC )
  330. return cmDspInstErr(ctx,inst,kUiEleCreateFailDspRC,"Score UI element create failed.");
  331. // Set the kUiDsvFl on the variables used for the min/max/def/val for this scalar
  332. // Setting this flag will cause their values to be sent to the UI whenever they change.
  333. cmDspInstVarSetFlags( ctx, inst, scFileVarId, kUiDsvFl );
  334. cmDspInstVarSetFlags( ctx, inst, selVarId, kUiDsvFl );
  335. cmDspInstVarSetFlags( ctx, inst, smpIdxVarId, kUiDsvFl );
  336. cmDspInstVarSetFlags( ctx, inst, pitchVarId, kUiDsvFl );
  337. cmDspInstVarSetFlags( ctx, inst, velVarId, kUiDsvFl );
  338. cmDspInstVarSetFlags( ctx, inst, locIdxVarId, kUiDsvFl );
  339. cmDspInstVarSetFlags( ctx, inst, evtIdxVarId, kUiDsvFl );
  340. cmDspInstVarSetFlags( ctx, inst, dynVarId, kUiDsvFl );
  341. cmDspInstVarSetFlags( ctx, inst, valTypeVarId, kUiDsvFl );
  342. cmDspInstVarSetFlags( ctx, inst, valueVarId, kUiDsvFl );
  343. cmDspInstVarSetFlags( ctx, inst, measVarId, kUiDsvFl );
  344. return rc;
  345. }
  346. cmDspRC_t cmDspUiTakeSeqBldrCreate( cmDspCtx_t* ctx, cmDspInst_t* inst, unsigned fileNameVarId, unsigned ptrVarId, unsigned selVarId, unsigned refreshVarId )
  347. {
  348. cmDspRC_t rc;
  349. unsigned arr[] = { fileNameVarId, ptrVarId, selVarId, refreshVarId };
  350. cmDspValue_t v;
  351. unsigned vn = sizeof(arr)/sizeof(arr[0]);
  352. cmDsvSetUIntMtx(&v,arr,vn,1);
  353. // tell the UI to create a sequence builder control
  354. if((rc = _cmDspUiMsg( ctx, kUiSelAsId, kTakeSeqBldrDuiId, 0, inst, cmInvalidId, &v )) != kOkDspRC )
  355. return cmDspInstErr(ctx,inst,kUiEleCreateFailDspRC,"Take Sequence Builder UI element create failed.");
  356. // Setting kUiDsvFl will cause variable values to be sent to the UI whenever they change.
  357. cmDspInstVarSetFlags( ctx, inst, fileNameVarId, kUiDsvFl );
  358. cmDspInstVarSetFlags( ctx, inst, ptrVarId, kUiDsvFl );
  359. cmDspInstVarSetFlags( ctx, inst, selVarId, kUiDsvFl );
  360. cmDspInstVarSetFlags( ctx, inst, refreshVarId, kUiDsvFl );
  361. return rc;
  362. }
  363. cmDspRC_t cmDspUiTakeSeqRendCreate( cmDspCtx_t* ctx, cmDspInst_t* inst, unsigned ptrVarId, unsigned refreshVarId, unsigned selVarId )
  364. {
  365. cmDspRC_t rc;
  366. unsigned arr[] = { ptrVarId, refreshVarId, selVarId };
  367. cmDspValue_t v;
  368. unsigned vn = sizeof(arr)/sizeof(arr[0]);
  369. cmDsvSetUIntMtx(&v,arr,vn,1);
  370. // tell the UI to create a sequence render control
  371. if((rc = _cmDspUiMsg( ctx, kUiSelAsId, kTakeSeqRendDuiId, 0, inst, cmInvalidId, &v )) != kOkDspRC )
  372. return cmDspInstErr(ctx,inst,kUiEleCreateFailDspRC,"Take Sequence Render UI element create failed.");
  373. // Setting kUiDsvFl will cause variable values to be sent to the UI whenever they change.
  374. cmDspInstVarSetFlags( ctx, inst, ptrVarId, kUiDsvFl );
  375. cmDspInstVarSetFlags( ctx, inst, refreshVarId, kUiDsvFl );
  376. cmDspInstVarSetFlags( ctx, inst, selVarId, kUiDsvFl );
  377. return rc;
  378. }
  379. cmDspRC_t cmDspUi2dCreate( cmDspCtx_t* ctx, cmDspInst_t* inst, unsigned xVarId, unsigned yVarId, unsigned radiusVarId, unsigned angleVarId)
  380. {
  381. cmDspRC_t rc;
  382. unsigned arr[] = { xVarId, yVarId, radiusVarId, angleVarId };
  383. cmDspValue_t v;
  384. unsigned vn = sizeof(arr)/sizeof(arr[0]);
  385. cmDsvSetUIntMtx(&v,arr,vn,1);
  386. // tell the UI to create a sequence render control
  387. if((rc = _cmDspUiMsg( ctx, kUiSelAsId, kTwodDuiId, 0, inst, cmInvalidId, &v )) != kOkDspRC )
  388. return cmDspInstErr(ctx,inst,kUiEleCreateFailDspRC,"2-d UI element create failed.");
  389. // Setting kUiDsvFl will cause variable values to be sent to the UI whenever they change.
  390. cmDspInstVarSetFlags( ctx, inst, xVarId, kUiDsvFl );
  391. cmDspInstVarSetFlags( ctx, inst, yVarId, kUiDsvFl );
  392. cmDspInstVarSetFlags( ctx, inst, radiusVarId, kUiDsvFl );
  393. cmDspInstVarSetFlags( ctx, inst, angleVarId, kUiDsvFl );
  394. return rc;
  395. }
  396. cmDspRC_t cmDspUiNewColumn( cmDspCtx_t* ctx, unsigned colW )
  397. {
  398. cmDspRC_t rc = kOkDspRC;
  399. cmDspValue_t val;
  400. cmDsvSetUInt(&val,colW);
  401. if((rc = _cmDspUiMsg(ctx, kUiSelAsId, kColumnDuiId, 0, NULL, cmInvalidId, &val )) != kOkDspRC )
  402. return cmErrMsg(&ctx->cmCtx->err,kUiEleCreateFailDspRC,"New UI column request failed.");
  403. return rc;
  404. }
  405. cmDspRC_t cmDspUiInsertHorzBorder( cmDspCtx_t* ctx )
  406. {
  407. cmDspRC_t rc = kOkDspRC;
  408. if((rc = _cmDspUiMsg(ctx, kUiSelAsId, kHBorderDuiId, 0, NULL, cmInvalidId, NULL )) != kOkDspRC )
  409. return cmErrMsg(&ctx->cmCtx->err,kUiEleCreateFailDspRC,"Horizontal border request failed.");
  410. return rc;
  411. }
  412. cmDspRC_t cmDspUiNewPage( cmDspCtx_t* ctx, const cmChar_t* title )
  413. {
  414. cmDspRC_t rc = kOkDspRC;
  415. cmDspValue_t v;
  416. cmDsvSetStrcz(&v,title==NULL ? "Controls" : title );
  417. if((rc = _cmDspUiMsg(ctx, kUiSelAsId, kPageDuiId, 0, NULL, cmInvalidId, &v )) != kOkDspRC )
  418. return cmErrMsg(&ctx->cmCtx->err,kUiEleCreateFailDspRC,"New page request failed.");
  419. return rc;
  420. }