文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Linux下怎么用C语言实现贪吃蛇游戏

2024-04-02 19:55

关注

这篇文章主要介绍“Linux下怎么用C语言实现贪吃蛇游戏”,在日常操作中,相信很多人在Linux下怎么用C语言实现贪吃蛇游戏问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Linux下怎么用C语言实现贪吃蛇游戏”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

代码展示

#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

图片展示

Linux下怎么用C语言实现贪吃蛇游戏

到此,关于“Linux下怎么用C语言实现贪吃蛇游戏”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯