#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
#define _USE_MATH_DEFINES
#include <math.h>
#ifdef __APPLE__
#include <GLUT/glut.h>
#else
#include <GL/glut.h>
#endif
#define DEGRAD 57.295779513
#define K 1024
#define MAXTICKS 60
typedef struct viewer {
GLfloat x, y, z;
GLfloat theta, phi;
GLfloat vx, vy, vz;
} VIEWER;
typedef struct monstertype {
GLfloat x, y, z;
GLfloat heading;
GLfloat leftleg, rightleg;
} MONSTER;
typedef struct actiontype {
GLfloat startangle;
GLfloat angle[MAXTICKS];
GLfloat slope[MAXTICKS];
int currentphase;
} ACTION;
ACTION kick;
int automode = 0;
GLfloat pos1[] = { 1.0, 3.0, 4.0, 1.0 };
GLfloat pos2[] = { -1.0, 3.0, 4.0, 1.0 };
GLfloat amb[] = { 0.5, 0.5, 0.5, 1.0 };
GLfloat dif[] = { 0.5, 0.5, 0.5, 1.0 };
GLfloat spe[] = { 0.9, 0.9, 0.9, 1.0 };
GLfloat matamb[] = { 0.30, 0.30, 0.30, 1.0 };
GLfloat matdif[] = { 0.50, 0.50, 0.50, 1.0 };
GLfloat matspe[] = { 0.10, 0.10, 0.10, 1.0 };
GLfloat objamb[] = { 0.60, 0.10, 0.10, 1.0 };
GLfloat objdif[] = { 0.10, 0.10, 0.10, 1.0 };
GLfloat objspe[] = { 0.10, 0.10, 0.80, 1.0 };
GLUquadric *body;
MONSTER bob;
double pov;
VIEWER moi;
int xOrigin = 0;
int yOrigin = 0;
int lastx = 400;
int lasty = 300;
void display();
void animate();
void reshape(int w, int h);
void arrows(int c, int x, int y);
void keyboard(unsigned char c, int x, int y);
void blocks(int x, int y, int z);
void move_viewer(int dir);
//non-functional
void mouseMove(int x, int y);
void init();
void update_viewer();
void monster(MONSTER *p);
int main(int argc, char *argv[])
{
pov
= (argc
== 1) ? 60.0 : atof(argv
[1]); glutInit(&argc, argv);
glutInitWindowSize(800, 600);
glutInitWindowPosition(400, 100);
glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGBA | GLUT_DEPTH);
glutCreateWindow("V0.1");
glutKeyboardFunc(keyboard);
glutDisplayFunc(display);
glutSpecialFunc(arrows);
glutReshapeFunc(reshape);
glutIdleFunc(animate);
// mouse func's
glutSetCursor(GLUT_CURSOR_CROSSHAIR);
glutPassiveMotionFunc(mouseMove);
init();
display();
glutMainLoop();
}
void move_viewer(int dir)
{
GLfloat tx, tz, tt;
int k;
/* for forward and backward movement */
switch (dir){
case 1:
//tx = moi.x + moi.vx;
//tz = moi.z + moi.vz;
moi.x += moi.vx;
moi.z += moi.vz;
break;
case 2:
tt = moi.theta;
moi.theta -= 90.0;
moi.x += moi.vx;
moi.z += moi.vz;
moi.theta = tt;
break;
case 3:
tt = moi.theta;
moi.theta += 90.0;
moi.x += moi.vx*1.0;
moi.z += moi.vz*1.0;
moi.theta = tt;
break;
case 4:
//tx = moi.x - moi.vx;
//tz = moi.z - moi.vz;
moi.x -= moi.vx;
moi.z -= moi.vz;
break;
}
pos1[0] = moi.x;
pos1[1] = moi.y;
pos1[2] = moi.z;
glLightfv(GL_LIGHT0, GL_POSITION, pos1);
}
void keyboard(unsigned char c, int x, int y)
{
switch (c){
case 27: /* escape key */
case 'w':
move_viewer(1);
break;
case 's':
move_viewer(4);
break;
case 'a':
move_viewer(2);
break;
case 'd':
move_viewer(3);
break;
case 'r':
if (!automode){
automode = 1;
kick.currentphase = 0;
}
break;
}
update_viewer();
glutPostRedisplay();
}
void mouseMove(int x, int y)
{
// update the angles
int diffx = x - lastx;
int diffy = y - lasty;
lastx = x;
lasty = y;
moi.phi = ((diffy *2) - y) * 0.001f;
moi.theta = ((diffx*2) - x) * 0.001f;
/*moi.phi += diffx;
moi.theta += diffy;*/
// update camera's direction
update_viewer();
glutPostRedisplay();
// put new directions back into the origins
yOrigin = moi.phi;
xOrigin = moi.theta;
}
void arrows(int c, int x, int y)
{
switch (c){
case GLUT_KEY_LEFT:
break;
case GLUT_KEY_UP:
moi.phi += 0.1;
break;
case GLUT_KEY_DOWN:
moi.phi -= 0.1;
break;
case GLUT_KEY_RIGHT:
bob.heading -= 5.0;
break;
}
update_viewer();
glutPostRedisplay();
}
void reshape(int w, int h)
{
glViewport(0, 0, w, h);
glMatrixMode(GL_PROJECTION);
glLoadIdentity();
gluPerspective(pov, (GLdouble)w / (GLdouble)h, 0.001, 50.0);
glMatrixMode(GL_MODELVIEW);
}
void init_action(ACTION *p)
{
int i;
p->startangle = 0.0;
for (i = 0; i<MAXTICKS; i++)
p->slope[i] = (i < MAXTICKS / 3) ? 4.0 : -2.0;
p->angle[0] = p->startangle;
for (i = 1; i<MAXTICKS; i++)
p->angle[i] = p->angle[i - 1] + p->slope[i];
p->currentphase = 0;
}
void init_monster(MONSTER *p)
{
memset(p
, 0, sizeof(MONSTER
)); }
void init()
{
moi.x = 0.0;
moi.y = 2.5;
moi.z = 5.0;
pos1[0] = moi.x;
pos1[1] = moi.y;
pos1[2] = moi.z;
moi.theta = -M_PI / 2.0;
moi.phi = 0.0;
automode = 0;
glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGB | GLUT_DEPTH);
update_viewer();
glEnable(GL_LIGHTING);
glEnable(GL_DEPTH_TEST);
glEnable(GL_TEXTURE_2D);
glEnable(GL_LIGHT0);
glEnable(GL_LIGHT1);
glLightfv(GL_LIGHT0, GL_POSITION, pos1);
glLightfv(GL_LIGHT0, GL_AMBIENT, amb);
glLightfv(GL_LIGHT0, GL_DIFFUSE, dif);
glLightfv(GL_LIGHT0, GL_SPECULAR, spe);
glLightfv(GL_LIGHT0, GL_POSITION, pos2);
glLightfv(GL_LIGHT0, GL_AMBIENT, amb);
glLightfv(GL_LIGHT0, GL_DIFFUSE, dif);
glLightfv(GL_LIGHT0, GL_SPECULAR, spe);
body = gluNewQuadric();
gluQuadricDrawStyle(body, GLU_LINE);
init_monster(&bob);
init_action(&kick);
}
void animate()
{
int n;
if (!automode)
return;
fprintf(stderr
, "made it to animate!\n"); n = kick.currentphase++;
if (n >= MAXTICKS){
automode = 0;
bob.rightleg = kick.startangle;
}
else {
bob.rightleg = kick.angle[n];
}
update_viewer();
glutPostRedisplay();
}
void update_viewer()
{
}
void display()
{
int i, j, k, u, v;
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
glLineWidth(2.0);
glLoadIdentity();
gluLookAt(moi.x, moi.y, moi.z,
moi.x + moi.vx, moi.y + moi.vy, moi.z + moi.vz,
0.0, 1.0, 0.0);
/* blocks(x,y,z) */
for (i = -10; i < 20; i++){
for (k = -10; k < 20; k++){
if (v % 2 == 0){
glColor3f(1.0f, 1.0f, 1.0f);
}
else{
glColor3f(0.1f, 0.9f, 0.2f);
}
blocks(i, 0, k);
}
}
//monster(&bob);
glutSwapBuffers();
}
void blocks(int x, int y, int z)
{
/* floor blocks */
// glMaterialfv(GL_FRONT_AND_BACK, GL_AMBIENT, matamb);
// glMaterialfv(GL_FRONT_AND_BACK, GL_DIFFUSE, matdif);
// glMaterialfv(GL_FRONT_AND_BACK, GL_SPECULAR, matspe);
// glMaterialf(GL_FRONT_AND_BACK, GL_SHININESS, 50.0);
glBegin(GL_LINE_STRIP);
/* top of block */
glVertex3f(x, y+1.0, z);
glVertex3f(x+1.0, y+1.0, z);
glVertex3f(x+1.0, y+1.0, z+1.0);
glVertex3f(x, y+1.0, z+1.0);
glEnd();
/* left of block */
glBegin(GL_LINE_STRIP);
glVertex3f(x, y+1.0, z);
glVertex3f(x, y, z);
glVertex3f(x, y, z+1.0);
glVertex3f(x, y + 1.0, z + 1.0);
glEnd();
/* right of block */
glBegin(GL_LINE_STRIP);
glVertex3f(x+1.0, y+1.0, z);
glVertex3f(x+1.0, y, z);
glVertex3f(x+1.0, y, z+1.0);
glVertex3f(x+1.0, y+1.0, z+1.0);
glEnd();
/* front of block */
glBegin(GL_LINE_STRIP);
glVertex3f(x, y+1.0, z);
glVertex3f(x, y, z);
glVertex3f(x+1.0, y, z);
glVertex3f(x+1.0, y+1.0, z);
glEnd();
/* back of block */
glBegin(GL_LINE_STRIP);
glVertex3f(x, y+1.0, z+1.0);
glVertex3f(x, y, z+1.0);
glVertex3f(x+1.0, y, z+1.0);
glVertex3f(x+1.0, y+1.0, z+1.0);
glEnd();
/* bottom of block */
glBegin(GL_LINE_STRIP);
glVertex3f(x, y, z);
glVertex3f(x+1.0, y, z);
glVertex3f(x+1.0, y, z+1.0);
glVertex3f(x, y, z+1.0);
glEnd();
}
void monster(MONSTER *p)
{
glPushMatrix();
glMaterialfv(GL_FRONT_AND_BACK, GL_AMBIENT, objamb);
glMaterialfv(GL_FRONT_AND_BACK, GL_DIFFUSE, objdif);
glMaterialfv(GL_FRONT_AND_BACK, GL_SPECULAR, objspe);
glMaterialf(GL_FRONT_AND_BACK, GL_SHININESS, 10.0);
glRotatef(bob.heading, 0.0, 1.0, 0.0);
glRotatef(-90.0, 1.0, 0.0, 0.0);
/* torso and head*/
glPushMatrix();
glTranslatef(0.0, 0.0, 2.5);
gluSphere(body, 0.5, 12, 12);
glTranslatef(0.0, 0.0, -1.5);
glScalef(0.5, 1.0, 1.0);
gluCylinder(body, 0.2, 0.3, 1.0, 12, 12);
glPopMatrix();
/* legs */
glPushMatrix();
glTranslatef(0.0, 0.1, 1.0);
glRotatef(p->rightleg, 0.0, 1.0, 0.0);
glTranslatef(0.0, 0.0, -1.0);
gluCylinder(body, 0.05, 0.05, 1.0, 12, 12);
glPopMatrix();
glTranslatef(0.0, -0.1, 0.0);
gluCylinder(body, 0.05, 0.05, 1.0, 12, 12);
glPopMatrix();
}
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
#define _USE_MATH_DEFINES
#include <math.h>

#ifdef __APPLE__
#include <GLUT/glut.h>
#else
#include <GL/glut.h>
#endif

#define DEGRAD        57.295779513
#define K           1024

#define MAXTICKS      60

typedef struct viewer {
	GLfloat x, y, z;
	GLfloat theta, phi;
	GLfloat vx, vy, vz;
} VIEWER;

typedef struct monstertype {
	GLfloat x, y, z;
	GLfloat heading;
	GLfloat leftleg, rightleg;
} MONSTER;

typedef struct actiontype {
	GLfloat startangle;
	GLfloat angle[MAXTICKS];
	GLfloat slope[MAXTICKS];
	int currentphase;
} ACTION;

ACTION kick;

int automode = 0;

GLfloat pos1[] = { 1.0, 3.0, 4.0, 1.0 };
GLfloat pos2[] = { -1.0, 3.0, 4.0, 1.0 };
GLfloat amb[] = { 0.5, 0.5, 0.5, 1.0 };
GLfloat dif[] = { 0.5, 0.5, 0.5, 1.0 };
GLfloat spe[] = { 0.9, 0.9, 0.9, 1.0 };

GLfloat matamb[] = { 0.30, 0.30, 0.30, 1.0 };
GLfloat matdif[] = { 0.50, 0.50, 0.50, 1.0 };
GLfloat matspe[] = { 0.10, 0.10, 0.10, 1.0 };

GLfloat objamb[] = { 0.60, 0.10, 0.10, 1.0 };
GLfloat objdif[] = { 0.10, 0.10, 0.10, 1.0 };
GLfloat objspe[] = { 0.10, 0.10, 0.80, 1.0 };

GLUquadric *body;
MONSTER bob;

double pov;
VIEWER moi;
int xOrigin = 0;
int yOrigin = 0;
int lastx = 400;
int lasty = 300;

void display();
void animate();
void reshape(int w, int h);
void arrows(int c, int x, int y);
void keyboard(unsigned char c, int x, int y);
void blocks(int x, int y, int z);
void move_viewer(int dir);
//non-functional
void mouseMove(int x, int y);

void init();
void update_viewer();
void monster(MONSTER *p);

int main(int argc, char *argv[])
{
	srand(time(NULL));
	pov = (argc == 1) ? 60.0 : atof(argv[1]);
	glutInit(&argc, argv);
	glutInitWindowSize(800, 600);
	glutInitWindowPosition(400, 100);

	glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGBA | GLUT_DEPTH);
	glutCreateWindow("V0.1");

	glutKeyboardFunc(keyboard);
	glutDisplayFunc(display);
	glutSpecialFunc(arrows);
	glutReshapeFunc(reshape);
	glutIdleFunc(animate);

	// mouse func's
	glutSetCursor(GLUT_CURSOR_CROSSHAIR);
	glutPassiveMotionFunc(mouseMove);

	init();
	display();

	glutMainLoop();
}
void move_viewer(int dir)
{
	GLfloat tx, tz, tt;
	int k;

	/* for forward and backward movement */
	switch (dir){
	case 1:
		//tx = moi.x + moi.vx;
		//tz = moi.z + moi.vz;
		moi.x += moi.vx;
		moi.z += moi.vz;
		break;
	case 2:
		tt = moi.theta;
		moi.theta -= 90.0;
		moi.vx = cos(moi.theta);
		moi.vz = sin(moi.theta);
		moi.x += moi.vx;
		moi.z += moi.vz;
		moi.theta = tt;
		break;
	case 3:
		tt = moi.theta;
		moi.theta += 90.0;
		moi.vx = cos(moi.theta);
		moi.vz = sin(moi.theta);
		moi.x += moi.vx*1.0;
		moi.z += moi.vz*1.0;
		moi.theta = tt;
		break;
	case 4:
		//tx = moi.x - moi.vx;
		//tz = moi.z - moi.vz;
		moi.x -= moi.vx;
		moi.z -= moi.vz;
		break;
	}

	pos1[0] = moi.x;
	pos1[1] = moi.y;
	pos1[2] = moi.z;
	glLightfv(GL_LIGHT0, GL_POSITION, pos1);
}
void keyboard(unsigned char c, int x, int y)
{
	switch (c){
	case 27:  /* escape key */
		exit(0);
	case 'w':
		move_viewer(1);
		break;
	case 's':
		move_viewer(4);
		break;
	case 'a':
		move_viewer(2);
		break;
	case 'd':
		move_viewer(3);
		break;
	case 'r':
		if (!automode){
			automode = 1;
			kick.currentphase = 0;
		}
		break;
	}
	update_viewer();
	glutPostRedisplay();
}
void mouseMove(int x, int y) 
{


	// update the angles
	int diffx = x - lastx;
	int diffy = y - lasty;
	lastx = x;
	lasty = y;
	
	
	moi.phi = ((diffy *2) - y) * 0.001f;
	moi.theta = ((diffx*2) - x) * 0.001f;

	/*moi.phi += diffx;
	moi.theta += diffy;*/
	// update camera's direction
	update_viewer();
	glutPostRedisplay();
	// put new directions back into the origins
	yOrigin = moi.phi;
	xOrigin = moi.theta;

}
void arrows(int c, int x, int y)
{
	switch (c){
	case GLUT_KEY_LEFT:
		break;
	case GLUT_KEY_UP:
		moi.phi += 0.1;
		break;
	case GLUT_KEY_DOWN:
		moi.phi -= 0.1;
		break;
	case GLUT_KEY_RIGHT:
		bob.heading -= 5.0;
		break;
	}
	update_viewer();
	glutPostRedisplay();
}
void reshape(int w, int h)
{
	glViewport(0, 0, w, h);
	glMatrixMode(GL_PROJECTION);
	glLoadIdentity();
	gluPerspective(pov, (GLdouble)w / (GLdouble)h, 0.001, 50.0);
	glMatrixMode(GL_MODELVIEW);
}
void init_action(ACTION *p)
{
	int i;

	p->startangle = 0.0;
	for (i = 0; i<MAXTICKS; i++)
		p->slope[i] = (i < MAXTICKS / 3) ? 4.0 : -2.0;
	p->angle[0] = p->startangle;
	for (i = 1; i<MAXTICKS; i++)
		p->angle[i] = p->angle[i - 1] + p->slope[i];
	p->currentphase = 0;
}
void init_monster(MONSTER *p)
{
	memset(p, 0, sizeof(MONSTER));
}
void init()
{
	moi.x = 0.0;
	moi.y = 2.5;
	moi.z = 5.0;
	pos1[0] = moi.x;
	pos1[1] = moi.y; 
	pos1[2] = moi.z;
	moi.theta = -M_PI / 2.0;
	moi.phi = 0.0;

	automode = 0;
	glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGB | GLUT_DEPTH);
	update_viewer();

	glEnable(GL_LIGHTING);
	glEnable(GL_DEPTH_TEST);
	glEnable(GL_TEXTURE_2D);
	glEnable(GL_LIGHT0);
	glEnable(GL_LIGHT1);

	glLightfv(GL_LIGHT0, GL_POSITION, pos1);
	glLightfv(GL_LIGHT0, GL_AMBIENT, amb);
	glLightfv(GL_LIGHT0, GL_DIFFUSE, dif);
	glLightfv(GL_LIGHT0, GL_SPECULAR, spe);

	glLightfv(GL_LIGHT0, GL_POSITION, pos2);
	glLightfv(GL_LIGHT0, GL_AMBIENT, amb);
	glLightfv(GL_LIGHT0, GL_DIFFUSE, dif);
	glLightfv(GL_LIGHT0, GL_SPECULAR, spe);

	body = gluNewQuadric();
	gluQuadricDrawStyle(body, GLU_LINE);

	init_monster(&bob);
	init_action(&kick);
}
void animate()
{
	int n;

	if (!automode)
		return;
	fprintf(stderr, "made it to animate!\n");
	n = kick.currentphase++;
	if (n >= MAXTICKS){
		automode = 0;
		bob.rightleg = kick.startangle;
	}
	else {
		bob.rightleg = kick.angle[n];
	}
	update_viewer();
	glutPostRedisplay();
}
void update_viewer()
{
	moi.vx = cos(moi.theta);
	moi.vy = sin(moi.phi);
	moi.vz = sin(moi.theta);
}
void display()
{
	int i, j, k, u, v;

	
	glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
	glLineWidth(2.0);
	glLoadIdentity();

	gluLookAt(moi.x, moi.y, moi.z,
		moi.x + moi.vx, moi.y + moi.vy, moi.z + moi.vz,
		0.0, 1.0, 0.0);

	/* blocks(x,y,z) */
	for (i = -10; i < 20; i++){
		for (k = -10; k < 20; k++){
			v = rand();
			if (v % 2 == 0){
				glColor3f(1.0f, 1.0f, 1.0f);
			}
			else{
				glColor3f(0.1f, 0.9f, 0.2f);
			}
			
			blocks(i, 0, k);
		}
	}

	//monster(&bob);

	glutSwapBuffers();
}
void blocks(int x, int y, int z)
{
	/* floor blocks */

//	glMaterialfv(GL_FRONT_AND_BACK, GL_AMBIENT, matamb);
//	glMaterialfv(GL_FRONT_AND_BACK, GL_DIFFUSE, matdif);
//	glMaterialfv(GL_FRONT_AND_BACK, GL_SPECULAR, matspe);
//	glMaterialf(GL_FRONT_AND_BACK, GL_SHININESS, 50.0);
	glBegin(GL_LINE_STRIP);
	/* top of block */
	glVertex3f(x,     y+1.0, z);
	glVertex3f(x+1.0, y+1.0, z);
	glVertex3f(x+1.0, y+1.0, z+1.0);
	glVertex3f(x,     y+1.0, z+1.0);
	glEnd();
	/* left of block */
	glBegin(GL_LINE_STRIP);
	glVertex3f(x, y+1.0, z);
	glVertex3f(x, y,     z);
	glVertex3f(x, y,     z+1.0);
	glVertex3f(x, y + 1.0, z + 1.0);
	glEnd();
	/* right of block */
	glBegin(GL_LINE_STRIP);
	glVertex3f(x+1.0, y+1.0, z);
	glVertex3f(x+1.0, y,     z);
	glVertex3f(x+1.0, y,     z+1.0);
	glVertex3f(x+1.0, y+1.0, z+1.0);
	glEnd();
	/* front of block */
	glBegin(GL_LINE_STRIP);
	glVertex3f(x,     y+1.0, z);
	glVertex3f(x,     y,     z);
	glVertex3f(x+1.0, y,     z);
	glVertex3f(x+1.0, y+1.0, z);
	glEnd();
	/* back of block */
	glBegin(GL_LINE_STRIP);
	glVertex3f(x,     y+1.0, z+1.0);
	glVertex3f(x,     y,     z+1.0);
	glVertex3f(x+1.0, y,     z+1.0);
	glVertex3f(x+1.0, y+1.0, z+1.0);
	glEnd();
	/* bottom of block */
	glBegin(GL_LINE_STRIP);
	glVertex3f(x,     y, z);
	glVertex3f(x+1.0, y, z);
	glVertex3f(x+1.0, y, z+1.0);
	glVertex3f(x,     y, z+1.0);
	glEnd();
}
void monster(MONSTER *p)
{
	glPushMatrix();

	glMaterialfv(GL_FRONT_AND_BACK, GL_AMBIENT, objamb);
	glMaterialfv(GL_FRONT_AND_BACK, GL_DIFFUSE, objdif);
	glMaterialfv(GL_FRONT_AND_BACK, GL_SPECULAR, objspe);
	glMaterialf(GL_FRONT_AND_BACK, GL_SHININESS, 10.0);

	glRotatef(bob.heading, 0.0, 1.0, 0.0);

	glRotatef(-90.0, 1.0, 0.0, 0.0);

	/* torso and head*/

	glPushMatrix();

	glTranslatef(0.0, 0.0, 2.5);
	gluSphere(body, 0.5, 12, 12);

	glTranslatef(0.0, 0.0, -1.5);
	glScalef(0.5, 1.0, 1.0);
	gluCylinder(body, 0.2, 0.3, 1.0, 12, 12);
	glPopMatrix();

	/* legs */
	glPushMatrix();
	glTranslatef(0.0, 0.1, 1.0);
	glRotatef(p->rightleg, 0.0, 1.0, 0.0);
	glTranslatef(0.0, 0.0, -1.0);
	gluCylinder(body, 0.05, 0.05, 1.0, 12, 12);
	glPopMatrix();

	glTranslatef(0.0, -0.1, 0.0);
	gluCylinder(body, 0.05, 0.05, 1.0, 12, 12);

	glPopMatrix();
}