forked from MozillaReality/area-demo-service-task
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy patharosg.h
784 lines (719 loc) · 38.8 KB
/
arosg.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
/*
* arosg.h
* artoolkitX
*
* This file is part of artoolkitX.
*
* artoolkitX is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* artoolkitX is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with artoolkitX. If not, see <http://www.gnu.org/licenses/>.
*
* As a special exception, the copyright holders of this library give you
* permission to link this library with independent modules to produce an
* executable, regardless of the license terms of these independent modules, and to
* copy and distribute the resulting executable under terms of your choice,
* provided that you also meet, for each linked independent module, the terms and
* conditions of the license of that module. An independent module is a module
* which is neither derived from nor based on this library. If you modify this
* library, you may extend this exception to your version of the library, but you
* are not obligated to do so. If you do not wish to do so, delete this exception
* statement from your version.
*
* Copyright 2020 Mozilla.
* Copyright 2018 Realmax, Inc.
* Copyright 2015-2016 Daqri, LLC.
* Copyright 2009-2015 ARToolworks, Inc.
*
* Author(s): Philip Lamb
*
*/
/*!
@header arosg
@abstract C-interface to OpenSceneGraph for augmented reality applications.
@discussion
arosg is intended to provide access to the modern plugin-based scene graph
OpenSceneGraph, and its attendant model formats and graphical capabilities.
arosg provides a C-based interface to a limited subset of the
functionality of OpenSceneGraph. As of version 1.0 of arosg, the
supported functionality is primarily 3D model loading and drawing.
@availability Available ARToolKit v4.4.2 and later.
*/
#ifndef AR_OSG_H
#define AR_OSG_H
#include "ar_compat.h"
#ifdef _WIN32
# ifdef LIBAROSG_EXPORTS
# define AR_OSG_EXTERN __declspec(dllexport)
# else
# ifdef _DLL
# define AR_OSG_EXTERN __declspec(dllimport)
# else
# define AR_OSG_EXTERN extern
# endif
# endif
#else
# define AR_OSG_EXTERN
#endif
#ifdef __EMSCRIPTEN__
# include <emscripten/emscripten.h>
# define AR_OSG_EXTDEF EMSCRIPTEN_KEEPALIVE
#else
# define AR_OSG_EXTDEF
#endif
typedef struct _AROSG AROSG; // (Forward definition of opaque structure).
#ifdef __cplusplus
extern "C" {
#endif
/*!
@function
@abstract Get the version of ARToolKit with which the arOSG library was built.
@discussion
It is highly recommended that
any calling program that depends on features in a certain
ARToolKit version, check at runtime that it is linked to a version
of ARToolKit that can supply those features. It is NOT sufficient
to check the ARToolKit SDK header versions, since with ARToolKit implemented
in dynamically-loaded libraries, there is no guarantee that the
version of ARToolKit installed on the machine at run-time will be as
recent as the version of the ARToolKit SDK which the host
program was compiled against.
@result
Returns the full version number of the ARToolKit version corresponding
to this OSG library, in binary coded decimal (BCD) format.
BCD format allows simple tests of version number in the caller
e.g. if ((arGetVersion() >> 16) > 0x0272) printf("This release is later than 2.72\n");
The major version number is encoded in the most-significant byte
(bits 31-24), the minor version number in the second-most-significant
byte (bits 23-16), the tiny version number in the third-most-significant
byte (bits 15-8), and the build version number in the least-significant
byte (bits 7-0).
@availability Available in ARToolKit v4.4.2 and later.
*/
AR_OSG_EXTERN unsigned int arOSGGetVersion();
/*!
@function
@abstract Get the preferred OpenGL API of the underlying OSG build.
@result
Returns an enum indicating the preferred OpenGL API.
*/
AR_OSG_EXTERN ARG_API arOSGGetPreferredAPI();
/*!
@function
@abstract Create a settings structure for use with all other arOSG functions.
@discussion
All other arOSG functions require a reference to settings and global data.
Use this function to create and initialise such a structure.
@param maxModels An integer value specifying the maximum number of models
that may be loaded at any one time.
@result Pointer to the new AROSG settings structure.
*/
AR_OSG_EXTERN AROSG *arOSGInit(int maxModels);
/*!
@function
@abstract Dispose of an AROSG settings structure.
@discussion
If you have finished with an AROSG settings structure in your running program,
you can unload its internal data by calling arOSGFinal.
@param arOsg Pointer to the AROSG settings structure to be disposed of. (See arOSGInit().)
*/
AR_OSG_EXTERN void arOSGFinal(AROSG *arOsg);
/*!
@function
@abstract Load an OSG model using a "model description file".
@discussion -
The format of this file is a simple text file. Comments may be
included by prefixing the line with a "#" character.
The object definition consists of the following:
<ul>
<li> A line with the path to the object's data file, relative to the
objects file. (This path may include spaces.)
<li> A line with the position of the object's origin, relative to the
parent coordinate system's origin, expressed as 3 floating point
numbers separated by spaces, representing the offset in x, y, and z.
This is the same format used by the glTranslate() function.
<li> A line with the orientation of the object's coordinate system,
relative to the parent coordinate system, expressed as 4 floating
point numbers separated by spaces, representing an angle and an
axis of a rotation from the parent. This is the same format used
by the glRotate() function.
<li> A line with the scale factor to apply to the object, expressed
as 3 floating point numbers separated by spaces, representing the
scale factor to apply in x, y, and z.
This is the same format used by the glScale() function.
<li> Zero or more lines with optional tokens representing additional
information about the object. The following tokens are defined:
<ul>
<li> LIGHTING f: Enables or disables lighting calculations for this
object. Note that disabling lighting will result in the
object being drawn fully lit but without shading.
f = 0 to disable, f = 1 to enable. Default is enabled.
<li> TRANSPARENT: Provides a hint that this object includes transparent
portions, and should be drawn alpha-blended. Default is
that no transparency hint is provided.
<li> TEXTURES: Provides a hint that this object includes textured
portions, and should be drawn with texturing enabled. Default is
that no texturing hint is provided.
<li> SELECTABLE f: Enables or disables the ability for this model to
be selectable by hit-testing methods.
f = 0 to disable, f = 1 to enable. Default is enabled.
</ul>
</ul>
@param arOsg Pointer to the AROSG settings structure into which the model should be loaded. (See arOSGInit().)
@param modelDescriptionFilePath
A string holding the path to a "model description file". This file must contain a structured list of
the following data: the relative path to the actual OSG model to be loaded, the translation (in x,y,z axes)
to be applied to the model, the rotation (in angle/axis form, as degrees, angle of rotation x,y,z), and
the scale factor to be applied to the model (in the x,y,z axes). See the sample files included
in the ARToolKit distribution in the directory bin/OSG for examples.
@result An index value with which the loaded model can be referred to, in the range [0, maxModels - 1],
or, in case of error, a value less than 0.
*/
AR_OSG_EXTERN int arOSGLoadModel(AROSG *arOsg, const char *modelDescriptionFilePath);
/*!
@function
@abstract Load an OSG model.
@discussion -
@param arOsg Pointer to the AROSG settings structure into which the model should be loaded. (See arOSGInit().)
@param modelFilePath A string holding the path to a file readable by OSG (as a node, e.g. an .ive or .osg file).
@param translation The translation (in x,y,z axes) to be applied to the model, or NULL to apply no translation.
@param rotation The rotation (in angle/axis form, as degrees, angle of rotation x,y,z) to be applied to the model, or NULL to apply no rotation.
@param scale The scale factor to be applied to the model (in the x,y,z axes) or NULL to retain the scale at 1.0.
@param textures Provides a hint that the model uses textures. This is required when using programmable OpenGL pipelines (e.g. OpenGL ES 2.0+, or OpenGL 3.1+) with textured models.
@result An index value with which the loaded model can be referred to, in the range [0, maxModels - 1],
or, in case of error, a value less than 0.
@availability Available in ARToolKit v4.5.1 and later.
*/
AR_OSG_EXTERN int arOSGLoadModel2(AROSG *arOsg, const char *modelFilePath, const double translation[3], const double rotation[4], const double scale[3], const int textures);
/*!
@function
@abstract Unload an OSG model.
@discussion
Frees the memory associated with an OSG model.
@param arOsg Pointer to the AROSG settings structure from which the model should be unloaded. (See arOSGInit().)
@result 0, or in case of error, a value less than 0.
*/
AR_OSG_EXTERN int arOSGUnloadModel(AROSG *arOsg, const int index);
AR_OSG_EXTERN int arOSGCreateCubeModel(AROSG *arOsg);
/*!
@function
@abstract Create a model from a DEM (digital elevation model) file.
@discussion
Frees the memory associated with an OSG model.
@param arOsg Pointer to the AROSG settings structure from which the model should be loaded. (See arOSGInit().)
@param demFilePath A string holding the path to a file readable by OSG (as an image containing DEM height field data, e.g. .tiff or .geotiff).
@param scaleFactor The scale factor between the DEM file and the size to be displayed in-scene.
E.g. to create a model 2m per side from a 2000x2000 DEM with 25m-per-pixel resolution, each pixel must be 0.001m,
so supply the value 25000 for scale.
@param heightExaggerationFactor A factor by which to exaggerate the height, e.g. 10.0f.
@result An index value with which the loaded model can be referred to, in the range [0, maxModels - 1],
or, in case of error, a value less than 0.
*/
AR_OSG_EXTERN int arOSGCreateDEMModel(AROSG *arOsg, const char *demFilePath, const float scaleFactor, const float heightExaggerationFactor);
/*!
@function
@abstract Show or hide an OSG-based model.
@discussion
Models are visible by default.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model to adjust the visibility of. See arOSGLoadModel().
@param visible 0 to hide, or non-zero to show.
@result 0, or in case of error, a value less than 0.
*/
AR_OSG_EXTERN int arOSGSetModelVisibility(AROSG *arOsg, const int index, const int visible);
/*!
@function
@abstract Find out if an OSG-based model is shown or hidden.
@discussion
Models are visible by default.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model to request the visibility of. See arOSGLoadModel().
@param visible Pointer to a location, which on return will contain 0 if hidden, or 1 if shown.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v4.5.1 and later.
*/
AR_OSG_EXTERN int arOSGGetModelVisibility(AROSG *arOsg, const int index, int *visible);
/*!
@function
@abstract Set lighting for a model on or off.
@discussion
By default, lighting is enabled for models.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model to adjust the lighting of. See arOSGLoadModel().
@param lit 0 to disable lighting, or non-zero to enable.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v4.5.1 and later.
*/
AR_OSG_EXTERN int arOSGSetModelLighting(AROSG *arOsg, const int index, const int lit);
/*!
@function
@abstract Find out if lighting for model is on or off.
@discussion
By default, lighting is enabled for models.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model to request the lighting state of. See arOSGLoadModel().
@param lit Pointer to a location, which on return will contain 0 if lighting disable, or 1 if enabled.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v4.5.1 and later.
*/
AR_OSG_EXTERN int arOSGGetModelLighting(AROSG *arOsg, const int index, int *lit);
/*!
@function
@abstract Set transparency for a model on or off.
@discussion
By default, transparency for models depends on the state with which the model was created.
However, this setting allows overriding of the transparency settings. One example usage
would be to force an image texture containing an alpha channel to draw with transparency,
or alternately without.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model to adjust the transparency of. See arOSGLoadModel().
@param transparent 0 to disable transparency, or non-zero to enable.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v4.6. and later.
*/
AR_OSG_EXTERN int arOSGSetModelTransparency(AROSG *arOsg, const int index, const int transparent);
/*!
@function
@abstract For a model with animation, pause or resume the animation.
@discussion
Models with animations may have the animation paused and later resumed.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model of which the animation should be paused or resumed. See arOSGLoadModel().
@param pause 0 to resume the animation, 1 to pause it.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v4.6.7 and later.
*/
AR_OSG_EXTERN int arOSGSetModelAnimationPause(AROSG *arOsg, const int index, const int pause);
/*!
@function
@abstract For a model with animation, discover the animation time.
@discussion
You may query the animation time of models with animations.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model of which the animation time should be queried. See arOSGLoadModel().
@result 0, or in case of error, a value less than 0.
@param animationTime A pointer to a double, which will be filled with the animation time (should one be available), or 0 if no animation time is defined.
@availability Available in ARToolKit v4.6.7 and later.
*/
AR_OSG_EXTERN int arOSGGetModelAnimationTime(AROSG *arOsg, const int index, double *animationTime);
/*!
@function
@abstract For a model with animation, reset the animation.
@discussion
Models with animations may have the animation reset to the initial state.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model of which the animation should be reset. See arOSGLoadModel().
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v4.6.7 and later.
*/
AR_OSG_EXTERN int arOSGSetModelAnimationReset(AROSG *arOsg, const int index);
/*!
@function
@abstract For a model with animation, override the animation loop mode.
@discussion
Models with animations have a default mode set at time of creation. To
override the mode at runtime, use this function.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model of which the animation loop mode should be overridden. See arOSGLoadModel().
@param mode 0 to disable looping, 1 to enable looping (where at the end of the animation sequence, animation continues from the beginning again), or 2 to enable
swinging animation (where at the end of animation, animation proceeds in reverse
until the beginning is reached, at which point animation proceeds forward again,
ad infinitum.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v4.6.7 and later.
*/
AR_OSG_EXTERN int arOSGSetModelAnimationLoopModeOverride(AROSG *arOsg, const int index, const int mode);
/*!
@function
@abstract Set the projection matrix used in OSG drawing.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param p A 4x4 OpenGL transform matrix (column-major order) representing the projection transform.
@result 0, or in case of error, a value less than 0.
*/
AR_OSG_EXTERN int arOSGSetProjection(AROSG *arOsg, double p[16]);
/*!
@function
@abstract Set the projection matrix used in OSG drawing.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param p A 4x4 OpenGL transform matrix (column-major order) representing the projection transform.
@result 0, or in case of error, a value less than 0.
*/
AR_OSG_EXTERN int arOSGSetProjectionf(AROSG *arOsg, float p[16]);
/*!
@function
@abstract Get the projection matrix used in OSG drawing.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param p A 4x4 OpenGL transform matrix (column-major order) representing the projection transform.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v4.5.1 and later.
*/
AR_OSG_EXTERN int arOSGGetProjection(AROSG *arOsg, double *p);
/*!
@function
@abstract Get the projection matrix used in OSG drawing.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param p A 4x4 OpenGL transform matrix (column-major order) representing the projection transform.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v4.5.1 and later.
*/
AR_OSG_EXTERN int arOSGGetProjectionf(AROSG *arOsg, float *p);
/*!
@function
@abstract Set the view matrix used in OSG drawing.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param v A 4x4 OpenGL transform matrix (column-major order) representing the viewing transform.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v5.4 and later.
*/
AR_OSG_EXTERN int arOSGSetView(AROSG *arOsg, double v[16]);
/*!
@function
@abstract Set the view matrix used in OSG drawing.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param v A 4x4 OpenGL transform matrix (column-major order) representing the viewing transform.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v5.4 and later.
*/
AR_OSG_EXTERN int arOSGSetViewf(AROSG *arOsg, float v[16]);
/*!
@function
@abstract Get the view matrix used in OSG drawing.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param v A 4x4 OpenGL transform matrix (column-major order) representing the view transform.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v5.4 and later.
*/
AR_OSG_EXTERN int arOSGGetView(AROSG *arOsg, double *v);
/*!
@function
@abstract Get the view matrix used in OSG drawing.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param v A 4x4 OpenGL transform matrix (column-major order) representing the view transform.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v5.4 and later.
*/
AR_OSG_EXTERN int arOSGGetViewf(AROSG *arOsg, float *v);
/*!
@function
@abstract Set the polygon winding for front-facing polygons.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param winding 0 to set counter-clockwise (the default), or 1 to set clockwise.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v5.0 and later.
*/
AR_OSG_EXTERN int arOSGSetFrontFace(AROSG *arOsg, int winding);
/*!
@function
@abstract Get the polygon winding for front-facing polygons.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param winding Pointer to a location, which on return will be 0 if counter-clockwise (the default), or 1 if clockwise.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v5.0 and later.
*/
AR_OSG_EXTERN int arOSGGetFrontFace(AROSG *arOsg, int *winding);
/*!
@function
@abstract Set the pose (position and orientation) of an OSG-based model.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model to adjust the pose of. See arOSGLoadModel().
@param modelview A 4x4 OpenGL transform matrix (column-major order) representing the modelview transform of the model.
@result 0, or in case of error, a value less than 0.
*/
AR_OSG_EXTERN int arOSGSetModelPose(AROSG *arOsg, const int index, const double modelview[16]);
/*!
@function
@abstract Set the pose (position and orientation) of an OSG-based model.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model to adjust the pose of. See arOSGLoadModel().
@param modelview A 4x4 OpenGL transform matrix (column-major order) representing the modelview transform of the model.
@result 0, or in case of error, a value less than 0.
*/
AR_OSG_EXTERN int arOSGSetModelPosef(AROSG *arOsg, const int index, const float modelview[16]);
/*!
@function
@abstract Get the pose (position and orientation) of an OSG-based model.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model to retrieve the pose of. See arOSGLoadModel().
@param modelview A 4x4 OpenGL transform matrix (column-major order) representing the modelview transform of the model.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v4.5.1 and later.
*/
AR_OSG_EXTERN int arOSGGetModelPose(AROSG *arOsg, const int index, double *modelview);
/*!
@function
@abstract Get the pose (position and orientation) of an OSG-based model.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model to retrieve the pose of. See arOSGLoadModel().
@param modelview A 4x4 OpenGL transform matrix (column-major order) representing the modelview transform of the model.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v4.5.1 and later.
*/
AR_OSG_EXTERN int arOSGGetModelPosef(AROSG *arOsg, const int index, float *modelview);
/*!
@function
@abstract Set the local pose (position and orientation) of an OSG-based model.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model to adjust the pose of. See arOSGLoadModel().
@param model A 4x4 OpenGL transform matrix (column-major order) representing the local transform of the model.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v4.5.5 and later.
*/
AR_OSG_EXTERN int arOSGSetModelLocalPose(AROSG *arOsg, const int index, const double model[16]);
/*!
@function
@abstract Set the local pose (position and orientation) of an OSG-based model.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model to adjust the pose of. See arOSGLoadModel().
@param model A 4x4 OpenGL transform matrix (column-major order) representing the local transform of the model.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v4.5.5 and later.
*/
AR_OSG_EXTERN int arOSGSetModelLocalPosef(AROSG *arOsg, const int index, const float model[16]);
/*!
@function
@abstract Get the local pose (position and orientation) of an OSG-based model.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model to retrieve the pose of. See arOSGLoadModel().
@param model A 4x4 OpenGL transform matrix (column-major order) representing the local transform of the model.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v4.5.5 and later.
*/
AR_OSG_EXTERN int arOSGGetModelLocalPose(AROSG *arOsg, const int index, double *model);
/*!
@function
@abstract Get the local pose (position and orientation) of an OSG-based model.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model to retrieve the pose of. See arOSGLoadModel().
@param model A 4x4 OpenGL transform matrix (column-major order) representing the local transform of the model.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v4.5.5 and later.
*/
AR_OSG_EXTERN int arOSGGetModelLocalPosef(AROSG *arOsg, const int index, float *model);
/*!
@function
@abstract Turn on or off 2D outlining of a model's boundary.
@discussion
Outlining allows a model to be highlighted by drawing a 2D outline of the models extreme boundary.
Outlining is not currently supported by OSG on platforms using OpenGL ES, and calling this function
will produce erroneous visual results if used on an OpenGL ES platform.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model to retrieve the pose of. See arOSGLoadModel().
@param width The width, in pixels, of the outline to place around the model. To disable outlining, pass 0.
Outlining is initially disabled.
@param rgba The colour of the outline, as an array of unsigned bytes in order red, green, blue, alpha.
An opaque outline can be generated by passing 255 for the alpha value. Values less than 255 will result in a transparent outline.
To use the default colour, just pass NULL.
@result 0, or in case of error, a value less than 0.
@availability Available in ARToolKit v4.6.3 and later.
*/
AR_OSG_EXTERN int arOSGSetModelOutline(AROSG *arOsg, const int index, const int width, const unsigned char rgba[4]);
/*!
@function
@abstract Determine if a model is intersected by a line segment.
@discussion
This calculates the intersection between a line segment (defined by two points in world coordinates)
and a model (actually an OSG node and subnodes). If an intersection is found, different data types
can be returned by providing pointers in parameters nodeType, nodeName, and intersectionCoords.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model to calculate the intersection of. See arOSGLoadModel().
@param p1 Required; a vector specifying the location of one end of the line segment, in world coordinates.
@param p2 Required; a vector specifying the location of the other end of the line segment, in world coordinates.
@result 1 if an intersection was found, 0 if no intersection was found, or in case of error, a value less than 0.
@availability Available in ARToolKit v4.5.1 and later.
*/
AR_OSG_EXTERN int arOSGGetModelIntersectionf(AROSG *arOsg, const int index, const float p1[3], const float p2[3]);
/*!
@constant
@abstract Variable to supply to arOSGSetDrawTime to direct OpenSceneGraph to use its internal reference time.
@discussion
OSG maintains its own internal reference time for animation and simulation
rendering. If you wish to render using OSG's reference time, supply this
value to arOSGSetDrawTime.
@seealso arOSGSetDrawTime arOSGSetDrawTime
*/
extern const double AR_OSG_TIME_USE_REFERENCE_TIME;
/*!
@function
@abstract Process scenegraph-related events, including drawing all visible models.
@discussion
OSG maintains its own internal reference time for animation and simulation
rendering. If you wish to render at particular time instants or at non-unit
timescales, you can manipulate the timeline for following arOSGDraw calls by
calling this function with the time (in decimal seconds) supplied in the
parameter. To revert to OSG's internal reference time, pass the value
AR_OSG_TIME_USE_REFERENCE_TIME.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param time Decimal seconds value at which to render the next arOSGDraw call.
@result 0, or in case of error, a value less than 0.
@seealso AR_OSG_TIME_USE_REFERENCE_TIME AR_OSG_TIME_USE_REFERENCE_TIME
@seealso arOSGDraw arOSGDraw
*/
AR_OSG_EXTERN int arOSGSetDrawTime(AROSG *arOsg, double time);
/*!
@function
@abstract Process scenegraph-related events, including drawing all visible models.
@discussion
This function leaves the values of the OpenGL machine in an indeterminate state, including
clobbering the OpenGL viewport, projection and modelview matrices. The user
should save any sensitive state prior to calling this function, and restore that state upon return.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@result 0, or in case of error, a value less than 0.
*/
AR_OSG_EXTERN int arOSGDraw(AROSG *arOsg);
/*!
@function
@abstract Inform OpenSceneGraph that a window reshape has occured (i.e. changes to window size have occured).
@discussion
This function should be called when the window is first created, and then
whenever the operating system generates a notification
that the user has changed the window size.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param w The new window width, in pixels.
@param h The new window height, in pixels.
*/
AR_OSG_EXTERN void arOSGHandleReshape(AROSG *arOsg, const int w, const int h);
/*!
@function
@abstract Inform OpenSceneGraph that a window reshape has occured (i.e. changes to window size have occured).
@discussion
This function should be called when the window is first created, and then
whenever the operating system generates a notification
that the user has changed the window size.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param left The new viewport origin left coordinate, in pixels.
@param bottom The new viewport origin bottom coordinate, in pixels.
@param width The new viewport width, in pixels.
@param height The new viewport height, in pixels.
*/
AR_OSG_EXTERN void arOSGHandleReshape2(AROSG *arOsg, const int left, const int bottom, const int width, const int height);
/*!
@function
@abstract Pass mouse clicks to OpenSceneGraph.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param button The values 0, 1 or 2 for the left, middle and right mouse buttons, respectively.
(For the convenience of users using GLUT, these values match the values of GLUT_LEFT_BUTTON,
GLUT_MIDDLE_BUTTON and GLUT_RIGHT_BUTTON.)
@param state 0 for a mouse-button-down event, and 1 for a mouse-button-up (button released) event.
@param x The mouse x location in window relative coordinates when the mouse button was pressed.
@param y The mouse y location in window relative coordinates.
*/
AR_OSG_EXTERN void arOSGHandleMouseDownUp(AROSG *arOsg, const int button, const int state, const int x, const int y);
/*!
@function
@abstract Pass mouse motion events to OpenSceneGraph
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param x The mouse x location in window relative coordinates.
@param y The mouse y location in window relative coordinates.
*/
AR_OSG_EXTERN void arOSGHandleMouseMove(AROSG *arOsg, int x, int y);
/*!
@function
@abstract Pass key press events to OpenSceneGraph.
@discussion -
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param key Key code. The handling of this is OSG-depdendent, but ASCII key codes (0x00 to 0x7f) at least
can be passed in directly. For the appropriate key code to use for
other keys, see the values defined in OpenSceneGraph. The values are listed in the OSG header file
<osgGA/GUIEventAdapter> under the enum "KeyCode".
@param x The mouse x location in window relative coordinates when the key was pressed -- presently ignored.
@param y The mouse y location in window relative coordinates when the key was pressed -- presently ignored.
*/
AR_OSG_EXTERN void arOSGHandleKeyboard(AROSG *arOsg, int key, int x, int y);
/*!
@function
@abstract Enable or disable ray selection on a model.
@discussion When using the provided ray selection model, this function can
be used to disable or re-enable selectability of an object. Objects which
are marked as not selectable will not be considered when determining the
ray path.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model of which to set the selectability.
@param selectable 0 to make the object un-selectable, 1 to make it selectable.
*/
AR_OSG_EXTERN void arOSGSetModelSelectable(AROSG *arOsg, const int index, const int selectable);
/*!
@function
@abstract Query whether ray selection on a model is enabled or disabled.
@discussion When using the provided ray selection model, this function can
be used to determine the selectability of an object.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param index The index of the model of which to query the selectability.
@result 0 if the object is un-selectable, 1 if it is selectable.
*/
AR_OSG_EXTERN int arOSGGetModelSelectable(AROSG *arOsg, const int index);
#define AR_OSG_RAYS_MAX 2
/*!
@function
@abstract Enables a ray for ray-based selection and test for object hits.
@discussion This function allows for a laser-pointer-like "ray" to be shown
in the scene and used by the user to select objects.
After this call, the position (in world coordinates) of the first (if any)
object struck by the ray will be queryable via calling arOSGGetRayHit.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param ray The index of the ray (in the range [0, AR_OSG_RAYS_MAX - 1]
to enable and test for object hits.
@param pose Sets the position and orientation of the proximal end of the
ray, as a 4x4 column-major transform. If the identity matrix is passed,
the ray will begin at the origin and point in the direction of the -z axis.
*/
AR_OSG_EXTERN void arOSGShowRayAndSetPose(AROSG *arOsg, int ray, float pose[16]);
/*!
@function
@abstract Disable a ray for ray-based selection and test for object hits.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param ray The index of the ray (in the range [0, AR_OSG_RAYS_MAX - 1]
to disable for object hits.
*/
AR_OSG_EXTERN void arOSGHideRay(AROSG *arOsg, int ray);
/*!
@function
@abstract Enables a ray for ray-based selection and test for object hits.
@discussion This function allows for a laser-pointer-like "ray" to be shown
in the scene and used by the user to select objects.
After this call, the position (in world coordinates) of the first (if any)
object struck by the ray will be queryable via calling arOSGGetRayHit.
@param arOsg Pointer to the AROSG settings structure. (See arOSGInit().)
@param ray The index of the ray (in the range [0, AR_OSG_RAYS_MAX - 1]
for which to return object hits.
@param pos The position in world coordinates of the point where the ray
hit the object, or NULL if this value is not required.
@param norm The normal vector in world coordinates of the surface at the
point where the ray hit the object, or NULL if this value is not required.
@param modelIndexPtr A pointer to an integer which will be set to the
index of the loaded model which was hit, nor NULL if this value is not required.
@result 0 if the ray is did not hit an object, 1 if it hit an object.
*/
AR_OSG_EXTERN int arOSGGetRayHit(AROSG *arOsg, int ray, float pos[3], float norm[3], int *modelIndexPtr);
AR_OSG_EXTERN int arOSGSetModelLabel(AROSG *arOsg, const int index, const char *labelText);
#ifdef __cplusplus
}
#endif
#endif // !AR_OSG_H