HGE-OpenGL портирует функцию Gfx_SetTransform - PullRequest
0 голосов
/ 15 апреля 2011

Прежде всего - я новичок в графическом программировании Smile.

Я поддерживаю игру на основе портированной версии HGE, которая не содержит OpenGL-версию Gfx_SetTransform .Я нашел несколько примеров портирования HGE-Opengl, но любой пример имеет эту функцию.

Код:

void CALL HGE_Impl::Gfx_SetTransform(float x, float y, float dx, float dy, float rot, float hscale, float vscale)
{
   D3DXMATRIX tmp;

   if(vscale==0.0f) D3DXMatrixIdentity(&matView);
   else
   {
      D3DXMatrixTranslation(&matView, -x, -y, 0.0f);
      D3DXMatrixScaling(&tmp, hscale, vscale, 1.0f);
      D3DXMatrixMultiply(&matView, &matView, &tmp);
      D3DXMatrixRotationZ(&tmp, -rot);
      D3DXMatrixMultiply(&matView, &matView, &tmp);
      D3DXMatrixTranslation(&tmp, x+dx, y+dy, 0.0f);
      D3DXMatrixMultiply(&matView, &matView, &tmp);
   }

   _render_batch();
   pD3DDevice->SetTransform(D3DTS_VIEW, &matView);
}

Итак, кто-нибудь может помочь в портировании Gfx_SetTransform илисделать предложение (может быть, какой-нибудь простой пример или функции OpenGL, которые я должен искать)?Спасибо.

1 Ответ

1 голос
/ 15 апреля 2011

С OpenGL до версии, не включающей 3, вы можете заменить ее следующим:

void GL2_SetTransform(float x, float y, float dx, float dy, float rot, float hscale, float vscale)
{
   glMatrixMode(GL_MODELVIEW);
   glLoadIdentity(); // we start off a identity matrix

   // Instead of testing for 0, you should test for some
   // threshold, to increase numerical stability
   if( fabs(vscale) >= 1e-7 ) {
      glTranslatef(-x, -y, 0.0f);
      glScalef(hscale, vscale, 1.0f);
      glRotatef(-rot, 0., 0., 1.);
      glTranslatef(x+dx, y+dy, 0.0f);
   }
}

OpenGL-3 устарел функциями манипулирования матрицей, поэтому код выглядит почти идентично версии DirectX (я изменилнесколько вещей для улучшения стабильности):

typedef float mat4x4[4][4];
// OpenGL uses column major mode, so the first
// index selects column, the second row - this is
// opposite to the usual C notation.

// The following functions must be implemented as well.
// But they're easy enough.

// function to set the matrix to identity
void mat4x4_identity(mat4x4 *M);

// those functions transform the matrix in-place,
// i.e. no temporaries needed.
void mat4x4_rotX(mat4x4 *M, float angle);
void mat4x4_rotY(mat4x4 *M, float angle);
void mat4x4_rotZ(mat4x4 *M, float angle);

void mat4x4_scale(mat4x4 *M, float x, float y, float z);

void mat4x4_translate(mat4x4 *M, float x, float y, float z);


void GL3_SetTransform(float x, float y, float dx, float dy, float rot, float hscale, float vscale)
{
   mat4x4 view;
   mat4x4_identity(view);

   if( fabs(vscale) >= 1e-8 ) {
      mat4x4_translate(view, -x, -y, 0.0f);
      mat4x4_scale(view, hscale, vscale, 1.0f);
      mat4x4_rotZ(view, -rot);
      mat4x4_translate(view, x+dx, y+dy, 0.0f);
   }

   _render_batch();
   // get_view_uniform_location returns the handle for the currently loaded
   // shader's modelview matrix' location. Application specific, so you've to
   // come up with that yourself.
   glUniformMatrix4fv(get_view_uniform_locaton(), 1, false, view);
}

Здесь я приведу исходный код для функций манипуляции с матрицами: http://pastebin.com/R0PHTW0M Они не используют точно такую ​​же схему именования.

...