Linux下C语言实现贪吃蛇小游戏

 更新时间:2021年03月14日 10:03:32   作者:RICKO-_-  
这篇文章主要为大家详细介绍了Linux下C语言实现贪吃蛇小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C语言实现贪吃蛇小游戏的具体代码,供大家参考,具体内容如下

此次贪吃蛇小游戏的目的是使得我在Linux底下使用vi进行编写的

心得:

1.自己对linux中如何使用vi更加熟悉

如::wq yy pp dd u 等等

2.对c语言的指针,结构体,链表等更加的牢固

3.借此小项目也运用到多线程作为进入linux的深入学习打下坚实的基础

代码展示

#include<curses.h>
#include<stdlib.h>
#define UP 1 //1与-1的目的是使用abs()函数防止一上一下
#define DOWN -1
#define LEFT 2
#define RIGHT -2
struct Snake{ //创建一个结构体
 int hang;
 int lie;
 struct Snake *next;
};
struct Snake *head = NULL; //全局定义一个头和尾
struct Snake *tail= NULL;
int key; //定义一个按键的整形变量
int dir;//定义一个方向的整形变量
struct Snake food;
void initFood(){ //定义一个食物## 可以随机生成
 int x = rand()%19;
 int y = rand()%19;
 food.hang = x;
 food.lie = y;
}
void initNcurse(){
 initscr();
 keypad(stdscr,1);
 noecho();
}
int hasSnakeNode(int i, int j){ //显示蛇身体
 struct Snake *p;
 p = head;
 while(p != NULL){
 if(p->hang == i && p ->lie == j){
 return 1;
 }
 p = p->next;
 }
 return 0;
}
int hasFood(int i,int j){ //有食物
 if(food.hang == i && food.lie == j){
 return 1;
 }
 return 0;
}
void gamePic(){ //游戏图形化展示
 int hang;
 int lie;
 move(0,0);
 for(hang=0;hang<20;hang++){
 if(hang == 0){
 for(lie=0;lie<20;lie++){
 printw("--");
 }
 printw("\n"); 
 }
 if(hang >=0 && hang<=19 ){
 for(lie=0;lie<=20;lie++){
 if(lie == 0 || lie == 20){
  printw("|");
 }else if(hasSnakeNode(hang,lie)){
  printw("[]");
 }else if(hasFood(hang,lie)){
  printw("##");
 }
 else{
  printw(" ");
 }
 }
 printw("\n");
 }
 if(hang == 19){
 for(lie=0;lie<20;lie++){
 printw("--");
 }
 printw("\n"); 
 printw("by ricko");
 }
 }
}
void addNode(){ //加头并且方向
 struct Snake *new = (struct Snake *)malloc(sizeof(struct Snake));
 new->next = NULL;
 switch(dir){
 case UP:
 new->hang = tail->hang-1;
 new->lie = tail->lie;
 break;
 case DOWN:
 new->hang = tail->hang+1;
 new->lie = tail->lie;
 break;
 case LEFT:
 new->hang = tail->hang;
 new->lie = tail->lie-1;
 break;
 case RIGHT:
 new->hang = tail->hang;
 new->lie = tail->lie+1;
 break;
 }
 tail->next = new;
 tail = new;
}
void initSnake(){ //初始化蛇
 struct Snake *p;
 dir = RIGHT;
 while(head != NULL){
 p = head;
 head = head->next;
 free(p);
 }
 initFood(); 
 head = (struct Snake *)malloc(sizeof(struct Snake));
 head->hang = 1;
 head->lie = 1;
 head->next = NULL;
 tail = head;
 addNode();
 addNode();
 addNode();
 addNode();
}
void deleNode(){ //删除最后节点
 struct Snake *p;
 p = head;
 head = head->next;
 free(p);
}
int ifSnakeDie(){ //在撞到边界以及自己迟到自己的时候会输出一个1让自己复活
 struct Snake *p;
 p = head;
 if(tail->hang < 0 || tail->lie == 0 || tail->hang == 20 || tail->lie == 20){
 return 1;
 }
 while(p->next != NULL){
 if(p->hang == tail->hang && p->lie == tail->lie){
 return 1;
 }
 p = p->next;
 }
 return 0;
}
void moveSnake(){ //蛇的移动
 addNode();
 if(hasFood(tail->hang,tail->lie)){ //如果吃到食物就不删除最后的节点
 initFood();
 }else{
 deleNode();
 }
 if(ifSnakeDie()){
 initSnake(); 
 }
}
void refreshJieMian(){ //刷新界面 线程
 while(1){
 moveSnake();
 gamePic();
 refresh();
 usleep(150000); //刷新频率
 }
}
void turn(int direction){ //防止方向键按了上又按下
 if(abs(dir) != abs(direction)){
 dir = direction;
 }
}
void changeDir(){ //改变方向
 while(1){
 key = getch();
 switch(key){
 case KEY_DOWN:
 turn(DOWN);
 break;
 case KEY_UP:
 turn(UP);
 break;
 case KEY_LEFT:
 turn(LEFT);
 break;
 case KEY_RIGHT:
 turn(RIGHT);
 break;
 }
 }
}
int main(){
 pthread_t t1; //定义线程1
 pthread_t t2; 
 initNcurse(); //初始化ncurse
 initSnake(); //初始化蛇
 gamePic();  //初始化界面
 pthread_create(&t1,NULL,refreshJieMian,NULL);//启动线程里面的函数
 pthread_create(&t2,NULL,changeDir,NULL);
 while(1);//线程3
 getch();
 endwin();
 return 0;
}

对代码进行编译

gcc snake.c -lcurses -lpthread

生成a.out运行文件

运行代码

./a.out

图片展示

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C语言数据输入与输出实例详解

    C语言数据输入与输出实例详解

    这篇文章主要介绍了C语言数据输入与输出实例详解的相关资料,需要的朋友可以参考下
    2017-06-06
  • C++面试题之结构体内存对齐计算问题总结大全

    C++面试题之结构体内存对齐计算问题总结大全

    这篇文章主要给大家总结了关于C++面试题中结构体内存对齐计算问题的相关资料,文中通过示例代码介绍的非常详细,通过这些介绍的内容对大家在面试C++工作的时候,会有一定的参考帮助,需要的朋友们下面随着小编来一起学习学习吧。
    2017-08-08
  • C语言之陷阱与缺陷详解

    C语言之陷阱与缺陷详解

    本片文章是对C++中陷阱与缺陷进行了详细的分析介绍,小编觉得本片文章讲解的非常详细,需要的朋友参考下,希望能够给你带来帮助
    2021-09-09
  • C++ LeetCode1796字符串中第二大数字

    C++ LeetCode1796字符串中第二大数字

    这篇文章主要为大家介绍了C++ LeetCode1796字符串中第二大数字示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • C 语言基础之初识 C 语言常量

    C 语言基础之初识 C 语言常量

    C语言中的常量分为以下几种:字面常量、const修饰的常变量、#define定义的标识符常量等,下面我们将详细对C语言这几个常量做介绍,感兴趣的小伙伴可以参考一下
    2021-09-09
  • C++实现顺序排序算法简单示例代码

    C++实现顺序排序算法简单示例代码

    这篇文章主要介绍了C++实现顺序排序算法简单示例代码,对于学过C++的朋友一定不会陌生,现在重温一下这个算法,需要的朋友可以参考下
    2014-08-08
  • C语言中逻辑运算符与条件运算符的学习教程

    C语言中逻辑运算符与条件运算符的学习教程

    这篇文章主要介绍了C语言中逻辑运算符与条件运算符的学习教程,条件运算符问号即三目运算符使用起来十分方便,需要的朋友可以参考下
    2016-04-04
  • C++指向函数的指针实例解析

    C++指向函数的指针实例解析

    这篇文章主要介绍了C++指向函数的指针,需要的朋友可以参考下
    2014-07-07
  • Dijkstra最短路径算法实现代码

    Dijkstra最短路径算法实现代码

    这篇文章主要介绍了Dijkstra最短路径算法实现代码,有需要的朋友可以参考一下
    2013-12-12
  • C++ 异常处理noexcept正确使用示例详解

    C++ 异常处理noexcept正确使用示例详解

    这篇文章主要为大家介绍了C++ 异常处理noexcept正确使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04

最新评论