mirror of
https://github.com/JulianGro/overte.git
synced 2025-04-06 01:03:19 +02:00
Default with less stuff showing, code cleanup.
This commit is contained in:
commit
eb69451c9b
7 changed files with 49 additions and 138 deletions
BIN
.DS_Store
vendored
BIN
.DS_Store
vendored
Binary file not shown.
|
@ -18,6 +18,8 @@
|
|||
D40BDFD513404BA300B0BE1F /* GLUT.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = D40BDFD413404BA300B0BE1F /* GLUT.framework */; };
|
||||
D40BDFD713404BB300B0BE1F /* OpenGL.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = D40BDFD613404BB300B0BE1F /* OpenGL.framework */; };
|
||||
D40FD5FB164AF1C200878184 /* int-texture256-v2.png in CopyFiles */ = {isa = PBXBuildFile; fileRef = D40FD5FA164AF1A700878184 /* int-texture256-v2.png */; };
|
||||
D40FD5FD164B0D3A00878184 /* int-texture256-v4.png in CopyFiles */ = {isa = PBXBuildFile; fileRef = D40FD5FC164B0D2800878184 /* int-texture256-v4.png */; };
|
||||
D40FD5FF164B146C00878184 /* int-texture256-v5.png in CopyFiles */ = {isa = PBXBuildFile; fileRef = D40FD5FE164B145E00878184 /* int-texture256-v5.png */; };
|
||||
D4B96D4915FF967C00CE6E8B /* head.cpp in Sources */ = {isa = PBXBuildFile; fileRef = D4B96D4815FF967C00CE6E8B /* head.cpp */; };
|
||||
D4EE3BBC15E45FFE00EE4C89 /* SerialInterface.cpp in Sources */ = {isa = PBXBuildFile; fileRef = D4EE3BBB15E45FFE00EE4C89 /* SerialInterface.cpp */; };
|
||||
D4EE3BBE15E7465700EE4C89 /* field.cpp in Sources */ = {isa = PBXBuildFile; fileRef = D4EE3BBD15E7465700EE4C89 /* field.cpp */; };
|
||||
|
@ -39,6 +41,8 @@
|
|||
dstPath = "";
|
||||
dstSubfolderSpec = 16;
|
||||
files = (
|
||||
D40FD5FF164B146C00878184 /* int-texture256-v5.png in CopyFiles */,
|
||||
D40FD5FD164B0D3A00878184 /* int-texture256-v4.png in CopyFiles */,
|
||||
D40FD5FB164AF1C200878184 /* int-texture256-v2.png in CopyFiles */,
|
||||
F68135B21649EF3F003040E3 /* grayson-particle.png in CopyFiles */,
|
||||
F68135971649CF41003040E3 /* sphere.png in CopyFiles */,
|
||||
|
@ -65,6 +69,8 @@
|
|||
D40BDFD413404BA300B0BE1F /* GLUT.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = GLUT.framework; path = /System/Library/Frameworks/GLUT.framework; sourceTree = "<absolute>"; };
|
||||
D40BDFD613404BB300B0BE1F /* OpenGL.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = OpenGL.framework; path = /System/Library/Frameworks/OpenGL.framework; sourceTree = "<absolute>"; };
|
||||
D40FD5FA164AF1A700878184 /* int-texture256-v2.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "int-texture256-v2.png"; sourceTree = SOURCE_ROOT; };
|
||||
D40FD5FC164B0D2800878184 /* int-texture256-v4.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "int-texture256-v4.png"; sourceTree = SOURCE_ROOT; };
|
||||
D40FD5FE164B145E00878184 /* int-texture256-v5.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "int-texture256-v5.png"; sourceTree = SOURCE_ROOT; };
|
||||
D4B96D4715FF966200CE6E8B /* head.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = head.h; sourceTree = "<group>"; };
|
||||
D4B96D4815FF967C00CE6E8B /* head.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = head.cpp; sourceTree = "<group>"; };
|
||||
D4EE3BBA15E45FFE00EE4C89 /* SerialInterface.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = SerialInterface.h; sourceTree = "<group>"; };
|
||||
|
@ -180,6 +186,8 @@
|
|||
F681356716487A7F003040E3 /* images */ = {
|
||||
isa = PBXGroup;
|
||||
children = (
|
||||
D40FD5FE164B145E00878184 /* int-texture256-v5.png */,
|
||||
D40FD5FC164B0D2800878184 /* int-texture256-v4.png */,
|
||||
D40FD5FA164AF1A700878184 /* int-texture256-v2.png */,
|
||||
F68135B01649EF37003040E3 /* grayson-particle.png */,
|
||||
F68135951649CF38003040E3 /* sphere.png */,
|
||||
|
|
Binary file not shown.
|
@ -8,11 +8,11 @@
|
|||
ignoreCount = "0"
|
||||
continueAfterRunningActions = "No"
|
||||
filePath = "main.cpp"
|
||||
timestampString = "374006988.485904"
|
||||
timestampString = "374020144.685254"
|
||||
startingColumnNumber = "9223372036854775807"
|
||||
endingColumnNumber = "9223372036854775807"
|
||||
startingLineNumber = "324"
|
||||
endingLineNumber = "324"
|
||||
startingLineNumber = "320"
|
||||
endingLineNumber = "320"
|
||||
landmarkName = "init(void)"
|
||||
landmarkType = "7">
|
||||
</FileBreakpoint>
|
||||
|
|
166
main.cpp
166
main.cpp
|
@ -116,7 +116,7 @@ ParticleSystem balls(10,
|
|||
#define RENDER_FRAME_MSECS 10
|
||||
#define SLEEP 0
|
||||
|
||||
#define NUM_TRIS 50000 // 20000 //000
|
||||
#define NUM_TRIS 100000
|
||||
struct {
|
||||
float vertices[NUM_TRIS * 3];
|
||||
float normals [NUM_TRIS * 3];
|
||||
|
@ -127,7 +127,6 @@ struct {
|
|||
int element[NUM_TRIS];
|
||||
}tris;
|
||||
|
||||
float twiddles[NUM_TRIS * 9];
|
||||
|
||||
float yaw =0.f; // The yaw, pitch for the avatar head
|
||||
float pitch = 0.f; //
|
||||
|
@ -153,8 +152,9 @@ int noise_on = 0; // Whether to add random noise
|
|||
float noise = 1.0; // Overall magnitude scaling for random noise levels
|
||||
|
||||
int step_on = 0;
|
||||
int display_levels = 1;
|
||||
int display_levels = 0;
|
||||
int display_head = 0;
|
||||
int display_hand = 0;
|
||||
int display_field = 0;
|
||||
|
||||
int display_head_mouse = 1; // Display sample mouse pointer controlled by head movement
|
||||
|
@ -200,10 +200,11 @@ double elapsedTime;
|
|||
// 1. Add to the XCode project in the Resources/images group
|
||||
// (ensure "Copy file" is checked
|
||||
// 2. Add to the "Copy files" build phase in the project
|
||||
char texture_filename[] = "int-texture256-v2.png";
|
||||
char texture_filename[] = "int-texture256-v4.png";
|
||||
unsigned int texture_width = 256;
|
||||
unsigned int texture_height = 256;
|
||||
|
||||
|
||||
float particle_attenuation_quadratic[] = { 0.0f, 0.0f, 2.0f }; // larger Z = smaller particles
|
||||
|
||||
|
||||
|
@ -227,7 +228,7 @@ void Timer(int extra)
|
|||
void display_stats(void)
|
||||
{
|
||||
// bitmap chars are about 10 pels high
|
||||
char legend[] = "/ - toggle this display, Q - exit, N - toggle noise, M - toggle map, T - test audio";
|
||||
char legend[] = "/ - toggle this display, Q - exit, H - show head, M - show hand, T - test audio";
|
||||
drawtext(10, 15, 0.10, 0, 1.0, 0, legend);
|
||||
|
||||
char stats[200];
|
||||
|
@ -235,6 +236,7 @@ void display_stats(void)
|
|||
FPS, ping_msecs, packets_per_second, bytes_per_second);
|
||||
drawtext(10, 30, 0.10, 0, 1.0, 0, stats);
|
||||
|
||||
/*
|
||||
char adc[200];
|
||||
sprintf(adc, "pitch_rate = %i, yaw_rate = %i, accel_lat = %i, accel_fwd = %i, loc[0] = %3.1f loc[1] = %3.1f, loc[2] = %3.1f",
|
||||
(int)(adc_channels[0] - avg_adc_channels[0]),
|
||||
|
@ -244,6 +246,7 @@ void display_stats(void)
|
|||
location[0], location[1], location[2]
|
||||
);
|
||||
drawtext(10, 50, 0.10, 0, 1.0, 0, adc);
|
||||
*/
|
||||
|
||||
}
|
||||
|
||||
|
@ -307,41 +310,22 @@ void init(void)
|
|||
tris.vertices[i*3] = verts[j].x;
|
||||
tris.vertices[i*3 + 1] = verts[j].y;
|
||||
tris.vertices[i*3 + 2] = verts[j].z;
|
||||
|
||||
// reuse pos for the normal
|
||||
glm::normalize((pos += glm::cross(verts[1] - verts[0], verts[2] - verts[0])));
|
||||
tris.normals[i*3] = pos.x;
|
||||
tris.normals[i*3+1] = pos.y;
|
||||
tris.normals[i*3+2] = pos.z;
|
||||
|
||||
// Decide what kind of element this particle is to be, color accordingly
|
||||
if (randFloat() < 0.10)
|
||||
{
|
||||
// Fixed - blue
|
||||
tris.element[i] = 0;
|
||||
tris.colors[i*3] = 0.0; tris.colors[i*3+1] = 0.0; tris.colors[i*3+2] = 1.0;
|
||||
tris.vel[i*3] = tris.vel[i*3+1] = tris.vel[i*3+2] = 0.0;
|
||||
}
|
||||
else
|
||||
{
|
||||
// Moving - white
|
||||
tris.element[i] = 1;
|
||||
tris.colors[i*3] = 1.0; tris.colors[i*3+1] = 1.0; tris.colors[i*3+2] = 1.0;
|
||||
tris.vel[i*3] = (randFloat() - 0.5)*VEL_SCALE;
|
||||
tris.vel[i*3+1] = (randFloat() - 0.5)*VEL_SCALE;
|
||||
tris.vel[i*3+2] = (randFloat() - 0.5)*VEL_SCALE;
|
||||
|
||||
}
|
||||
// Moving - white
|
||||
tris.element[i] = 1;
|
||||
tris.colors[i*3] = 1.0; tris.colors[i*3+1] = 1.0; tris.colors[i*3+2] = 1.0;
|
||||
tris.vel[i*3] = (randFloat() - 0.5)*VEL_SCALE;
|
||||
tris.vel[i*3+1] = (randFloat() - 0.5)*VEL_SCALE;
|
||||
tris.vel[i*3+2] = (randFloat() - 0.5)*VEL_SCALE;
|
||||
|
||||
}
|
||||
|
||||
const float TWIDDLE_SCALE = 0.01;
|
||||
for (i = 0; i < NUM_TRIS; i++)
|
||||
{
|
||||
twiddles[i*3] = (randFloat() - 0.5)*TWIDDLE_SCALE;
|
||||
twiddles[i*3 + 1] = (randFloat() - 0.5)*TWIDDLE_SCALE;
|
||||
twiddles[i*3 + 2] = (randFloat() - 0.5)*TWIDDLE_SCALE;
|
||||
}
|
||||
|
||||
if (serial_on)
|
||||
{
|
||||
// Call readsensors for a while to get stable initial values on sensors
|
||||
|
@ -378,7 +362,7 @@ const float SCALE_Y = 1.f;
|
|||
|
||||
void update_tris()
|
||||
{
|
||||
int i;
|
||||
int i, j;
|
||||
float field_val[3];
|
||||
|
||||
for (i = 0; i < NUM_TRIS; i++)
|
||||
|
@ -410,18 +394,14 @@ void update_tris()
|
|||
}
|
||||
|
||||
// bounce at edge of world
|
||||
// X-Direction
|
||||
if ((tris.vertices[i*3+0] > WORLD_SIZE) || (tris.vertices[i*3+0] < 0.0))
|
||||
tris.vel[i*3]*= -1.0;
|
||||
// Y-direction
|
||||
if ((tris.vertices[i*3+1] > WORLD_SIZE) || (tris.vertices[i*3+1] < 0.0))
|
||||
{
|
||||
tris.vel[i*3+1]*= -1.0;
|
||||
for (j=0; j < 3; j++) {
|
||||
if ((tris.vertices[i*3+j] > WORLD_SIZE) || (tris.vertices[i*3+j] < 0.0)) {
|
||||
tris.vertices[i*3+j] = min(WORLD_SIZE, tris.vertices[i*3+j]);
|
||||
tris.vertices[i*3+j] = max(0.f, tris.vertices[i*3+j]);
|
||||
tris.vel[i*3 + j]*= -1.0;
|
||||
}
|
||||
}
|
||||
// Z-Direction
|
||||
if ((tris.vertices[i*3+2] > WORLD_SIZE) || (tris.vertices[i*3+2] < 0.0))
|
||||
tris.vel[i*3+2]*= -1.0;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void reset_sensors()
|
||||
|
@ -594,37 +574,10 @@ void display(void)
|
|||
glRotatef(render_pitch, 1, 0, 0);
|
||||
glRotatef(render_yaw, 0, 1, 0);
|
||||
glTranslatef(location[0], location[1], location[2]);
|
||||
|
||||
//glEnable(GL_DEPTH_TEST);
|
||||
// TEST: Draw a reference object in world space coordinates!
|
||||
//glPushMatrix();
|
||||
// glTranslatef(1,0,0);
|
||||
//glTranslatef(myHead.getPos().x, myHead.getPos().y, myHead.getPos().z);
|
||||
// glColor3f(1,0,0);
|
||||
// glutSolidCube(0.4);
|
||||
//glPopMatrix();
|
||||
|
||||
// TEST: Draw a textured square (Yoz)
|
||||
|
||||
/* create a square on the XY
|
||||
note that OpenGL origin is at the lower left
|
||||
but texture origin is at upper left
|
||||
=> it has to be mirrored */
|
||||
|
||||
int error = load_png_as_texture(texture_filename, texture_width, texture_height);
|
||||
glEnable(GL_TEXTURE_2D);
|
||||
glBegin(GL_QUADS);
|
||||
glNormal3f(0.0, 0.0, 1.0);
|
||||
glTexCoord2d(1, 1); glVertex3f(0.0, 0.0, 0.0);
|
||||
glTexCoord2d(1, 0); glVertex3f(0.0, 2.0, 0.0);
|
||||
glTexCoord2d(0, 0); glVertex3f(1.0, 2.0, 0.0);
|
||||
glTexCoord2d(0, 1); glVertex3f(1.0, 0.0, 0.0);
|
||||
glEnd();
|
||||
glDisable(GL_TEXTURE_2D);
|
||||
|
||||
|
||||
// Draw Point Sprites
|
||||
|
||||
load_png_as_texture(texture_filename);
|
||||
|
||||
/* assuming you have setup a 32-bit RGBA texture with a legal name */
|
||||
glActiveTexture(GL_TEXTURE0);
|
||||
glEnable( GL_TEXTURE_2D );
|
||||
|
@ -643,39 +596,21 @@ void display(void)
|
|||
{
|
||||
for (i = 0; i < NUM_TRIS; i++)
|
||||
{
|
||||
// glColor3f(tris.colors[i*3],
|
||||
// tris.colors[i*3+1],
|
||||
// tris.colors[i*3+2]);
|
||||
// for (j = 0; j < 3; j++)
|
||||
// {
|
||||
// glVertex3f(tris.vertices[i*9 + j*3],
|
||||
// tris.vertices[i*9 + j*3 + 1],
|
||||
// tris.vertices[i*9 + j*3 + 2]);
|
||||
// }
|
||||
// glNormal3f(tris.normals[i*3],
|
||||
// tris.normals[i*3 + 1],
|
||||
// tris.normals[i*3 + 2]);
|
||||
glVertex3f(tris.vertices[i*3],
|
||||
tris.vertices[i*3+1],
|
||||
tris.vertices[i*3+2]);
|
||||
|
||||
}
|
||||
}
|
||||
glEnd();
|
||||
glDisable( GL_TEXTURE_2D );
|
||||
glDisable( GL_POINT_SPRITE_ARB );
|
||||
|
||||
// Show field vectors
|
||||
if (display_field) field_render();
|
||||
|
||||
|
||||
if (display_head) myHead.render();
|
||||
|
||||
// Display floating head in front of viewer
|
||||
if (display_head)
|
||||
{
|
||||
myHead.render();
|
||||
}
|
||||
myHand.render();
|
||||
if (display_hand) myHand.render();
|
||||
|
||||
|
||||
// balls.render();
|
||||
|
||||
|
@ -692,13 +627,14 @@ void display(void)
|
|||
glDisable(GL_DEPTH_TEST);
|
||||
glDisable(GL_LIGHTING);
|
||||
|
||||
drawvec3(100, 100, 0.15, 0, 1.0, 0, myHead.getPos(), 0, 1, 0);
|
||||
//drawvec3(100, 100, 0.15, 0, 1.0, 0, myHead.getPos(), 0, 1, 0);
|
||||
|
||||
if (mouse_pressed == 1)
|
||||
{
|
||||
glPointSize(20.f);
|
||||
glColor3f(1,1,1);
|
||||
glEnable(GL_POINT_SMOOTH);
|
||||
glEnable( GL_POINT_SPRITE_ARB );
|
||||
glBegin(GL_POINTS);
|
||||
glVertex2f(target_x, target_y);
|
||||
glEnd();
|
||||
|
@ -778,7 +714,10 @@ void key(unsigned char k, int x, int y)
|
|||
|
||||
}
|
||||
if (k == 'h') display_head = !display_head;
|
||||
if (k == 'm') display_hand = !display_hand;
|
||||
if (k == 'f') display_field = !display_field;
|
||||
if (k == 'l') display_levels = !display_levels;
|
||||
|
||||
if (k == 'e') location[1] -= WORLD_SIZE/100.0;
|
||||
if (k == 'c') location[1] += WORLD_SIZE/100.0;
|
||||
if (k == 'w') fwd_vel += 0.05;
|
||||
|
@ -975,42 +914,3 @@ int main(int argc, char** argv)
|
|||
return EXIT_SUCCESS;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
//Create the texture using the hard-coded bitmap data
|
||||
glTexImage2D(GL_TEXTURE_2D,0,3,Img.GetWidth(),Img.GetHeight(),0,GL_RGB,GL_UNSIGNED_BYTE,Img.GetImg());
|
||||
//Set the magnification and minimization filtering to GL_NEAREST
|
||||
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
|
||||
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
|
||||
|
||||
// Trails - Draw a single Quad to blend instead of clear screen
|
||||
glColor4f(0.f, 0.f, 0.f, 0.9f); //glColor4f(0.f, 0.f, 0.f, 0.01f);
|
||||
//glEnable(GL_TEXTURE_2D); //Enable the texture to draw the polygon
|
||||
glBegin(GL_QUADS);
|
||||
glTexCoord2f(0, 1); glVertex2f(0.f, HEIGHT);
|
||||
glTexCoord2f(1, 1); glVertex2f(WIDTH, HEIGHT);
|
||||
glTexCoord2f(1, 0); glVertex2f( WIDTH,0.f);
|
||||
glTexCoord2f(0, 0); glVertex2f(0.f,0.f);
|
||||
glEnd();
|
||||
//glDisable(GL_TEXTURE_2D);
|
||||
|
||||
//glTexCoord2f(1, 0); glVertex2f(1, -1);
|
||||
//glTexCoord2f(1, 1); glVertex2f(1,1);
|
||||
//glTexCoord2f(0, 1); glVertex2f(-1, 1);
|
||||
|
||||
|
||||
// But totally clear stats display area
|
||||
glBegin(GL_QUADS);
|
||||
glColor4f(0.f, 0.f, 0.f, 1.f);
|
||||
glVertex2f(0.f, HEIGHT/10.f);
|
||||
glVertex2f(WIDTH, HEIGHT/10.f);
|
||||
glVertex2f( WIDTH,0.f);
|
||||
glVertex2f(0.f,0.f);
|
||||
|
||||
glVertex2f(0.f, HEIGHT);
|
||||
glVertex2f(WIDTH/20.f, HEIGHT);
|
||||
glVertex2f( WIDTH/20.f,0.f);
|
||||
glVertex2f(0.f,0.f);
|
||||
glEnd();
|
||||
|
||||
*/
|
||||
|
|
|
@ -20,9 +20,12 @@
|
|||
#define TEXTURE_LOAD_ERROR 0
|
||||
|
||||
|
||||
int load_png_as_texture(char* filename, unsigned int width, unsigned int height)
|
||||
int load_png_as_texture(char* filename)
|
||||
{
|
||||
std::vector<unsigned char> image;
|
||||
// width and height will be read from the file at the start
|
||||
// and loaded into these vars
|
||||
unsigned int width = 1, height = 1;
|
||||
unsigned error = lodepng::decode(image, width, height, filename);
|
||||
if (error) {
|
||||
return (int) error;
|
||||
|
|
|
@ -16,6 +16,6 @@
|
|||
#include <GL/glut.h>
|
||||
#endif
|
||||
|
||||
int load_png_as_texture(char* filename, unsigned int width, unsigned int height);
|
||||
int load_png_as_texture(char* filename);
|
||||
|
||||
#endif /* defined(__interface__texture__) */
|
||||
|
|
Loading…
Reference in a new issue