国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

Linux下C語言實現(xiàn)貪吃蛇小游戲

瀏覽:146日期:2024-04-09 13:42:27

本文實例為大家分享了C語言實現(xiàn)貪吃蛇小游戲的具體代碼,供大家參考,具體內(nèi)容如下

此次貪吃蛇小游戲的目的是使得我在Linux底下使用vi進(jìn)行編寫的

心得:

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

如::wq yy pp dd u 等等

2.對c語言的指針,結(jié)構(gòu)體,鏈表等更加的牢固

3.借此小項目也運用到多線程作為進(jìn)入linux的深入學(xué)習(xí)打下堅實的基礎(chǔ)

代碼展示

#include<curses.h>#include<stdlib.h>#define UP 1 //1與-1的目的是使用abs()函數(shù)防止一上一下#define DOWN -1#define LEFT 2#define RIGHT -2struct Snake{ //創(chuàng)建一個結(jié)構(gòu)體 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(){ //刪除最后節(jié)點 struct Snake *p; p = head; head = head->next; free(p);}int ifSnakeDie(){ //在撞到邊界以及自己遲到自己的時候會輸出一個1讓自己復(fù)活 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)){ //如果吃到食物就不刪除最后的節(jié)點 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);//啟動線程里面的函數(shù) pthread_create(&t2,NULL,changeDir,NULL); while(1);//線程3 getch(); endwin(); return 0;}

對代碼進(jìn)行編譯

gcc snake.c -lcurses -lpthread

生成a.out運行文件

運行代碼

./a.out

圖片展示

Linux下C語言實現(xiàn)貪吃蛇小游戲

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Linux系統(tǒng)
相關(guān)文章:
主站蜘蛛池模板: 靖远县| 抚州市| 贵溪市| 寿光市| 镶黄旗| 崇阳县| 临清市| 哈尔滨市| 阿拉善盟| 台北市| 道真| 广德县| 土默特左旗| 容城县| 宁陕县| 潮安县| 攀枝花市| 普洱| 临邑县| 江西省| 江华| 盐津县| 隆回县| 蒲江县| 阳城县| 慈溪市| 盐边县| 威宁| 和林格尔县| 元朗区| 弋阳县| 潼南县| 汕头市| 临西县| 南汇区| 奈曼旗| 手游| 平遥县| 炎陵县| 都匀市| 定边县|