刚学OpenGL的时候,写的一个最简单的贪吃蛇游戏代码 如下:

//贪吃蛇游戏
#include<stdio.h>
#include<stdlib.h>
#include<gl/GLUT.H>
#include<time.h>
#define UP 10 //上
#define DOWN -10//下
#define LEFT -1//左
#define RIGHT 1//右
#define NODE_WIDTH 10;//蛇身节点正方形的宽度
#define STEP_SIZE 10;//运动步长
#define PANEL_WIDTH 500;//面板长度
#define PANEL_HEIGHT 400;//面板宽度
int dir = RIGHT;//运动方向,初始化为右
struct node//节点结构
{
int x;//x坐标
int y;//y坐标
struct node *prev;//前一个节点
struct node *next;//后一个节点
};
struct snake//蛇结构
{
struct node *head;//头部
struct node *tail;//尾部
int node_count;//节点个数
};
struct snake *sn;//蛇
struct node *food;//食物
void snake_init()//蛇的初始化
{
sn = (struct snake *)malloc(sizeof(struct snake));
food = (struct node *)malloc(sizeof(struct node));
food->x = ;
food->y = ;
node *head = (struct node *)malloc(sizeof(struct node));
node *tail = (struct node *)malloc(sizeof(struct node));
head->x = ;
head->y = ;
tail->x = ;
tail->y = ;
head->next = tail;
tail->prev = head;
sn->head = head;
sn->tail = tail;
sn->node_count = ;
}
//添加一个节点到头部
void add_head(node *n)
{
n->next = sn->head;
sn->head->prev = n;
sn->head = n;
}
//删除尾部
void remove_tail()
{
node *old_tail = sn->tail;
sn->tail = sn->tail->prev;//重新指定尾节点
free(old_tail);//释放删除的尾节点
}
bool snake_contain(int x, int y)
{
node *node = sn->head;
for (int i = ; i < sn->node_count; i++)
{
if ((abs(node->x - x)<=&&abs(node->y - y)<=))//食物与蛇身的距离不能同时小于6才不会碰到,反正同时小于6就会包含
{
return true;
}
node = node->next;
}
return false;
}
//新食物
void new_food()
{
int width = PANEL_WIDTH;
int height = PANEL_HEIGHT;
int node_width = NODE_WIDTH;
int x = rand()%width;
int y = rand()%height;
//要满足的条件
// x < PANEL_WIDTH - NODE_WIDTH; PANEL_HEIGHT-NODE_WIDTH< y
// abs(x- sn->head)&&abs(x->)
while (snake_contain(x, y) && x < (height - node_width) && y>(height - node_width))
{
x = rand()%PANEL_WIDTH;
y = rand()%PANEL_HEIGHT;
}
food->x = x;
food->y = y;
} bool is_eat(node * n)
{
return abs(n->x - food->x)< &&abs(n->y - food->y)< ;
}
//前进
void step(int go_dir)
{
if ((dir + go_dir) != )//如果不是朝相反的方向
{
dir = go_dir;
//求蛇运动下一步的坐标点,这里运用了数字技巧
int x = sn->head->x + (dir%)*STEP_SIZE;
int y = sn->head->y + (dir/)*STEP_SIZE;
struct node *n = (struct node *)malloc(sizeof(struct node));
n->x = x;
n->y = y;
if (is_eat(n))
{
add_head(n);
new_food();
sn->node_count++;
}
else
{
add_head(n);
remove_tail();
} } }
//重绘
void repaint(int a)
{
//画蛇身
node *node = sn->head;
for (int i = ; i < sn->node_count; i++)
{
int x = node->x;
int y = node->y;
int lx = x-NODE_WIDTH;
int ly = y;
int rx = x;
int ry = y-NODE_WIDTH;
//glColor3f(1.0f, 0.0f, 0.0f);
glRectf(lx,ly,rx,ry);
node = node->next;
}
//画食物
int lx = food->x - NODE_WIDTH;
int ly = food->y;
int rx = food->x;
int ry = food->y - NODE_WIDTH;
glRectf(lx,ly,rx,ry);
}
void time_func(int a)
{
step(dir);
glutPostRedisplay();//重绘
glutTimerFunc(,time_func,);
} void Initial(void)
{
glClearColor(1.0f, 1.0f, 1.0f, 1.0f); //设置窗口背景色为白色
glMatrixMode(GL_PROJECTION);
gluOrtho2D(0.0,500.0,0.0,400.0);
} void Display(void)
{
glClear(GL_COLOR_BUFFER_BIT);//用当前背景色填充窗口
glColor3f(1.0f, 0.0f, 0.0f);//设置当前的绘图颜色为红色
//glRectf(50.0f, 100.0f, 60.0f, 90.0f);//绘制一个矩形
/*glBegin(GL_TRIANGLES);
glColor3f(1, 1, 0);
glVertex2f(250, 400);
glColor3f(0, 1, 1);
glVertex2f(50, 300);
glColor3f(1, 0, 1);
glVertex2f(450, 300);
glEnd();
*/
repaint(dir);
glFlush();
} void key_turn(unsigned char key, int x, int y)
{
switch (key)
{
case 'w':
step(UP);
break;
case 's':
step(DOWN);
break;
case 'a':
step(LEFT);
break;
case 'd':
step(RIGHT);
break;
}
}
int main(int argc, char* argv[])
{
glutInit(&argc, argv);
snake_init();
glutInitDisplayMode(GLUT_SINGLE|GLUT_RGB);//初始化窗口的显示模式
glutInitWindowSize(, );//设置窗口的尺寸
glutInitWindowPosition(, ); //设置窗口的位置
glutCreateWindow("矩形"); //创建一个名为矩形的窗口
glutDisplayFunc(Display);
Initial();
glutKeyboardFunc(key_turn);
glutTimerFunc(,time_func,);//计数器
glutMainLoop();
return ;
}

用OpenGL简单编写的一个最简单贪吃蛇游戏的更多相关文章

  1. 一个原生JS实现的不太成熟的贪吃蛇游戏

    一个初初初初级前端民工 主要是记录一下写过的东西,复习用 大佬们如果看到代码哪里不符合规范,或者有更好写法的,欢迎各位批评指正 十分感谢 实现一个贪吃蛇游戏需要几步? 1.有地图 2.有蛇 3.有食物 ...

  2. 使用TypeScript实现简单的HTML5贪吃蛇游戏

    TypeScript是一种由微软开发的自由和开源的编程语言.它是JavaScript的一个超集,而且本质上向这个语言添加了可选的静态类型和基于类的面向对象编程.安德斯·海尔斯伯格,C#的首席架构师,已 ...

  3. js编写简单的贪吃蛇游戏

    css代码 *{ margin:; padding:; } td{ width: 4px; height: 4px; background: #ccc; border: 2px solid #ccc; ...

  4. Android快乐贪吃蛇游戏实战项目开发教程-03虚拟方向键(二)绘制一个三角形

    该系列教程概述与目录:http://www.cnblogs.com/chengyujia/p/5787111.html 一.绘制三角形 在上一篇文章中,我们已经新建了虚拟方向键的自定义控件Direct ...

  5. python 写一个贪吃蛇游戏

    #!usr/bin/python #-*- coding:utf-8 -*- import random import curses s = curses.initscr() curses.curs_ ...

  6. 第一个windows 小游戏 贪吃蛇

    最近用dx尝试做了一个小的贪吃蛇游戏,代码放到github上面:https://github.com/nightwolf-chen/MyFreakout 说一下自己实现的过程: 首先,我把蛇这个抽象成 ...

  7. Python实例:贪吃蛇(简单贪吃蛇编写)🐍

    d=====( ̄▽ ̄*)b 叮~ Python -- 简易贪吃蛇实现 目录: 1.基本原理 2.需要学习的库 3.代码实现 1.基本原理 基本贪吃蛇所需要的东西其实很少,只需要有一块让蛇动的屏幕, 在 ...

  8. 如何用Python写一个贪吃蛇AI

    前言 这两天在网上看到一张让人涨姿势的图片,图片中展示的是贪吃蛇游戏, 估计大部分人都玩过.但如果仅仅是贪吃蛇游戏,那么它就没有什么让人涨姿势的地方了. 问题的关键在于,图片中的贪吃蛇真的很贪吃XD, ...

  9. 贪吃蛇小游戏—C++、Opencv编写实现

    贪吃蛇游戏,C++.Opencv实现 设计思路: 1.显示初始画面,蛇头box初始位置为中心,食物box位置随机 2.按随机方向移动蛇头,按a.s.d.w键控制移动方向,分别为向左,向下,向右,向上 ...

随机推荐

  1. qconf 介绍

    转载自:http://www.tuicool.com/articles/BJfiMbr 360 如何用 QConf 搞定 2W+ 服务器的配置管理 时间 2015-06-29 09:27:47 佚名 ...

  2. C++基础复习

    1.Object-C也是面向对象的语言:2.#include<iostream> //#include是一个预处理指令3.using namespace std; //std是命名空间,u ...

  3. redis 实时从mysql 更新数据

    现在的互联网普遍都用redis+mysql ,查询一般放在 redis  上,更改 放在 redis  上, 如果更新 mysql数据到  redis 上呢? mysql 有四中类型的日志 Error ...

  4. Codeforces 112B-Petya and Square(实现)

    B. Petya and Square time limit per test 2 seconds memory limit per test 256 megabytes input standard ...

  5. DBMS_RLS包实现数据库表中的行级安全控制

    DBMS_RLS 实现一个数据库表为行级安全控制,该套餐包括细粒度的访问控制管理界面,此接口是用来实现VPD(Virtual Private Database),虚拟专用数据库.DBMS_RLS仅仅能 ...

  6. Java程序员也应该知道的系统知识系列之(网卡,cpu,内存,硬盘,虚拟化)

    https://yq.aliyun.com/articles/1718?spm=5176.100240.searchblog.16.UaGd04 https://yq.aliyun.com/artic ...

  7. js的new操作符

    1.创建一个空对象,并且 this 变量引用该对象,同时还继承了该函数的原型. 2.属性和方法被加入到 this 引用的对象中. 3.新创建的对象由 this 所引用,并且最后隐式的返回 this . ...

  8. MySQL中TIMESTAMP和DATETIME区别

    1.两者的存储方式不一样 TIMESTAMP:把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储.查询时,将其又转化为客户端当前时区进行返回. DATETIME:不做任何改变,基本上是原 ...

  9. MVC +EF+linq 多表联查

    关于linq的多表联查效果的实现: 后台多表查询  内连接: SELECT [Extent2].[partID] AS [partID], [Extent1].[userName] AS [userN ...

  10. 合理计划 dictionary cache 大小

    [数据字典缓冲区(Data Dictionary Cache)  ] 用于存放Oracle系统管理自身所需要的所有信息,包括登录的用户名.用户对象.权限等. 查看 data dictionary ca ...