本文整理汇总了C++中float4类的典型用法代码示例。如果您正苦于以下问题:C++ float4类的具体用法?C++ float4怎么用?C++ float4使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了float4类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1:
void IGLUShaderVariable::operator= ( float4 val )
{
// Check for a valid shader index
if ( m_varIdx < 0 ) return;
// Check for type mismatches
if ( m_isAttribute )
{
AssignmentToAttribute( "vec4" );
return;
}
if ( m_varType != GL_FLOAT_VEC4 && m_varType != GL_DOUBLE_VEC4 )
TypeMismatch( "vec4" );
// Ensure this program is currently bound, or setting shader values fails!
m_parent->PushProgram();
// For types of variable that can be assigned from our input value, assign them here
if ( m_varType == GL_FLOAT_VEC4 )
glUniform4fv( m_varIdx, 1, val.GetConstDataPtr() );
if ( m_varType == GL_DOUBLE_VEC4 )
glUniform4d( m_varIdx, val.X(), val.Y(), val.Z(), val.W() );
// We have a short "program stack" so make sure to pop off.
m_parent->PopProgram();
}
示例2: addRandRect
void addRandRect(int num, float4 min, float4 max, float spacing, float scale, float4 dmin, float4 dmax, std::vector<float4>& rvec)
{
/*!
* Create a rectangle with at most num particles in it.
* The size of the return vector will be the actual number of particles used to fill the rectangle
*/
srand(time(NULL));
spacing *= 1.1f;
min.print("Box min: ");
max.print("Box max: ");
float xmin = min.x / scale;
float xmax = max.x / scale;
float ymin = min.y / scale;
float ymax = max.y / scale;
float zmin = min.z / scale;
float zmax = max.z / scale;
rvec.resize(num);
int i=0;
for (float z = zmin; z <= zmax; z+=spacing) {
for (float y = ymin; y <= ymax; y+=spacing) {
for (float x = xmin; x <= xmax; x+=spacing) {
if (i >= num) break;
//printf("adding particles: %f, %f, %f\n", x, y, z);
rvec[i] = float4(x-(float) rand()/RAND_MAX,y-(float) rand()/RAND_MAX,z-(float) rand()/RAND_MAX,1.0f);
i++;
}}}
rvec.resize(i);
}
示例3: RotateFromTo
Quat MUST_USE_RESULT Quat::RotateFromTo(const float4 &sourceDirection, const float4 &targetDirection)
{
#if defined(MATH_AUTOMATIC_SSE) && defined(MATH_SSE)
// Best: 12.289 nsecs / 33.144 ticks, Avg: 12.489 nsecs, Worst: 14.210 nsecs
simd4f cosAngle = dot4_ps(sourceDirection.v, targetDirection.v);
cosAngle = negate3_ps(cosAngle); // [+ - - -]
// XYZ channels use the trigonometric formula sin(x/2) = +/-sqrt(0.5-0.5*cosx))
// The W channel uses the trigonometric formula cos(x/2) = +/-sqrt(0.5+0.5*cosx))
simd4f half = set1_ps(0.5f);
simd4f cosSinHalfAngle = sqrt_ps(add_ps(half, mul_ps(half, cosAngle))); // [cos(x/2), sin(x/2), sin(x/2), sin(x/2)]
simd4f axis = cross_ps(sourceDirection.v, targetDirection.v);
simd4f recipLen = rsqrt_ps(dot4_ps(axis, axis));
axis = mul_ps(axis, recipLen); // [0 z y x]
// Set the w component to one.
simd4f one = add_ps(half, half); // [1 1 1 1]
simd4f highPart = _mm_unpackhi_ps(axis, one); // [_ _ 1 z]
axis = _mm_movelh_ps(axis, highPart); // [1 z y x]
Quat q;
q.q = mul_ps(axis, cosSinHalfAngle);
return q;
#else
// Best: 19.970 nsecs / 53.632 ticks, Avg: 20.197 nsecs, Worst: 21.122 nsecs
assume(EqualAbs(sourceDirection.w, 0.f));
assume(EqualAbs(targetDirection.w, 0.f));
return Quat::RotateFromTo(sourceDirection.xyz(), targetDirection.xyz());
#endif
}
示例4:
void float4::Orthonormalize(float4 &a, float4 &b)
{
assume(!a.IsZero());
assume(!b.IsZero());
a.Normalize();
b -= b.ProjectToNorm(a);
b.Normalize();
}
示例5: GetRadFromXY
void DynamicSkyLight::SetLightParams(float4 newLightDir, float startAngle, float orbitTime) {
newLightDir.ANormalize();
sunStartAngle = PI + startAngle; //FIXME WHY +PI?
sunOrbitTime = orbitTime;
initialSunAngle = GetRadFromXY(newLightDir.x, newLightDir.z);
//FIXME This function really really needs comments about what it does!
if (newLightDir.w == FLT_MAX) {
// old: newLightDir is position where sun reaches highest altitude
const float sunLen = newLightDir.Length2D();
const float sunAzimuth = (sunLen <= 0.001f) ? PI / 2.0f : atan(newLightDir.y / sunLen);
const float sunHeight = tan(sunAzimuth - 0.001f);
float3 v1(cos(initialSunAngle), sunHeight, sin(initialSunAngle));
v1.ANormalize();
if (v1.y <= orbitMinSunHeight) {
newLightDir = UpVector;
sunOrbitHeight = v1.y;
sunOrbitRad = sqrt(1.0f - sunOrbitHeight * sunOrbitHeight);
} else {
float3 v2(cos(initialSunAngle + PI), orbitMinSunHeight, sin(initialSunAngle + PI));
v2.ANormalize();
float3 v3 = v2 - v1;
sunOrbitRad = v3.Length() / 2.0f;
v3.ANormalize();
float3 v4 = (v3.cross(UpVector)).ANormalize();
float3 v5 = (v3.cross(v4)).ANormalize();
if (v5.y < 0.0f)
v5 = -v5;
newLightDir = v5;
sunOrbitHeight = v5.dot(v1);
}
} else {
// new: newLightDir is center position of orbit, and newLightDir.w is orbit height
sunOrbitHeight = std::max(-1.0f, std::min(newLightDir.w, 1.0f));
sunOrbitRad = sqrt(1.0f - sunOrbitHeight * sunOrbitHeight);
}
sunRotation.LoadIdentity();
sunRotation.SetUpVector(newLightDir);
const float4& peakDir = CalculateSunPos(0.0f);
const float peakElev = std::max(0.01f, peakDir.y);
shadowDensityFactor = 1.0f / peakElev;
SetLightDir(CalculateSunPos(sunStartAngle).ANormalize());
}
示例6: assume
float4 float4::Perpendicular(const float4 &hint, const float4 &hint2) const
{
assume(!this->IsZero3());
assume(EqualAbs(w, 0));
assume(hint.IsNormalized());
assume(hint2.IsNormalized());
float4 v = this->Cross(hint);
float len = v.Normalize();
if (len == 0)
return hint2;
else
return v;
}
示例7: atan
void CGlobalRendering::UpdateSunParams(float4 newSunDir, float startAngle, float orbitTime, bool iscompat) {
newSunDir.ANormalize();
sunStartAngle = startAngle;
sunOrbitTime = orbitTime;
initialSunAngle = fastmath::coords2angle(newSunDir.x, newSunDir.z);
if(iscompat) { // backwards compatible: sunDir is position where sun reaches highest altitude
float sunLen = newSunDir.Length2D();
float sunAzimuth = (sunLen <= 0.001f) ? PI / 2.0f : atan(newSunDir.y / sunLen);
float sunHeight = tan(sunAzimuth - 0.001f);
float orbitMinSunHeight = 0.1f; // the lowest sun altitude for an auto generated orbit
float3 v1(cos(initialSunAngle), sunHeight, sin(initialSunAngle));
v1.ANormalize();
if(v1.y <= orbitMinSunHeight) {
newSunDir = float3(0.0f, 1.0f, 0.0f);
sunOrbitHeight = v1.y;
sunOrbitRad = sqrt(1.0f - sunOrbitHeight * sunOrbitHeight);
}
else {
float3 v2(cos(initialSunAngle + PI), orbitMinSunHeight, sin(initialSunAngle + PI));
v2.ANormalize();
float3 v3 = v2 - v1;
sunOrbitRad = v3.Length() / 2.0f;
v3.ANormalize();
float3 v4 = v3.cross(float3(0.0f, 1.0f, 0.0f));
v4.ANormalize();
float3 v5 = v3.cross(v4);
v5.ANormalize();
if(v5.y < 0)
v5 = -v5;
newSunDir = v5;
sunOrbitHeight = v5.dot(v1);
}
}
else { // new: sunDir is center position of orbit, and sunDir.w is orbit height
sunOrbitHeight = std::max(-1.0f, std::min(newSunDir.w, 1.0f));
sunOrbitRad = sqrt(1.0f - sunOrbitHeight * sunOrbitHeight);
}
sunRotation.LoadIdentity();
sunRotation.SetUpVector(newSunDir);
float4 peakSunDir = CalculateSunDir(0.0f);
shadowDensityFactor = 1.0f / std::max(0.01f, peakSunDir.y);
UpdateSun(true);
}
示例8: u
matrix4 matrix4::rotation(float4 axis, float angle)
{
matrix4 result;
float sin = std::sin(angle);
float cos = std::cos(angle);
axis.w = 0.0f;
float4 u(axis.normalized());
/*
* According to Redbook:
*
* u = axis/||axis||
*
* | 0 -z y |
* S = | z 0 -x |
* | -y x 0 |
*
* M = uu^t + cos(a)(I - uu^t) + sin(a)*S
*
* That is: M.x = (uu^t).x + cos(a)((1 0 0)^t - uu^t.x) + sin(a) (0 -z y)^t
* uu^t.x = u.x * u
* And so on for the others
*/
result.x = u.x*u + cos*(float4(1, 0, 0, 0) - u.x*u) + sin * float4(0.0, u.z, -u.y, 0);
result.y = u.y*u + cos*(float4(0, 1, 0, 0) - u.y*u) + sin * float4(-u.z, 0.0, u.x, 0);
result.z = u.z*u + cos*(float4(0, 0, 1, 0) - u.z*u) + sin * float4(u.y, -u.x, 0.0, 0);
result.w = float4(0, 0, 0, 1);
return result;
}
示例9: SetUniform
// set uniform to 4D vector
void Shader::SetUniform(const c8 * const name, const float4 &val)
{
PUSH_ACTIVE_SHADER(t);
Activate();
glUniform4fv(GetUniformLocation(name),1, val.GetVec());
POP_ACTIVE_SHADER(t);
};
示例10: printf
Hose::Hose(RTPS *ps, int total_n, float4 center, float4 velocity, float radius, float spacing, float4 color)
{
printf("Constructor!\n");
this->ps = ps;
this->total_n = total_n;
this->center = center;
this->velocity = velocity;
this->radius = radius;
this->spacing = spacing;
this->color = color;
em_count = 0;
n_count = total_n;
calc_vectors();
center.print("center");
velocity.print("velocity");
}
示例11: Transpose
// Multiply matrix and 4D vector together
float4 Mat44::Mult(const float4 &m) const
{
Mat44 tr = Transpose();
__m128 matcols[] =
{
_mm_load_ps(tr.mat),
_mm_load_ps(tr.mat+4),
_mm_load_ps(tr.mat+8),
_mm_load_ps(tr.mat+12)
};
__m128 v = _mm_load_ps(m.GetVec());
// Broadcast vector into SSE registers
__m128 xb = _mm_shuffle_ps(v,v,0x00);
__m128 yb = _mm_shuffle_ps(v,v,0x55);
__m128 zb = _mm_shuffle_ps(v,v,0xAA);
__m128 wb = _mm_shuffle_ps(v,v,0xFF);
// Perform multiplication by matrix columns
xb = _mm_mul_ps(xb, matcols[0]);
yb = _mm_mul_ps(yb, matcols[1]);
zb = _mm_mul_ps(zb, matcols[2]);
wb = _mm_mul_ps(wb, matcols[3]);
// Add results
__m128 r = _mm_add_ps(_mm_add_ps(xb, yb),_mm_add_ps(zb, wb));
float4 returnVec;
_mm_store_ps(returnVec.GetVec(), r);
return returnVec;
};
示例12: intersect_ray_plane
bool intersect_ray_plane(const ray & ray, const float4 & plane, float * hit_t)
{
float denom = dot(plane.xyz(), ray.direction);
if(std::abs(denom) == 0) return false;
if(hit_t) *hit_t = -dot(plane, float4(ray.origin,1)) / denom;
return true;
}
示例13: float4
float4 float4::Cross3(const float4 &rhs) const
{
#ifdef MATH_SSE
return float4(_mm_cross_ps(v, rhs.v));
#else
return Cross3(rhs.xyz());
#endif
}
示例14: p0p1
bool ray4::hitsTriangle(const float4 *points, float &length) const
{
const float4 p0p1(points[1] - points[0]);
const float4 p0p2(points[2] - points[0]);
const float4 normal = float4(p0p1.cross(p0p2));
// n * p = n * (s + t*d) = n*s + n*d*t
// n(p-s) = ndt
// (n(p-s))/(n*d) = t
float4 dir = direction();
float4 outFactor = float4(-1.0f);
float4 normalTimesDirection = normal.prod(dir);
outFactor = (normalTimesDirection != float4(0.0f)).select(normal.prod(points[0] - start()) / normalTimesDirection, outFactor);
if((outFactor < float4(0.0f)).all())
return false;
if(outFactor.max() > 1.0f)
return false;
const float4 location = this->point(outFactor.max());
length = outFactor.max();
return location.isOnTriangle(points);
}
示例15: GML_RECMUTEX_LOCK
void CSelectedUnits::HandleUnitBoxSelection(const float4& planeRight, const float4& planeLeft, const float4& planeTop, const float4& planeBottom)
{
GML_RECMUTEX_LOCK(sel); // SelectUnits
CUnit* unit = NULL;
int addedunits = 0;
int team, lastTeam;
if (gu->spectatingFullSelect || gs->godMode) {
// any team's units can be *selected*
// (whether they can be given orders
// depends on our ability to play god)
team = 0;
lastTeam = teamHandler->ActiveTeams() - 1;
} else {
team = gu->myTeam;
lastTeam = gu->myTeam;
}
for (; team <= lastTeam; team++) {
CUnitSet& teamUnits = teamHandler->Team(team)->units;
for (CUnitSet::iterator ui = teamUnits.begin(); ui != teamUnits.end(); ++ui) {
const float4 vec((*ui)->midPos, 1.0f);
if (vec.dot4(planeRight) < 0.0f && vec.dot4(planeLeft) < 0.0f && vec.dot4(planeTop) < 0.0f && vec.dot4(planeBottom) < 0.0f) {
if (keyInput->IsKeyPressed(SDLK_LCTRL) && (selectedUnits.find(*ui) != selectedUnits.end())) {
RemoveUnit(*ui);
} else {
AddUnit(*ui);
unit = *ui;
addedunits++;
}
}
}
}
#if (PLAY_SOUNDS == 1)
if (addedunits >= 2) {
Channels::UserInterface.PlaySample(soundMultiselID);
}
else if (addedunits == 1) {
Channels::UnitReply.PlayRandomSample(unit->unitDef->sounds.select, unit);
}
#endif
}