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


C++ vec3::Set方法代码示例

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


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

示例1: YawPitchRollToUpDirection

			bool YawPitchRollToUpDirection(float yaw, float pitch, float roll, vec3& up, vec3& dir)
			{
				float cos_yaw = cos(yaw);
				float cos_pitch = cos(pitch);
				float cos_roll = cos(roll);
				float sin_yaw = sin(yaw);
				float sin_pitch = sin(pitch);
				float sin_roll = sin(roll);

				dir.Set(sin_yaw * cos_pitch, sin_pitch, cos_pitch * -cos_yaw);
				up.Set(-cos_yaw * sin_roll - sin_yaw * sin_pitch * cos_roll, cos_pitch * cos_roll, -sin_yaw * sin_roll - sin_pitch * cos_roll * -cos_yaw);

				up.Normalize();
				dir.Normalize();
				return true;
			}
开发者ID:Mikalai,项目名称:punk_project_a,代码行数:16,代码来源:helper.cpp

示例2: SymmetricEigenSystem

	bool SymmetricEigenSystem(const mat3& m, vec3& value, mat3& r)
	{
		const int max_sweep = 32;
		const float epsilon = 1.0e-10f;
		float m11 = m.At(0,0);
		float m12 = m.At(0,1);
		float m13 = m.At(0,2);
		float m22 = m.At(1,1);
		float m23 = m.At(1,2);
		float m33 = m.At(2,2);

		r.Identity();

		for (int a = 0; a < max_sweep; ++a)
		{
			if ((Abs(m12) < epsilon) && (Abs(m13) < epsilon) && (Abs(m23) < epsilon))
				break;

			//	annihilate 1 2
			if (m12 != 0.0f)
			{
				float u = (m22 - m11) * 0.5f / m12;
				float u2 = u*u;
				float u2p1 = u2 + 1.0f;
				float t = (u2p1 != u2) ? ((u < 0.0f) ? -1.0f : 1.0f) * (sqrt(u2p1) - fabs(u)) : 0.5f / u;
				float c = 1.0f / sqrt(t*t + 1.0f);
				float s = c * t;

				m11 -= t * m12;
				m22 += t * m12;
				m12 = 0.0f;

				float temp = c*m13 - s * m23;
				m23 = s * m13 + c * m23;
				m13 = temp;

				for (int i = 0; i < 3; ++i)
				{
					float temp = c * r.At(i, 0) - s * r.At(i,1);
					r.At(i,1) = s * r.At(i,0) + c * r.At(i,1);
					r.At(i,0) = temp;
				}
			}

			//	annihilate 1 3
			if (m13 != 0.0f)
			{
				float u = (m33 - m11) * 0.5f / m13;
				float u2 = u*u;
				float u2p1 = u2 + 1.0f;
				float t = (u2p1 != u2) ? ((u < 0.0f) ? -1.0f : 1.0f) * (sqrt(u2p1) - fabs(u)) : 0.5f / u;
				float c = 1.0f / sqrt(t*t + 1.0f);
				float s = c * t;

				m11 -= t * m13;
				m33 += t * m13;
				m13 = 0.0f;

				float temp = c * m12 - s * m23;
				m23 = s * m12 + c * m23;
				m12 = temp;

				for (int i = 0; i < 3; ++i)
				{
					float temp = c * r.At(i, 0) - s * r.At(i, 2);
					r.At(i, 2) = s * r.At(i, 0) + c * r.At(i, 2);
					r.At(i, 0) = temp;
				}
			}

			//	annihilate 2 3
			if (m23 != 0.0f)
			{
				float u = (m33 - m22) * 0.5f / m23;
				float u2 = u*u;
				float u2p1 = u2 + 1.0f;
				float t = (u2p1 != u2) ? ((u < 0.0f) ? -1.0f : 1.0f) * (sqrt(u2p1) - fabs(u)) : 0.5f / u;
				float c = 1.0f / sqrt(t*t + 1.0f);
				float s = c * t;

				m22 -= t * m23;
				m33 += t * m23;
				m23 = 0.0f;

				float temp = c * m12 - s * m13;
				m13 = s * m12 + c * m13;
				m12 = temp;

				for (int i = 0; i < 3; ++i)
				{
					float temp = c * r.At(i, 1) - s * r.At(i, 2);
					r.At(i, 2) = s * r.At(i, 1) + c * r.At(i, 2);
					r.At(i, 1) = temp;
				}
			}
		}

		value.Set(m11, m22, m33);
		return true;
	}
开发者ID:Mikalai,项目名称:punk_project,代码行数:100,代码来源:helper.cpp


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