亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? main.cpp

?? openGL的3D的小球碰撞游戲
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
// ping3D.cpp : Defines the entry point for the console application.
//
//c header files
#include "stdlib.h" 
#include "string.h"
#include "stdio.h"
#include "math.h"
#include "time.h"

//include GLUT header file
#include "glew.h"
#include "glut.h" 
#include "FreeImage.h"
const double PI = 3.14159265358979323846;
int g_frameCount = 0;
GLuint g_displayList = 0;

GLuint tableID;
GLuint courtID;
GLuint lightID;
GLuint shadowID;



//global variables for drawing area size
int g_width = 1000;
int g_height = 1000;

//global camera parameters
double g_eye[3] = {0, 90, 170};
double g_center[3] = {0, 25, 0};
double g_up[3] = {0, 1, 0};

//global color vectors
float g_red[3] = {1.0f, 0.0f, 0.0f};
float g_green[3] = {0.0f, 1.0f, 0.0f};
float g_blue[3] = {0.0f, 0.0f, 1.0f};
float g_white[3] = {1.0f, 1.0f, 1.0f};

//point light
float ambient0[] = {0.2f, 0.2f, 0.6f, 1.0f};
float diffuse0[] = {0.3f, 0.3f, 0.3f, 1.0f};
 float specular0[] = {1.0f, 0.0f, 0.0f, 1.0f};
float  position0[] = {0.0f, 50.0f, 0.0f, 1.0f};

//directional light
float ambient1[] = {0.5f, 0.75f, 0.75f, 1.0f};
float diffuse1[] = {0.0f, 0.75f, 1.0f, 1.0f};
float specular1[] = {0.0f, 1.0f, 1.0f, 1.0f};
float position1[] = {20.0f, 10.0f, 30.0f, 0.0f};

//spot light
float ambient2[] = {0.5f, 0.0f, 0.0f, 1.0f};
float diffuse2[] = {0.25f, 0.75f, 1.0f, 1.0f};
float specular2[] = {1.0f, 0.0f, 0.0f, 1.0f};
float position2[] = {0.0f, 50.0f, 300.0f, 1.0f};
float spotDirection[]={0.0f, 0.0f, -1.0f};
float spotCutOff = 20.0f;
float spotExp = 0.2f;

//global parameters for walls
float g_wallHalfThickness = 2.0f;
float g_blockSize[3] = {100.0f, 100.0f, 100.0f};
float g_wallCenter[6][3];
float g_wallSize[6][3];
float g_wallNormal[6][3];

//global ball parameters
float g_ballPosition[3] = {0.0f, 50.0f, 0.0f};
float g_lastBallPosition[3] = {0.0f, 50.0f, 0.0f};
float g_ballVector[3];
float g_trajectory[3] = {1.5f, 0.6f, -0.7f};

//global ball movement parameters
float g_step = 0.08f;
float g_lastStep = 0.06f;
float g_damper = 0.99645f;
float g_reflect = 0.25f;
float g_maxStep = 0.12f;
float g_minStep = 0.055f;

//global behavior control
bool g_speedControl = false;
bool g_changeColorOnHit = true;
bool g_rotateCamera = false;

//which wall we just hit?
int g_wallHit = -1;

int g_gameOver = 1;
int g_currentGame = 0;
int g_misses = 0;				/* to keep track of the g_misses */
int g_leftButtonState = GLUT_UP;
int g_leftButtonLastX;
int g_leftButtonLastY;
int threshold = 5;

float g_wallHitColor[6][3] = {
    {1.0f, 0.25f, 0.75f},
    {0.0f, 1.0f, 0.0f},
    {0.0f, 0.0f, 1.0f},
    {1.0f, 1.0f, 0.0f},
    {1.0f, 0.0f, 1.0f},
    {0.0f, 1.0f, 1.0f}
};



void LoadTexture(char *pFileName, GLuint texID)
{
    FREE_IMAGE_FORMAT format = FreeImage_GetFileType(pFileName, 0);
	FIBITMAP* image = FreeImage_Load(format, pFileName);
	
	FIBITMAP* temp = image;
	image = FreeImage_ConvertTo32Bits(image);
	FreeImage_Unload(temp);
	
	int w = FreeImage_GetWidth(image);
	int h = FreeImage_GetHeight(image);
	
	GLubyte* texture = new GLubyte[4*w*h];
	char* pixels = (char*)FreeImage_GetBits(image);
	
	
	for(int j= 0; j<w*h; j++)
    {
		texture[j*4+0]= pixels[j*4+2];
		texture[j*4+1]= pixels[j*4+1];
		texture[j*4+2]= pixels[j*4+0];
		texture[j*4+3]= pixels[j*4+3];
	}
	
    FreeImage_Unload(image);

	//Now generate the OpenGL texture object
	glBindTexture(GL_TEXTURE_2D, texID);

//    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP);
//    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_REPEAT);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT);

        glTexImage2D(GL_TEXTURE_2D,0,GL_RGBA, w, h, 0, GL_RGBA,GL_UNSIGNED_BYTE,(GLvoid*)texture );
//        glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
 //       glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
        glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
        glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);

    delete [ ]texture;
}

//GLuint tableID;GLuint courtID;GLuint lightID;GLuint shadowID;
void InitTextures()
{
    glGenTextures(1, &tableID);
    glGenTextures(1, &courtID);
    glGenTextures(1, &lightID);
    glGenTextures(1, &shadowID);

    LoadTexture("table.bmp", tableID);
    LoadTexture("court.bmp", courtID);
    LoadTexture("lightmap.bmp", lightID);
    LoadTexture("shadowmap.bmp", shadowID);
}


void drawString(char* pText, int x, int y)
{
	glRasterPos2i(x, y);
	for (unsigned int i = 0; i < strlen(pText); i++)
		glutBitmapCharacter(GLUT_BITMAP_HELVETICA_18,   pText[i]);
}

//normalize a vector
void normalize(float* v)
{
    float length = v[0] * v[0] + v[1] * v[1] + v[2] * v[2];

    length= sqrtf(length);

    if (length > 0.0f)
    {
        float inv = 1.0f/length;
        v[0] *= inv;
        v[1] *= inv;
        v[2] *= inv;
    }
}

//setup random initial ball movement vector
void initBallVector()
{
    g_ballVector[0] = g_trajectory[0];
    g_ballVector[1] = g_trajectory[1];
    g_ballVector[2] = g_trajectory[2];

    normalize(g_ballVector);
}

//prepare wall coordinates, size and normals
void initWall()
{
    //front
    g_wallCenter[0][0] = 0.0f;
    g_wallCenter[0][1] = g_blockSize[1]*0.5f;
    g_wallCenter[0][2] = g_blockSize[2]*0.5f;

    g_wallSize[0][0] = g_blockSize[0]*0.15f;
    g_wallSize[0][1] = g_blockSize[1]*0.15f;
    g_wallSize[0][2] = g_wallHalfThickness;

    g_wallNormal[0][0] = 0.0f;
    g_wallNormal[0][1] = 0.0f;
    g_wallNormal[0][2] = -1.0f;

    //back
    g_wallCenter[1][0] = 0.0f;
    g_wallCenter[1][1] = g_blockSize[1]*0.5f;
    g_wallCenter[1][2] = -g_blockSize[2]*0.5f;

    g_wallSize[1][0] = g_blockSize[0]*0.5f;
    g_wallSize[1][1] = g_blockSize[1]*0.5f;
    g_wallSize[1][2] = g_wallHalfThickness;

    g_wallNormal[1][0] = 0.0f;
    g_wallNormal[1][1] = 0.0f;
    g_wallNormal[1][2] = 1.0f;

    //left
    g_wallCenter[2][0] = -g_blockSize[0]*0.5f;
    g_wallCenter[2][1] = g_blockSize[1]*0.5f;
    g_wallCenter[2][2] = 0.0f;

    g_wallSize[2][2] = g_blockSize[2]*0.5f;
    g_wallSize[2][1] = g_blockSize[1]*0.5f;
    g_wallSize[2][0] = g_wallHalfThickness;

    g_wallNormal[2][0] = 1.0f;
    g_wallNormal[2][1] = 0.0f;
    g_wallNormal[2][2] = 0.0f;

    //right
    g_wallCenter[3][0] = g_blockSize[0]*0.5f;
    g_wallCenter[3][1] = g_blockSize[1]*0.5f;
    g_wallCenter[3][2] = 0.0f;

    g_wallSize[3][2] = g_blockSize[2]*0.5f;
    g_wallSize[3][1] = g_blockSize[1]*0.5f;
    g_wallSize[3][0] = g_wallHalfThickness;

    g_wallNormal[3][0] = -1.0f;
    g_wallNormal[3][1] = 0.0f;
    g_wallNormal[3][2] = 0.0f;

    //top
    g_wallCenter[4][0] = 0.0f;
    g_wallCenter[4][1] = g_blockSize[1];
    g_wallCenter[4][2] = 0.0f;

    g_wallSize[4][2] = g_blockSize[2]*0.5f;
    g_wallSize[4][0] = g_blockSize[0]*0.5f;
    g_wallSize[4][1] = g_wallHalfThickness;

    g_wallNormal[4][0] = 0.0f;
    g_wallNormal[4][1] = -1.0f;
    g_wallNormal[4][2] = 0.0f;

    //bottom
    g_wallCenter[5][0] = 0.0f;
    g_wallCenter[5][1] = 0.0f;
    g_wallCenter[5][2] = 0.0f;

    g_wallSize[5][2] = g_blockSize[2]*0.5f;
    g_wallSize[5][0] = g_blockSize[0]*0.5f;
    g_wallSize[5][1] = g_wallHalfThickness;

    g_wallNormal[5][0] = 0.0f;
    g_wallNormal[5][1] = 1.0f;
    g_wallNormal[5][2] = 0.0f;
}


void drawBlock3D(float* pCenter, float* pHalfLength)
{
    float vertices[8][3];
	//normals for six quads of each block
	float normals[6][3]={
		{0.0f, 0.0f, -1.0f},
		{0.0f, 0.0f, 1.0f},
		{0.0f, -1.0f, 0.0f},
		{1.0f, 0.0f, 0.0f},
		{-1.0f, 0.0f, 0.0f},
		{0.0f, 1.0f, 0.0f}
	};

    int flags[8][3] = {
        {-1, -1, -1},
        {1, -1, -1},
        {1, 1, -1},
        {-1, 1, -1},

        {-1, -1, 1},
        {1, -1, 1},
        {1, 1, 1},
        {-1, 1, 1}
    };

    //generate 8 vertices based on center position, half length in x, y, z direction, and flags
    for (int i = 0; i < 8; i++)
    {
        vertices[i][0] = pCenter[0] + pHalfLength[0]*flags[i][0];
        vertices[i][1] = pCenter[1] + pHalfLength[1]*flags[i][1];
        vertices[i][2] = pCenter[2] + pHalfLength[2]*flags[i][2];
    }

    //indices of 4 vertices for one quad
    int indices[6][4] = {
        {3, 2, 1, 0},
        {4, 5, 6, 7},
        {0, 1, 5, 4},
        {6, 5, 1, 2},
        {0, 4, 7, 3},
        {7, 6, 2, 3}
    };
	glEnable(GL_BLEND);
	glDepthMask(GL_FALSE);
	glBlendFunc(GL_SRC_ALPHA, GL_ONE);
    float base = sin(g_frameCount*PI/18000.0f) * 0.95;

    //draw 3D block using quads
    glBegin(GL_QUADS);
        for (int i = 0; i < 6; i++)
        {
			glNormal3f(normals[i][0], normals[i][1], normals[i][2]);

             glTexCoord2f(0.0f, 0.0f);
             glVertex3fv(vertices[indices[i][0]]);

		     glTexCoord2f(1.0f + base, 0.0f);
             glVertex3fv(vertices[indices[i][1]]);

			  glTexCoord2f(1.0f + base, 1.0f + base);
            glVertex3fv(vertices[indices[i][2]]);

			glTexCoord2f(0.0f, 1.0f + base);
            glVertex3fv(vertices[indices[i][3]]);
        }
    glEnd();
}




//draw walls
void drawWall()
{
      
        glColor3fv(g_blue);
        glPolygonMode(GL_FRONT_AND_BACK, GL_FILL);
        drawBlock3D(g_wallCenter[0], g_wallSize[0]);

	for (int i = 1; i < 6; i++)
    {
        glColor3fv(g_white);
        glPolygonMode(GL_FRONT_AND_BACK, GL_FILL);

        if (g_wallHit == i && g_changeColorOnHit)
        {
            glColor3fv(g_wallHitColor[g_wallHit]);
            glPolygonMode(GL_FRONT_AND_BACK, GL_FILL);
        }
            
        drawBlock3D(g_wallCenter[i], g_wallSize[i]);
    }
}




//calculate reflection vector r based on incoming vector v and plane normal n
void reflection(float* v, float* n, float* r)
{
    float vDOTn = v[0]*n[0] + v[1]*n[1] + v[2]*n[2];
    
    r[0] = v[0] - 2*vDOTn*n[0];
    r[1] = v[1] - 2*vDOTn*n[1];
    r[2] = v[2] - 2*vDOTn*n[2];

    normalize(r);
}

//calculate point to plane distance
float pointPlaneDistance(float* point, float* planeOrigin, float* planeNormal)
{
    float dist = 0.0f;

    float a, b, c, d;//plane equation: a*x + b*y + c*z + d = 0

    a = planeNormal[0];
    b = planeNormal[1];
    c = planeNormal[2];
    d = -planeNormal[0]*planeOrigin[0] - planeNormal[1]*planeOrigin[1] - planeNormal[2]*planeOrigin[2];

    dist = a*point[0] + b*point[1] + c*point[2] + d;

    return dist;
}

float pointPlaneIntersection(float* p1, float* p2, float* po, float* pn)
{
    float a, b, c, d;//plane equation

    a = pn[0];
    b = pn[1];
    c = pn[2];
    d = -pn[0]*po[0] - pn[1]*po[1] - pn[2]*po[2];

	 float u, denominator;
    
    u = (a*p1[0] + b*p1[1] + c*p1[2] + d);
    denominator = a*(p1[0] - p2[0]) + b*(p1[1] - p2[1]) + c*(p1[2] - p2[2]);

    if (fabs(denominator) > 0.00001f)
        return u/denominator;
    else
        return -1.0f;

    //1. P = P1 + u (P2 - P1) line equation

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美精品一卡二卡| 蜜桃视频一区二区| 成人av电影免费观看| 国产丝袜欧美中文另类| 成人av午夜电影| 一区二区中文视频| 欧美性生活影院| 日本不卡视频一二三区| 亚洲精品一线二线三线无人区| 国产中文字幕一区| 久久青草国产手机看片福利盒子| 国产精品一区二区男女羞羞无遮挡 | 国产日产亚洲精品系列| 国产成人免费9x9x人网站视频| 国产日韩三级在线| 国产成人综合在线播放| 亚洲欧美视频在线观看视频| 欧美亚洲动漫精品| 久久精品国产网站| 国产精品免费观看视频| 欧美视频一区二区三区| 裸体一区二区三区| 国产精品日韩成人| 欧美精品一二三| 国产伦精品一区二区三区免费| 中文字幕亚洲视频| 9191成人精品久久| 北条麻妃国产九九精品视频| 亚洲韩国精品一区| 久久久亚洲精华液精华液精华液| 粉嫩一区二区三区性色av| 日韩伦理电影网| 日韩视频免费观看高清在线视频| 精品亚洲国内自在自线福利| 国产精品三级电影| 日韩一级大片在线观看| 成人动漫中文字幕| 免费看欧美女人艹b| 亚洲三级视频在线观看| 日韩精品一区二区三区老鸭窝 | 粉嫩绯色av一区二区在线观看| 最新热久久免费视频| 日韩欧美在线一区二区三区| 粉嫩嫩av羞羞动漫久久久| 午夜精品福利一区二区蜜股av| 国产午夜亚洲精品不卡| 日韩三级视频在线观看| 欧美三级在线播放| 成人视屏免费看| 蜜臀精品久久久久久蜜臀| 国产精品国产三级国产aⅴ入口| 欧美精品久久一区二区三区| 不卡av免费在线观看| 日韩高清不卡在线| 亚洲乱码国产乱码精品精98午夜| 精品久久久影院| 欧美日韩一区二区在线视频| 成人教育av在线| 免费一级欧美片在线观看| 一区二区三区国产精华| 欧美国产一区二区在线观看| 欧美成人午夜电影| 91精品中文字幕一区二区三区| 色综合久久久久网| 国产91精品欧美| 人人超碰91尤物精品国产| 一区二区三区在线免费观看| 中文字幕高清不卡| 国产日韩精品一区二区三区在线| 精品人伦一区二区色婷婷| 欧美顶级少妇做爰| 4438成人网| 69精品人人人人| 在线91免费看| 欧美久久久久中文字幕| 欧美日韩免费一区二区三区视频| 91视频xxxx| 色香色香欲天天天影视综合网| 99精品国产99久久久久久白柏| 成人久久视频在线观看| 成人一区在线看| 成人午夜av电影| 成人h精品动漫一区二区三区| 国产69精品久久99不卡| 成人免费视频caoporn| 国产高清在线观看免费不卡| 国产精品一区免费视频| 国产高清亚洲一区| av在线不卡网| 91传媒视频在线播放| 欧美日韩电影在线播放| 91精品免费观看| 精品va天堂亚洲国产| 久久久精品欧美丰满| 亚洲国产精品精华液2区45| 欧美激情在线一区二区| 国产精品福利一区| 一区二区三区四区激情| 亚洲成人免费电影| 理论电影国产精品| 国产另类ts人妖一区二区| 99国内精品久久| 欧美日韩国产综合草草| 欧美成人精品福利| 国产精品久久久久婷婷二区次| 一区视频在线播放| 日韩国产精品久久久| 久久99精品久久久久久久久久久久| 国产剧情av麻豆香蕉精品| 成人免费观看av| 欧美三区在线视频| 久久综合九色综合欧美亚洲| 国产精品女同互慰在线看| 一级特黄大欧美久久久| 麻豆精品一区二区综合av| 国产a区久久久| 欧美三区在线观看| 2023国产精品| 亚洲乱码中文字幕| 久久av资源站| 色噜噜夜夜夜综合网| 日韩美女一区二区三区四区| 国产精品视频在线看| 手机精品视频在线观看| 粉嫩欧美一区二区三区高清影视| 在线看一区二区| 久久久久久久久久久电影| 亚洲激情五月婷婷| 国产一区二区三区在线观看免费 | 成人av动漫在线| 91精品国产高清一区二区三区蜜臀| 久久精品网站免费观看| 亚洲成av人片| 不卡欧美aaaaa| 精品人在线二区三区| 亚洲另类春色国产| 国产成人免费高清| 欧美一级高清大全免费观看| 亚洲靠逼com| 国产成人亚洲综合色影视| 色妞www精品视频| 国产精品三级视频| 国产一区在线观看视频| 欧美高清一级片在线| 1区2区3区国产精品| 国产成人一区二区精品非洲| 911精品国产一区二区在线| 亚洲三级电影网站| 国产黑丝在线一区二区三区| 欧美电影免费观看高清完整版在线 | 国产成人免费视频网站 | 奇米888四色在线精品| 色婷婷久久99综合精品jk白丝| 久久精品视频一区| 卡一卡二国产精品| 欧美日韩一区二区三区免费看| 中文字幕一区免费在线观看| 国产一区91精品张津瑜| 欧美一区二区女人| 免费在线欧美视频| 在线成人av网站| 五月综合激情网| 欧美色综合影院| 亚洲一区二区三区爽爽爽爽爽 | 91久久国产综合久久| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 欧美亚一区二区| 一区二区三区四区不卡视频| av高清不卡在线| 国产精品久久久久三级| 成人国产亚洲欧美成人综合网| 国产日韩视频一区二区三区| 国产成人综合在线| 国产精品久久久久久久午夜片| 岛国精品一区二区| 国产精品对白交换视频| 91丨九色丨黑人外教| 亚洲日本乱码在线观看| 在线免费不卡电影| 樱桃视频在线观看一区| 欧洲亚洲精品在线| 亚洲午夜三级在线| 日韩欧美一区二区视频| 麻豆91免费观看| 国产欧美日韩在线视频| 99这里只有久久精品视频| 亚洲国产成人在线| 91影视在线播放| 亚洲成人av中文| 欧美一区二区三区在线电影| 久久成人久久爱| 国产日本欧洲亚洲| 一本大道av伊人久久综合| 洋洋成人永久网站入口| 欧美一区二区三区免费在线看| 九一久久久久久| 国产精品你懂的| 欧美日韩不卡在线| 国产一区中文字幕| 一区二区三区在线视频免费|