dxx-rebirth/common/3d/instance.cpp

85 lines
1.9 KiB
C++
Raw Normal View History

2006-03-20 16:43:15 +00:00
/*
* This file is part of the DXX-Rebirth project <http://www.dxx-rebirth.com/>.
* It is copyright by its individual contributors, as recorded in the
* project's Git history. See COPYING.txt at the top level for license
* terms and a link to the Git history.
*/
2006-03-20 16:43:15 +00:00
/*
*
* Instancing routines
*
*/
#include <stdlib.h>
#include "dxxerror.h"
2006-03-20 16:43:15 +00:00
#include "3d.h"
#include "globvars.h"
2015-12-13 18:00:49 +00:00
namespace dcx {
2015-12-05 22:57:24 +00:00
namespace {
2006-03-20 16:43:15 +00:00
struct instance_context {
vms_matrix m;
vms_vector p;
2015-08-12 03:11:46 +00:00
};
}
2016-07-10 04:11:34 +00:00
static array<instance_context, 5> instance_stack;
2006-03-20 16:43:15 +00:00
int instance_depth = 0;
//instance at specified point with specified orientation
//if matrix==NULL, don't modify matrix. This will be like doing an offset
2014-10-02 03:02:35 +00:00
void g3_start_instance_matrix(const vms_vector &pos,const vms_matrix *orient)
2006-03-20 16:43:15 +00:00
{
2016-07-10 04:11:34 +00:00
assert(instance_depth < instance_stack.size());
2006-03-20 16:43:15 +00:00
instance_stack[instance_depth].m = View_matrix;
instance_stack[instance_depth].p = View_position;
instance_depth++;
//step 1: subtract object position from view position
if (orient) {
2014-10-29 03:24:31 +00:00
const auto tempv = vm_vec_sub(View_position, pos);
2006-03-20 16:43:15 +00:00
//step 2: rotate view vector through object matrix
2014-10-01 02:28:42 +00:00
vm_vec_rotate(View_position,tempv,*orient);
2006-03-20 16:43:15 +00:00
//step 3: rotate object matrix through view_matrix (vm = ob * vm)
View_matrix = vm_matrix_x_matrix(vm_transposed_matrix(*orient),View_matrix);
2006-03-20 16:43:15 +00:00
}
}
//instance at specified point with specified orientation
//if angles==NULL, don't modify matrix. This will be like doing an offset
void g3_start_instance_angles(const vms_vector &pos,const vms_angvec *angles)
2006-03-20 16:43:15 +00:00
{
if (angles==NULL) {
g3_start_instance_matrix(pos,NULL);
2006-03-20 16:43:15 +00:00
return;
}
const auto tm = vm_angles_2_matrix(*angles);
g3_start_instance_matrix(pos,&tm);
2006-03-20 16:43:15 +00:00
}
//pops the old context
void g3_done_instance()
{
instance_depth--;
Assert(instance_depth >= 0);
View_position = instance_stack[instance_depth].p;
View_matrix = instance_stack[instance_depth].m;
}
2015-12-05 22:57:24 +00:00
}