miteUser * miteUserNew() { miteUser *muu; int i; muu = (miteUser *)calloc(1, sizeof(miteUser)); if (!muu) return NULL; muu->umop = airMopNew(); muu->nsin = NULL; muu->nvin = NULL; muu->ntin = NULL; muu->ntxf = NULL; /* managed by user (with miter: hest) */ muu->nout = NULL; /* managed by user (with miter: hest) */ muu->debug = NULL; muu->debugArr = NULL; muu->ndebug = NULL; /* not allocated until the debug pixel is rendered, see miteRayBegin */ muu->ntxfNum = 0; muu->shadeStr[0] = 0; muu->normalStr[0] = 0; for (i=0; i<MITE_RANGE_NUM; i++) { muu->rangeInit[i] = 1.0; } muu->normalSide = miteDefNormalSide; muu->refStep = miteDefRefStep; muu->rayStep = AIR_NAN; muu->opacMatters = miteDefOpacMatters; muu->opacNear1 = miteDefOpacNear1; muu->hctx = hooverContextNew(); ELL_3V_SET(muu->fakeFrom, AIR_NAN, AIR_NAN, AIR_NAN); ELL_3V_SET(muu->vectorD, 0, 0, 0); airMopAdd(muu->umop, muu->hctx, (airMopper)hooverContextNix, airMopAlways); for (i=0; i<GAGE_KERNEL_NUM; i++) { muu->ksp[i] = NULL; } muu->gctx0 = gageContextNew(); airMopAdd(muu->umop, muu->gctx0, (airMopper)gageContextNix, airMopAlways); gageParmSet(muu->gctx0, gageParmRequireAllSpacings, AIR_FALSE); muu->lit = limnLightNew(); airMopAdd(muu->umop, muu->lit, (airMopper)limnLightNix, airMopAlways); muu->normalSide = miteDefNormalSide; muu->verbUi = muu->verbVi = -1; muu->rendTime = 0; muu->sampRate = 0; return muu; }
mrendUser * mrendUserNew() { mrendUser *uu; int i; uu = (mrendUser *)calloc(1, sizeof(mrendUser)); uu->nin = NULL; uu->kind = NULL; uu->rayStep = 0.0; uu->whatq = gageSclUnknown; uu->measr = nrrdMeasureUnknown; for (i=gageKernelUnknown+1; i<gageKernelLast; i++) { uu->ksp[i] = NULL; } uu->gctx0 = gageContextNew(); uu->hctx = hooverContextNew(); uu->outS = NULL; uu->mrmop = airMopNew(); airMopAdd(uu->mrmop, uu->gctx0, (airMopper)gageContextNix, airMopAlways); airMopAdd(uu->mrmop, uu->hctx, (airMopper)hooverContextNix, airMopAlways); return uu; }