当前位置: 首页>>代码示例>>C++>>正文


C++ PointLight::getRadiance方法代码示例

本文整理汇总了C++中PointLight::getRadiance方法的典型用法代码示例。如果您正苦于以下问题:C++ PointLight::getRadiance方法的具体用法?C++ PointLight::getRadiance怎么用?C++ PointLight::getRadiance使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在PointLight的用法示例。


在下文中一共展示了PointLight::getRadiance方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: forwardPassRay

void PhotonMapper::forwardPassRay(Ray ray, int x, int y, float weight, int depth){
	Intersection is;
	if (weight > 0 && depth < maxForwardPassDepth && mScene->intersect(ray, is)){
		Hitpoint* hp = new Hitpoint();
		hp->pixelX = x;
		hp->pixelY = y;
		hp->is = is;
		hp->radius = startRadius;
		

		Color reflectedC, refractedC, emittedC;
		Material* m = is.mMaterial;
		float reflectivity = m->getReflectivity(is);
		float transparency = m->getTransparency(is);
		float diffuse = (1.0f - reflectivity - transparency)*weight;
		hp->pixelWeight = (1.0f - reflectivity - transparency) * weight;
		if (reflectivity > 0.0f) {
			Ray reflectedRay = is.getReflectedRay();
			forwardPassRay(reflectedRay, x, y, reflectivity * weight, depth+1);
		}
		if (transparency > 0.0f) {
			Ray refractedRay = is.getRefractedRay();
			forwardPassRay(refractedRay, x, y, transparency * weight, depth+1);
		}

		if (diffuse){
			for (int i = 0; i < mScene->getNumberOfLights(); ++i){
				PointLight* l = mScene->getLight(i);
				if (!mScene->intersect(is.getShadowRay(l))){
					Vector3D lightVec = l->getWorldPosition() - is.mPosition;
					float d2 = lightVec.length2();
					lightVec.normalize();
					Color radiance = l->getRadiance();
					Color brdf = is.mMaterial->evalBRDF(is, lightVec);
					float angle = max(lightVec * is.mNormal, 0.0f);
					hp->directIllumination += radiance * brdf * angle / d2;
				}
			}
			vec.push_back(hp);
		}
	}
}
开发者ID:aronsoderling,项目名称:raytracer,代码行数:42,代码来源:photonmapper.cpp

示例2: photonTracingPass

void PhotonMapper::photonTracingPass(){
	for (int i = 0; i < mScene->getNumberOfLights(); ++i){
		PointLight* l = mScene->getLight(i);
		for (int i = 0; i < numberPhotons; ++i){
			
			Vector3D dir(uniform() * 2 - 1, uniform() * 2 - 1, uniform() * 2 - 1);
			while(dir.length2() > 1.0f){
				dir = Vector3D(uniform() * 2 - 1, uniform() * 2 - 1, uniform() * 2 - 1);
			}
			dir.normalize();

			Ray ray;
			ray.orig = l->getWorldPosition();
			ray.dir = dir;

			Color startFlux = l->getRadiance() * 4.0f * M_PI;

			trace(ray, 0, startFlux);
		}
	}
}
开发者ID:aronsoderling,项目名称:raytracer,代码行数:21,代码来源:photonmapper.cpp


注:本文中的PointLight::getRadiance方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。