/usr/include/teem/limn.h is in libteem-dev 1.12.0~20160122-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 | /*
Teem: Tools to process and visualize scientific data and images .
Copyright (C) 2013, 2012, 2011, 2010, 2009 University of Chicago
Copyright (C) 2008, 2007, 2006, 2005 Gordon Kindlmann
Copyright (C) 2004, 2003, 2002, 2001, 2000, 1999, 1998 University of Utah
Copyright (C) 2012, 2011, 2010 Thomas Schultz
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public License
(LGPL) as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
The terms of redistributing and/or modifying this software also
include exceptions to the LGPL that facilitate static linking.
This library 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 this library; if not, write to Free Software Foundation, Inc.,
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef LIMN_HAS_BEEN_INCLUDED
#define LIMN_HAS_BEEN_INCLUDED
#include <stdlib.h>
#include <math.h>
#include <teem/air.h>
#include <teem/biff.h>
#include <teem/hest.h>
#include <teem/ell.h>
#include <teem/nrrd.h>
#include <teem/gage.h>
#include <teem/unrrdu.h>
#if defined(_WIN32) && !defined(__CYGWIN__) && !defined(TEEM_STATIC)
# if defined(TEEM_BUILD) || defined(limn_EXPORTS) || defined(teem_EXPORTS)
# define LIMN_EXPORT extern __declspec(dllexport)
# else
# define LIMN_EXPORT extern __declspec(dllimport)
# endif
#else /* TEEM_STATIC || UNIX */
# define LIMN_EXPORT extern
#endif
#ifdef __cplusplus
extern "C" {
#endif
#define LIMN limnBiffKey
#define LIMN_LIGHT_NUM 8
/*
******** #define LIMN_SPLINE_Q_AVG_EPS
**
** The convergence tolerance used for Buss/Fillmore quaternion
** averaging
*/
#define LIMN_SPLINE_Q_AVG_EPS 0.00001
/*
****** limnCamera struct
**
** for all standard graphics camera parameters. Image plane is
** spanned by U and V; N always points away from the viewer, U
** always points to the right, V can point up or down, if the
** camera is left- or right-handed, respectively.
**
** Has no dynamically allocated information or pointers.
*/
typedef struct limnCamera_t {
double from[3], /* location of eyepoint */
at[3], /* what eye is looking at */
up[3], /* what is up direction for eye (this is not updated
to the "true" up) */
uRange[2], /* range of U values to put on horiz. image axis */
vRange[2], /* range of V values to put on vert. image axis */
fov, /* if non-NaN, and aspect is non-NaN, then {u,v}Range
will be set accordingly by limnCameraUpdate().
"fov" is the angle, in degrees, vertically subtended
by the view window */
aspect, /* the ratio of horizontal to vertical size of the
view window */
neer, faar, /* near and far clipping plane distances
(misspelled for the sake of a McRosopht compiler) */
dist; /* distance to image plane */
int atRelative, /* if non-zero: given neer, faar, and dist
quantities indicate distance relative to the
_at_ point, instead of the usual (in computer
graphics) sense if being relative to the
eye point */
orthographic, /* no perspective projection: just orthographic */
rightHanded; /* if rightHanded, V = NxU (V points "downwards"),
otherwise, V = UxN (V points "upwards") */
/* --------------------------------------------------------------------
End of user-set parameters. Things below are set by limnCameraUpdate
-------------------------------------------------------------------- */
double W2V[16], /* World to view transform. The _rows_ of this
matrix (its 3x3 submatrix) are the U, V, N
vectors which form the view-space coordinate frame.
The column-major ordering of elements in the
matrix is from ell:
0 4 8 12
1 5 9 13
2 6 10 14
3 7 11 15 */
V2W[16], /* View to world transform */
U[4], V[4], N[4], /* View space basis vectors (in world coords)
last element always zero */
vspNeer, vspFaar, /* not usually user-set: near, far, and image plane
distances, in view space */
vspDist;
} limnCamera;
/*
******** struct limnLight
**
** information for directional lighting and the ambient light. All
** the vectors are length 4 (instead of 3) for the sake of passing them
** directly to OpenGL. For colors, the last coefficient (alpha) is
** always 1.0, and for directions it is 0.0 (w, homog coord).
**
**
** Has no dynamically allocated information or pointers
*/
typedef struct {
float amb[4], /* RGBA ambient light color */
_dir[LIMN_LIGHT_NUM][4], /* direction of light[i] (view or world space).
This is what the user sets via limnLightSet */
dir[LIMN_LIGHT_NUM][4], /* direction of light[i] (ONLY world space)
Not user-set: calculated/copied from _dir[] */
col[LIMN_LIGHT_NUM][4]; /* RGBA color of light[i] */
int on[LIMN_LIGHT_NUM], /* light[i] is on */
vsp[LIMN_LIGHT_NUM]; /* light[i] lives in view space */
} limnLight;
enum {
limnDeviceUnknown,
limnDevicePS,
limnDeviceGL,
limnDeviceLast
};
enum {
limnEdgeTypeUnknown, /* 0 */
limnEdgeTypeBackFacet, /* 1: back-facing non-crease */
limnEdgeTypeBackCrease, /* 2: back-facing crease */
limnEdgeTypeContour, /* 3: silhoette edge */
limnEdgeTypeFrontCrease, /* 4: front-facing crease */
limnEdgeTypeFrontFacet, /* 5: front-facing non-crease */
limnEdgeTypeBorder, /* 6: attached to only one face */
limnEdgeTypeLone, /* 7: attached to no faces */
limnEdgeTypeLast
};
#define LIMN_EDGE_TYPE_MAX 7
typedef struct {
float lineWidth[LIMN_EDGE_TYPE_MAX+1],
creaseAngle, /* difference between crease and facet, in *degrees* */
bg[3], /* background color */
edgeColor[3]; /* edge color */
int showpage, /* finish with "showpage" */
wireFrame, /* just render wire-frame */
noBackground; /* refrain from initially filling with bg[] color */
} limnOptsPS;
typedef struct {
limnOptsPS ps;
int device;
float scale,
bbox[4]; /* minX minY maxX maxY */
int yFlip;
FILE *file;
} limnWindow;
enum {
limnSpaceUnknown, /* 0 */
limnSpaceWorld, /* 1 */
limnSpaceView, /* 2 */
limnSpaceScreen, /* 3 */
limnSpaceDevice, /* 4 */
limnSpaceLast
};
#define LIMN_SPACE_MAX 4
/*
******** limnPrimitive* enum
**
** primitive types in the limnPolyData (should probably called
** limnPolyDataPrimitiveType).
**
** keep in sync: Deft/src/PolyData.cxx/PolyData::drawImmediate()
*/
enum {
limnPrimitiveUnknown, /* 0 */
limnPrimitiveNoop, /* 1: no-op primitive, nothing drawn */
limnPrimitiveTriangles, /* 2: triangle soup (for GL_TRIANGLES) */
limnPrimitiveTriangleStrip, /* 3: triangle strip (for GL_TRIANGLE_STRIP) */
limnPrimitiveTriangleFan, /* 4: triangle fan (for GL_TRIANGLE_FAN) */
limnPrimitiveQuads, /* 5: quad soup (for GL_QUADS) */
limnPrimitiveLineStrip, /* 6: line strip (for GL_LINE_STRIP) */
limnPrimitiveLines, /* 7: line soup (for GL_LINES) */
limnPrimitiveLast
};
#define LIMN_PRIMITIVE_MAX 7
/*
******** struct limnLook
**
** surface properties: pretty much anything having to do with
** appearance, for points, edges, faces, etc.
*/
typedef struct {
float rgba[4];
float kads[3], /* phong: ka, kd, ks */
spow; /* specular power */
} limnLook;
/*
******** struct limnVertex
**
** all the information you might want for a point.
**
** This used to have separate coordinate arrays for view, screen, and
** device space, but these have been collapsed (in the interest of space)
** into coord, with obj->vertSpace indicating which space these are in.
** This also used to have a lookIdx (now just rgba[4]), and a partIdx
** (which was never actually used).
**
** Has no dynamically allocated information or pointers
*/
typedef struct {
float world[4], /* world coordinates (homogeneous) */
rgba[4], /* RGBA color */
coord[4], /* coordinates in some space */
worldNormal[3]; /* vertex normal (world coords only) */
} limnVertex;
/*
******** struct limnEdge
**
** all the information about an edge
**
** Has no dynamically allocated information or pointers
*/
typedef struct limnEdge_t {
unsigned int vertIdx[2], /* indices into object's master vert array */
lookIdx, /* index into parent's look array */
partIdx; /* which part do we belong to */
int type, /* from the limnEdgeType enum */
faceIdx[2], /* indices into object's master face array */
once; /* flag used for certain kinds of rendering */
} limnEdge;
/*
******** struct limnFace
**
** all the information about a face
*/
typedef struct limnFace_t {
float worldNormal[3],
screenNormal[3];
unsigned int *vertIdx, /* regular array (*not* airArray) of vertex
indices in object's master vert array */
*edgeIdx, /* likewise for edges */
sideNum, /* number of sides (allocated length of
{vert,edge}Idx arrays */
lookIdx,
partIdx;
int visible; /* non-zero if face currently visible */
float depth;
} limnFace;
/*
******** struct limnPart
**
** one connected part of an object
*/
typedef struct limnPart_t {
/* (air)arrays of indices in object's vert array */
unsigned int *vertIdx, vertIdxNum;
airArray *vertIdxArr;
/* (air)arrays of indices in object's edge array */
unsigned int *edgeIdx, edgeIdxNum;
airArray *edgeIdxArr;
/* (air)arrays of indices in object's face array */
unsigned int *faceIdx, faceIdxNum;
airArray *faceIdxArr;
int lookIdx;
float depth;
} limnPart;
/*
******** struct limnObject
**
** the beast used to represent polygonal objects
**
** Relies on many dynamically allocated arrays
**
** learned: I used to have an array of limnParts inside here, and that
** array was managed by an airArray. Inside the limnPart, are more
** airArrays, for example the faceIdxArr which internally stores the
** *address* of faceIdx. When the array of limnParts is resized, the
** limnPart's faceIdx pointer is still valid, and faceIdxArr is still
** valid, but the faceIdxArr's internal pointer to the faceIdx pointer
** is now bogus. Thus: the weakness of airArrays (as long as they
** aren't giving the data pointer anew for EACH ACCESS), is that you
** must not confuse the airArrays by changing the address of its user
** data pointer. Putting user data pointers inside of a bigger
** airArray is a fine way to create such confusion.
*/
typedef struct {
limnVertex *vert; unsigned int vertNum;
airArray *vertArr;
limnEdge *edge; unsigned int edgeNum;
airArray *edgeArr;
limnFace *face; unsigned int faceNum;
airArray *faceArr;
limnFace **faceSort; /* pointers into "face", sorted by depth */
limnPart **part; unsigned int partNum; /* double indirection, see above */
airArray *partArr;
limnPart **partPool; unsigned int partPoolNum;
airArray *partPoolArr;
limnLook *look; unsigned int lookNum;
airArray *lookArr;
int vertSpace, /* which space limnVertex->coord is in */
setVertexRGBAFromLook, /* when possible, copy vertex RGB values
from limnLook of part (not face) */
doEdges; /* if non-zero, build edges as faces are added */
unsigned incr; /* increment to use with airArrays */
} limnObject;
/*
******** struct limnVrt
**
** a very abbreviated limnVertex
**
** this was killed Sun Feb 5 16:50:23 EST 2006 with the re-organization of
** limnPolyData to have per-attribute arrays
**
typedef struct {
float xyzw[4], / * homogeneous coordinates * /
norm[3]; / * normal * /
unsigned char rgba[4]; / * RGBA color * /
} limnVrt;
*/
/*
******** limnPolyDataInfo* enum
**
** information that may be known per-vertex in limnPolyData
**
** NOTE: The xyzw position data is always required, and that is always
** allocated and present. This is the optional extra per-vertex information.
*/
enum {
limnPolyDataInfoUnknown, /* 0: nobody knows */
limnPolyDataInfoRGBA, /* 1: RGBA 4-tuple */
limnPolyDataInfoNorm, /* 2: (x,y,z) unit-length 3-vector */
limnPolyDataInfoTex2, /* 3: (s,t) 2D texture coordinates */
limnPolyDataInfoTang, /* 4: unit-length surface tangent 3-vector */
limnPolyDataInfoLast
};
#define LIMN_POLY_DATA_INFO_MAX 4
/*
******** limnPolyData
**
** A simpler beast for representing polygonal surfaces and other things
**
** There is no notion of "part" here; there may be multiple
** disconnected pieces inside the surface, but there is no way of
** accessing just one such piece (because this is organized in terms
** of primitives, and each piece may be made of multiple primitives).
** Having separate parts is important for PostScript rendering, but
** the limnPolyData is more OpenGL oriented.
**
** Experimenting with *not* having airArrays here . . .
**
** There need to be per-attribute "xxxNum" variables because otherwise
** it is impossible to unambiguously manage both changes in the number
** of vertices, and changes in the set of attributes required.
**
** The idea is that at some point general gage info could be stored
** per-vertex here, until that happens there is probably not going
** to be explicit dependence of limn on gage (now that limnFeature
** stuff moved to the "seek" library)
*/
typedef struct {
float *xyzw; /* (always allocated) xyzwNum position 4-tuples */
unsigned int xyzwNum; /* logical size of xyzw */
unsigned char *rgba; /* if non-NULL, rgbaNum RGBA color 4-tuples */
unsigned int rgbaNum; /* logical size of rgba */
float *norm; /* if non-NULL, normNum (x,y,z) unit normals */
unsigned int normNum; /* logical size of norm */
float *tex2; /* if non-NULL, tex2Num (s,t) 2D texture coords */
unsigned int tex2Num; /* logical size of tex2 */
float *tang; /* if non-NULL, tangNum unit surface tangents */
unsigned int tangNum; /* logical size of tang */
unsigned int indxNum; /* there are indxNum vertex indices in indx[] */
unsigned int *indx; /* all indices (into above arrays) for all primitives,
concatenated together into one array */
unsigned int primNum; /* there are primNum primitives (e.g. tristrips) */
unsigned char *type; /* prim ii is a type[ii] (limnPrimitive* enum) */
unsigned int *icnt; /* prim ii has icnt[ii] vertex indices */
} limnPolyData;
/*
******** limnQN enum
**
** the different quantized normal schemes currently supported
*/
enum {
limnQNUnknown, /* 0 */
limnQN16simple, /* 1 */
limnQN16border1, /* 2 */
limnQN16checker, /* 3 */
limnQN16octa, /* 4 */
limnQN15octa, /* 5 */
limnQN14checker, /* 6 */
limnQN14octa, /* 7 */
limnQN13octa, /* 8 */
limnQN12checker, /* 9 */
limnQN12octa, /* 10 */
limnQN11octa, /* 11 */
limnQN10checker, /* 12 */
limnQN10octa, /* 13 */
limnQN9octa, /* 14 */
limnQN8checker, /* 15 */
limnQN8octa, /* 16 */
limnQNLast
};
#define LIMN_QN_MAX 16
enum {
limnSplineTypeUnknown, /* 0 */
limnSplineTypeLinear, /* 1 */
limnSplineTypeTimeWarp, /* 2 */
limnSplineTypeHermite, /* 3 */
limnSplineTypeCubicBezier, /* 4 */
limnSplineTypeBC, /* 5 */
limnSplineTypeLast
};
#define LIMN_SPLINE_TYPE_MAX 5
enum {
limnSplineInfoUnknown, /* 0 */
limnSplineInfoScalar, /* 1 */
limnSplineInfo2Vector, /* 2 */
limnSplineInfo3Vector, /* 3 */
limnSplineInfoNormal, /* 4 */
limnSplineInfo4Vector, /* 5 */
limnSplineInfoQuaternion, /* 6 */
limnSplineInfoLast
};
#define LIMN_SPLINE_INFO_MAX 6
enum {
limnCameraPathTrackUnknown, /* 0 */
limnCameraPathTrackFrom, /* 1: 3-D spline for *from* points, quaternion
spline for camera directions towards at */
limnCameraPathTrackAt, /* 2: 3-D spline for *at* points, quaternion
spline for directions back to camera */
limnCameraPathTrackBoth, /* 3: three 3-D splines: for from point, at
point, and the up vector */
limnCameraPathTrackLast
};
#define LIMN_CAMERA_PATH_TRACK_MAX 3
/*
******** limnSpline
**
** the ncpt nrrd stores control point information in a 3-D nrrd, with
** sizes C by 3 by N, where C is the number of values needed for each
** point (3 for 3Vecs, 1 for scalars), and N is the number of control
** points. The 3 things per control point are 0) the pre-point info
** (either inward tangent or an internal control point), 1) the control
** point itself, 2) the post-point info (e.g., outward tangent).
**
** NOTE: for the sake of simplicity, the ncpt nrrd is always "owned"
** by the limnSpline, that is, it is COPIED from the one given in
** limnSplineNew() (and is converted to type double along the way),
** and it will is deleted with limnSplineNix.
*/
typedef struct limnSpline_t {
int type, /* from limnSplineType* enum */
info, /* from limnSplineInfo* enum */
loop; /* the last (implicit) control point is the first */
double B, C; /* B,C values for BC-splines */
Nrrd *ncpt; /* the control point info, ALWAYS a 3-D nrrd */
double *time; /* ascending times for non-uniform control points.
Currently, only used for limnSplineTypeTimeWarp */
} limnSpline;
typedef struct limnSplineTypeSpec_t {
int type; /* from limnSplineType* enum */
double B, C; /* B,C values for BC-splines */
} limnSplineTypeSpec;
/* defaultsLimn.c */
LIMN_EXPORT const int limnPresent;
LIMN_EXPORT const char *limnBiffKey;
LIMN_EXPORT int limnDefCameraAtRelative;
LIMN_EXPORT int limnDefCameraOrthographic;
LIMN_EXPORT int limnDefCameraRightHanded;
/* enumsLimn.c */
LIMN_EXPORT const airEnum *const limnSpace;
LIMN_EXPORT const airEnum *const limnPolyDataInfo;
LIMN_EXPORT const airEnum *const limnCameraPathTrack;
LIMN_EXPORT const airEnum *const limnPrimitive;
/* qn.c */
LIMN_EXPORT unsigned int limnQNBins[LIMN_QN_MAX+1];
LIMN_EXPORT void (*limnQNtoV_f[LIMN_QN_MAX+1])(float *vec, unsigned int qn);
LIMN_EXPORT void (*limnQNtoV_d[LIMN_QN_MAX+1])(double *vec, unsigned int qn);
LIMN_EXPORT unsigned int (*limnVtoQN_f[LIMN_QN_MAX+1])(const float *vec);
LIMN_EXPORT unsigned int (*limnVtoQN_d[LIMN_QN_MAX+1])(const double *vec);
LIMN_EXPORT int limnQNDemo(Nrrd *nqn, unsigned int reso, int qni);
/* light.c */
LIMN_EXPORT void limnLightSet(limnLight *lit, int which, int vsp,
float r, float g, float b,
float x, float y, float z);
LIMN_EXPORT void limnLightAmbientSet(limnLight *lit,
float r, float g, float b);
LIMN_EXPORT void limnLightSwitch(limnLight *lit, int which, int on);
LIMN_EXPORT void limnLightReset(limnLight *lit);
LIMN_EXPORT int limnLightUpdate(limnLight *lit, limnCamera *cam);
/* envmap.c */
typedef void (*limnEnvMapCB)(float rgb[3], float vec[3], void *data);
LIMN_EXPORT int limnEnvMapFill(Nrrd *envMap, limnEnvMapCB cb,
int qnMethod, void *data);
LIMN_EXPORT void limnLightDiffuseCB(float rgb[3], float vec[3], void *_lit);
LIMN_EXPORT int limnEnvMapCheck(Nrrd *envMap);
/* methodsLimn.c */
LIMN_EXPORT limnLight *limnLightNew(void);
LIMN_EXPORT void limnCameraInit(limnCamera *cam);
LIMN_EXPORT limnLight *limnLightNix(limnLight *);
LIMN_EXPORT limnCamera *limnCameraNew(void);
LIMN_EXPORT limnCamera *limnCameraNix(limnCamera *cam);
LIMN_EXPORT limnWindow *limnWindowNew(int device);
LIMN_EXPORT limnWindow *limnWindowNix(limnWindow *win);
/* hestLimn.c */
LIMN_EXPORT void limnHestCameraOptAdd(hestOpt **hoptP, limnCamera *cam,
const char *frDef, const char *atDef,
const char *upDef, const char *dnDef,
const char *diDef, const char *dfDef,
const char *urDef, const char *vrDef,
const char *fvDef);
/* cam.c */
LIMN_EXPORT int limnCameraAspectSet(limnCamera *cam,
unsigned int horz, unsigned int vert,
int centering);
LIMN_EXPORT int limnCameraUpdate(limnCamera *cam);
LIMN_EXPORT int limnCameraPathMake(limnCamera *cam, int numFrames,
limnCamera *keycam, double *time,
int numKeys, int trackFrom,
limnSplineTypeSpec *quatType,
limnSplineTypeSpec *posType,
limnSplineTypeSpec *distType,
limnSplineTypeSpec *viewType);
/* obj.c */
LIMN_EXPORT int limnObjectLookAdd(limnObject *obj);
LIMN_EXPORT limnObject *limnObjectNew(int incr, int doEdges);
LIMN_EXPORT limnObject *limnObjectNix(limnObject *obj);
LIMN_EXPORT void limnObjectEmpty(limnObject *obj);
LIMN_EXPORT int limnObjectPreSet(limnObject *obj,
unsigned int partNum,
unsigned int lookNum,
unsigned int vertPerPart,
unsigned int edgePerPart,
unsigned int facePerPart);
LIMN_EXPORT int limnObjectPartAdd(limnObject *obj);
LIMN_EXPORT int limnObjectVertexNumPreSet(limnObject *obj,
unsigned int partIdx,
unsigned int vertNum);
LIMN_EXPORT int limnObjectVertexAdd(limnObject *obj,
unsigned int partIdx,
float x, float y, float z);
LIMN_EXPORT int limnObjectEdgeAdd(limnObject *obj,
unsigned int partIdx,
unsigned int lookIdx,
unsigned int faceIdx,
unsigned int vertIdx0,
unsigned int vertIdx1);
LIMN_EXPORT int limnObjectFaceNumPreSet(limnObject *obj,
unsigned int partIdx,
unsigned int faceNum);
LIMN_EXPORT int limnObjectFaceAdd(limnObject *obj,
unsigned int partIdx,
unsigned int lookIdx,
unsigned int sideNum,
unsigned int *vertIdx);
/* polydata.c */
LIMN_EXPORT limnPolyData *limnPolyDataNew(void);
LIMN_EXPORT limnPolyData *limnPolyDataNix(limnPolyData *pld);
LIMN_EXPORT unsigned int limnPolyDataInfoBitFlag(const limnPolyData *pld);
LIMN_EXPORT int limnPolyDataAlloc(limnPolyData *pld,
unsigned int infoBitFlag,
unsigned int vertNum,
unsigned int indxNum,
unsigned int primNum);
LIMN_EXPORT size_t limnPolyDataSize(const limnPolyData *pld);
LIMN_EXPORT int limnPolyDataCopy(limnPolyData *pldB, const limnPolyData *pldA);
LIMN_EXPORT int limnPolyDataCopyN(limnPolyData *pldB, const limnPolyData *pldA,
unsigned int num);
LIMN_EXPORT void limnPolyDataTransform_f(limnPolyData *pld,
const float homat[16]);
LIMN_EXPORT void limnPolyDataTransform_d(limnPolyData *pld,
const double homat[16]);
LIMN_EXPORT unsigned int limnPolyDataPolygonNumber(const limnPolyData *pld);
LIMN_EXPORT int limnPolyDataVertexNormals(limnPolyData *pld);
LIMN_EXPORT int limnPolyDataVertexNormalsNO(limnPolyData *pld);
LIMN_EXPORT unsigned int limnPolyDataPrimitiveTypes(const limnPolyData *pld);
LIMN_EXPORT int limnPolyDataPrimitiveVertexNumber(Nrrd *nout,
limnPolyData *pld);
LIMN_EXPORT int limnPolyDataPrimitiveArea(Nrrd *nout, limnPolyData *pld);
LIMN_EXPORT int limnPolyDataRasterize(Nrrd *nout, limnPolyData *pld,
double min[3], double max[3],
size_t size[3], int type);
LIMN_EXPORT void limnPolyDataColorSet(limnPolyData *pld,
unsigned char RR, unsigned char GG,
unsigned char BB, unsigned char AA);
/* polyshapes.c */
LIMN_EXPORT int limnPolyDataCube(limnPolyData *pld,
unsigned int infoBitFlag,
int sharpEdge);
LIMN_EXPORT int limnPolyDataCubeTriangles(limnPolyData *pld,
unsigned int infoBitFlag,
int sharpEdge);
LIMN_EXPORT int limnPolyDataOctahedron(limnPolyData *pld,
unsigned int infoBitFlag,
int sharpEdge);
LIMN_EXPORT int limnPolyDataCone(limnPolyData *pld,
unsigned int infoBitFlag,
unsigned int res, int sharpEdge);
LIMN_EXPORT int limnPolyDataCylinder(limnPolyData *pld,
unsigned int infoBitFlag,
unsigned int res, int sharpEdge);
LIMN_EXPORT int limnPolyDataSuperquadric(limnPolyData *pld,
unsigned int infoBitFlag,
float A, float B,
unsigned int thetaRes,
unsigned int phiRes);
LIMN_EXPORT int limnPolyDataSpiralBetterquadric(limnPolyData *pld,
unsigned int infoBitFlag,
float alpha, float beta,
float cee, float minRad,
unsigned int thetaRes,
unsigned int phiRes);
LIMN_EXPORT int limnPolyDataSpiralSuperquadric(limnPolyData *pld,
unsigned int infoBitFlag,
float A, float B,
unsigned int thetaRes,
unsigned int phiRes);
LIMN_EXPORT int limnPolyDataPolarSphere(limnPolyData *pld,
unsigned int infoBitFlag,
unsigned int thetaRes,
unsigned int phiRes);
LIMN_EXPORT int limnPolyDataSpiralSphere(limnPolyData *pld,
unsigned int infoBitFlag,
unsigned int thetaRes,
unsigned int phiRes);
LIMN_EXPORT int limnPolyDataIcoSphere(limnPolyData *pld,
unsigned int infoBitFlag,
unsigned int level);
LIMN_EXPORT int limnPolyDataPlane(limnPolyData *pld,
unsigned int infoBitFlag,
unsigned int uRes, unsigned int vRes);
LIMN_EXPORT int limnPolyDataSquare(limnPolyData *pld,
unsigned int infoBitFlag);
LIMN_EXPORT int limnPolyDataSuperquadric2D(limnPolyData *pld,
unsigned int infoBitFlag,
float alpha, unsigned int res);
/* polymod.c */
LIMN_EXPORT int limnPolyDataEdgeHalve(limnPolyData *pldOut,
const limnPolyData *pldIn);
LIMN_EXPORT int limnPolyDataVertexWindingFix(limnPolyData *pld,
int allowSplitting);
LIMN_EXPORT int limnPolyDataClip(limnPolyData *pld, Nrrd *nval, double thresh);
LIMN_EXPORT int limnPolyDataClipMulti(limnPolyData *pld, Nrrd *nval,
double *thresh);
LIMN_EXPORT limnPolyData *limnPolyDataCompress(const limnPolyData *pld);
LIMN_EXPORT limnPolyData *limnPolyDataJoin(const limnPolyData **plds,
unsigned int num);
LIMN_EXPORT int limnPolyDataVertexWindingFlip(limnPolyData *pld);
LIMN_EXPORT int limnPolyDataCCFind(limnPolyData *pld);
LIMN_EXPORT int limnPolyDataPrimitiveSort(limnPolyData *pld, const Nrrd *nval);
LIMN_EXPORT int limnPolyDataPrimitiveSelect(limnPolyData *pldOut,
const limnPolyData *pldIn,
const Nrrd *nmask);
LIMN_EXPORT int limnPolyDataNeighborList(unsigned int **nblist, size_t *len,
unsigned int *maxnb,
const limnPolyData *pld);
LIMN_EXPORT int limnPolyDataNeighborArray(int **neighbors, unsigned int *maxnb,
const limnPolyData *pld);
LIMN_EXPORT int limnPolyDataNeighborArrayComp(int **neighbors, int **idx,
const limnPolyData *pld);
/* polyfilter.c */
LIMN_EXPORT int limnPolyDataSpiralTubeWrap(limnPolyData *pldOut,
const limnPolyData *pldIn,
unsigned int infoBitFlag,
Nrrd *nvertMap,
unsigned int tubeFacet,
unsigned int endFacet,
double radius);
LIMN_EXPORT int limnPolyDataSmoothHC(limnPolyData *pld, int *neighbors,
int *idx, double alpha, double beta,
int iter);
/* io.c */
LIMN_EXPORT int limnObjectDescribe(FILE *file, const limnObject *obj);
LIMN_EXPORT int limnObjectReadOFF(limnObject *obj, FILE *file);
LIMN_EXPORT int limnObjectWriteOFF(FILE *file, const limnObject *obj);
LIMN_EXPORT int limnPolyDataWriteIV(FILE *file, const limnPolyData *pld);
LIMN_EXPORT int limnPolyDataWriteLMPD(FILE *file, const limnPolyData *pld);
LIMN_EXPORT int limnPolyDataReadLMPD(limnPolyData *pld, FILE *file);
LIMN_EXPORT int limnPolyDataWriteVTK(FILE *file, const limnPolyData *pld);
LIMN_EXPORT int limnPolyDataReadOFF(limnPolyData *pld, FILE *file);
LIMN_EXPORT int limnPolyDataSave(const char *fname, const limnPolyData *lpld);
LIMN_EXPORT hestCB *limnHestPolyDataLMPD;
LIMN_EXPORT hestCB *limnHestPolyDataOFF;
/* shapes.c */
LIMN_EXPORT int limnObjectCubeAdd(limnObject *obj, unsigned int lookIdx);
LIMN_EXPORT int limnObjectSquareAdd(limnObject *obj, unsigned int lookIdx);
LIMN_EXPORT int limnObjectCylinderAdd(limnObject *obj, unsigned int lookIdx,
unsigned int axis, unsigned int res);
LIMN_EXPORT int limnObjectPolarSphereAdd(limnObject *obj, unsigned int lookIdx,
unsigned int axis,
unsigned int thetaRes,
unsigned int phiRes);
LIMN_EXPORT int limnObjectConeAdd(limnObject *obj, unsigned int lookIdx,
unsigned int axis, unsigned int res);
LIMN_EXPORT int limnObjectPolarSuperquadAdd(limnObject *obj,
unsigned int lookIdx,
unsigned int axis,
float A, float B,
unsigned int thetaRes,
unsigned int phiRes);
LIMN_EXPORT int limnObjectPolarSuperquadFancyAdd(limnObject *obj,
unsigned int lookIdx,
unsigned int axis,
float A, float B,
float C, float R,
unsigned int thetaRes,
unsigned int phiRes);
/* transform.c */
LIMN_EXPORT int limnObjectWorldHomog(limnObject *obj);
LIMN_EXPORT int limnObjectFaceNormals(limnObject *obj, int space);
LIMN_EXPORT int limnObjectVertexNormals(limnObject *obj);
LIMN_EXPORT int limnObjectSpaceTransform(limnObject *obj, limnCamera *cam,
limnWindow *win, int space);
LIMN_EXPORT int limnObjectPartTransform(limnObject *obj, unsigned int partIdx,
float tx[16]);
LIMN_EXPORT int limnObjectDepthSortParts(limnObject *obj);
LIMN_EXPORT int limnObjectDepthSortFaces(limnObject *obj);
LIMN_EXPORT int limnObjectFaceReverse(limnObject *obj);
/* renderLimn.c */
LIMN_EXPORT int limnObjectRender(limnObject *obj, limnCamera *cam,
limnWindow *win);
LIMN_EXPORT int limnObjectPSDraw(limnObject *obj, limnCamera *cam,
Nrrd *envMap, limnWindow *win);
LIMN_EXPORT int limnObjectPSDrawConcave(limnObject *obj, limnCamera *cam,
Nrrd *envMap, limnWindow *win);
/* splineMethods.c */
LIMN_EXPORT limnSplineTypeSpec *limnSplineTypeSpecNew(int type, ...);
LIMN_EXPORT limnSplineTypeSpec *
limnSplineTypeSpecNix(limnSplineTypeSpec *spec);
LIMN_EXPORT limnSpline *limnSplineNew(Nrrd *ncpt, int info,
limnSplineTypeSpec *spec);
LIMN_EXPORT limnSpline *limnSplineNix(limnSpline *spline);
LIMN_EXPORT int limnSplineNrrdCleverFix(Nrrd *nout, Nrrd *nin,
int info, int type);
LIMN_EXPORT limnSpline *limnSplineCleverNew(Nrrd *ncpt, int info,
limnSplineTypeSpec *spec);
LIMN_EXPORT int limnSplineUpdate(limnSpline *spline, Nrrd *ncpt);
/* splineMisc.c */
LIMN_EXPORT const airEnum *const limnSplineType;
LIMN_EXPORT const airEnum *const limnSplineInfo;
LIMN_EXPORT limnSpline *limnSplineParse(char *str);
LIMN_EXPORT limnSplineTypeSpec *limnSplineTypeSpecParse(char *str);
LIMN_EXPORT hestCB *limnHestSpline;
LIMN_EXPORT hestCB *limnHestSplineTypeSpec;
LIMN_EXPORT unsigned int limnSplineInfoSize[LIMN_SPLINE_INFO_MAX+1];
LIMN_EXPORT int limnSplineTypeHasImplicitTangents[LIMN_SPLINE_TYPE_MAX+1];
LIMN_EXPORT int limnSplineNumPoints(limnSpline *spline);
LIMN_EXPORT double limnSplineMinT(limnSpline *spline);
LIMN_EXPORT double limnSplineMaxT(limnSpline *spline);
LIMN_EXPORT void limnSplineBCSet(limnSpline *spline, double B, double C);
/* splineEval.c */
LIMN_EXPORT void limnSplineEvaluate(double *out,
limnSpline *spline, double time);
LIMN_EXPORT int limnSplineNrrdEvaluate(Nrrd *nout,
limnSpline *spline, Nrrd *nin);
LIMN_EXPORT int limnSplineSample(Nrrd *nout, limnSpline *spline,
double minT, size_t M, double maxT);
/* lpu{Flotsam,. . .}.c */
#define LIMN_DECLARE(C) LIMN_EXPORT unrrduCmd limnpu_##C##Cmd;
#define LIMN_LIST(C) &limnpu_##C##Cmd,
/* F(clip) \ */
/* F(vwflip) \ */
/* F(vwfix) */
#define LIMN_MAP(F) \
F(about) \
F(ccfind) \
F(psel) \
F(rast) \
F(verts) \
F(meas) \
F(sort)
LIMN_MAP(LIMN_DECLARE)
LIMN_EXPORT unrrduCmd *limnpuCmdList[];
LIMN_EXPORT void limnpuUsage(char *me, hestParm *hparm);
#ifdef __cplusplus
}
#endif
#endif /* LIMN_HAS_BEEN_INCLUDED */
|