ftp.nice.ch/pub/next/unix/graphics/rayshade.4.0.s.tar.gz#/rayshade.4.0/libsurf/mist.c

This is mist.c in view mode; [Download] [Up]

/*
 * mist.c
 *
 * Copyright (C) 1989, 1991, Craig E. Kolb
 * All rights reserved.
 *
 * This software may be freely copied, modified, and redistributed
 * provided that this copyright notice is preserved on all copies.
 *
 * You may not distribute this software, in whole or in part, as part of
 * any commercial product without the express consent of the authors.
 *
 * There is no warranty or other guarantee of fitness of this software
 * for any purpose.  It is provided solely "as is".
 *
 * $Id$
 *
 * $Log$
 */
#include "atmosphere.h"
#include "mist.h"

Mist *
MistCreate(color, trans, zero, scale)
Color *color, *trans;
Float zero, scale;
{
	Mist *mist;

	mist = (Mist *)Malloc(sizeof(Mist));
	mist->color = *color;
	mist->trans = *trans;
	mist->zero = zero;
	mist->scale = 1. / scale;
	return mist;
}

/*
 * Add low-altitude mist to the given color.
 */
void
MistApply(mist, ray, pos, dist, color)
Mist *mist;
Ray *ray;
Vector *pos;
Float dist;
Color *color;
{
	Float deltaZ, d, atten;
	extern Float ExpAtten();

	deltaZ = mist->scale * (pos->z - ray->pos.z);
	if (fabs(deltaZ) > EPSILON)
		d = (exp(-ray->pos.z*mist->scale + mist->zero) -
			    exp(-pos->z*mist->scale + mist->zero)) / deltaZ;
	else
		d = exp(-pos->z*mist->scale + mist->zero);

	dist *= d;

	atten = ExpAtten(dist, mist->trans.r);
	color->r = atten*color->r + (1. - atten)*mist->color.r;

	atten = ExpAtten(dist, mist->trans.g);
	color->g = atten*color->g + (1. - atten)*mist->color.g;

	atten = ExpAtten(dist, mist->trans.b);
	color->b = atten*color->b + (1. - atten)*mist->color.b;
}

These are the contents of the former NiCE NeXT User Group NeXTSTEP/OpenStep software archive, currently hosted by Netfuture.ch.