用OpenGL简单编写的一个最简单贪吃蛇游戏
刚学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简单编写的一个最简单贪吃蛇游戏的更多相关文章
- 一个原生JS实现的不太成熟的贪吃蛇游戏
一个初初初初级前端民工 主要是记录一下写过的东西,复习用 大佬们如果看到代码哪里不符合规范,或者有更好写法的,欢迎各位批评指正 十分感谢 实现一个贪吃蛇游戏需要几步? 1.有地图 2.有蛇 3.有食物 ...
- 使用TypeScript实现简单的HTML5贪吃蛇游戏
TypeScript是一种由微软开发的自由和开源的编程语言.它是JavaScript的一个超集,而且本质上向这个语言添加了可选的静态类型和基于类的面向对象编程.安德斯·海尔斯伯格,C#的首席架构师,已 ...
- js编写简单的贪吃蛇游戏
css代码 *{ margin:; padding:; } td{ width: 4px; height: 4px; background: #ccc; border: 2px solid #ccc; ...
- Android快乐贪吃蛇游戏实战项目开发教程-03虚拟方向键(二)绘制一个三角形
该系列教程概述与目录:http://www.cnblogs.com/chengyujia/p/5787111.html 一.绘制三角形 在上一篇文章中,我们已经新建了虚拟方向键的自定义控件Direct ...
- python 写一个贪吃蛇游戏
#!usr/bin/python #-*- coding:utf-8 -*- import random import curses s = curses.initscr() curses.curs_ ...
- 第一个windows 小游戏 贪吃蛇
最近用dx尝试做了一个小的贪吃蛇游戏,代码放到github上面:https://github.com/nightwolf-chen/MyFreakout 说一下自己实现的过程: 首先,我把蛇这个抽象成 ...
- Python实例:贪吃蛇(简单贪吃蛇编写)🐍
d=====( ̄▽ ̄*)b 叮~ Python -- 简易贪吃蛇实现 目录: 1.基本原理 2.需要学习的库 3.代码实现 1.基本原理 基本贪吃蛇所需要的东西其实很少,只需要有一块让蛇动的屏幕, 在 ...
- 如何用Python写一个贪吃蛇AI
前言 这两天在网上看到一张让人涨姿势的图片,图片中展示的是贪吃蛇游戏, 估计大部分人都玩过.但如果仅仅是贪吃蛇游戏,那么它就没有什么让人涨姿势的地方了. 问题的关键在于,图片中的贪吃蛇真的很贪吃XD, ...
- 贪吃蛇小游戏—C++、Opencv编写实现
贪吃蛇游戏,C++.Opencv实现 设计思路: 1.显示初始画面,蛇头box初始位置为中心,食物box位置随机 2.按随机方向移动蛇头,按a.s.d.w键控制移动方向,分别为向左,向下,向右,向上 ...
随机推荐
- 将对象格式的style转换为字符串格式
var style = { position:'absolute', background:'red', width:'2px', height:'2px', color:'#fff', top:x, ...
- Linux(SLES)挂载NTFS移动硬盘实践
问题描写叙述: 因为通过測试环境导出的dmp过大,但要求尽快导入至生产server,请网络室打通防火墙后发现測试网络为100M而生产网络贵为1000M却无法发挥不论什么作用即使通过networklin ...
- [转] Linux文件系统之hard link&symbol link
这个图很清楚的表示出硬链接和软链接的方式. 1.硬链接: 基本定义:硬链接是有着相同inode号的仅文件名不同的文件(该文件名包含路径信息). 理解:如图,hard link和原始file通过同一个i ...
- UI实时预览最佳实践(转)
UI实时预览最佳实践 概要:Android中实时预览UI和编写UI的各种技巧.本文的例子都可以在结尾处的示例代码中看到并下载.如果喜欢请star,如果觉得有纰漏请提交issue,如果你有更好的点子可以 ...
- iOS报错Expected selector for Objective-C method
这个报错非常恶心:原因竟然是在导入头文件的地方多写了一个"+"号,可能问题在一个文件,报错在另一个文件
- HUD 2089 位数dp
/* 做的不多的位数dp 暴力的话 不知道多少组数据 会T 所以写dp 思路就和数学课本上那种“不超过xxx的x位偶数有几个” 这里可以类似的维护一个前缀和模样的东西(但又不同于前缀和) 状态:f[i ...
- HTML 详细介绍
什么是 HTML? HTML 是用来描述网页的一种语言. HTML 指的是超文本标记语言 (Hyper Text Markup Language) HTML 不是一种编程语言,而是一种标记语言 (ma ...
- ChesFrame框架介绍
一直以来想写一个框架,想达到的目的: 1.对曾经做过项目的总结 2.节约构建系统的成本,不用每次都从零开始做起 3.写框架并在使用中不断的完善框架,这也是个积攒过程. 经历了一个多月的时间,一个基本的 ...
- ASP.NET5配置
ASP.NET5支持各种各样的配置,应用程序配置数据可以来自JSON, XML或者INI格式的文件,也能来自环境变量,你也可以自定义你自己的Configuration Provider. 1. 获取和 ...
- java_annotation_01
一,Annotation简介 J2SE5.0提供了很多新的我,其中一个很重要的我就是对元数据的支持,在J2SE5.0中,这种元数据被称为注释,通过使用注释,程序开发人员可以在不改变原有逻辑的情况下,在 ...