您好,登錄后才能下訂單哦!
本篇內(nèi)容介紹了“Linux下C語(yǔ)言如何實(shí)現(xiàn)貪吃蛇小游戲”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
此次貪吃蛇小游戲的目的是使得我在Linux底下使用vi進(jìn)行編寫的
心得:
1.自己對(duì)linux中如何使用vi更加熟悉
如::wq yy pp dd u 等等
2.對(duì)c語(yǔ)言的指針,結(jié)構(gòu)體,鏈表等更加的牢固
3.借此小項(xiàng)目也運(yùn)用到多線程作為進(jìn)入linux的深入學(xué)習(xí)打下堅(jiān)實(shí)的基礎(chǔ)
代碼展示
#include<curses.h> #include<stdlib.h> #define UP 1 //1與-1的目的是使用abs()函數(shù)防止一上一下 #define DOWN -1 #define LEFT 2 #define RIGHT -2 struct Snake{ //創(chuàng)建一個(gè)結(jié)構(gòu)體 int hang; int lie; struct Snake *next; }; struct Snake *head = NULL; //全局定義一個(gè)頭和尾 struct Snake *tail= NULL; int key; //定義一個(gè)按鍵的整形變量 int dir;//定義一個(gè)方向的整形變量 struct Snake food; void initFood(){ //定義一個(gè)食物## 可以隨機(jī)生成 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é)點(diǎn) struct Snake *p; p = head; head = head->next; free(p); } int ifSnakeDie(){ //在撞到邊界以及自己遲到自己的時(shí)候會(huì)輸出一個(gè)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(){ //蛇的移動(dòng) addNode(); if(hasFood(tail->hang,tail->lie)){ //如果吃到食物就不刪除最后的節(jié)點(diǎn) 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);//啟動(dòng)線程里面的函數(shù) pthread_create(&t2,NULL,changeDir,NULL); while(1);//線程3 getch(); endwin(); return 0; }
對(duì)代碼進(jìn)行編譯
gcc snake.c -lcurses -lpthread
生成a.out運(yùn)行文件
運(yùn)行代碼
./a.out
圖片展示
“Linux下C語(yǔ)言如何實(shí)現(xiàn)貪吃蛇小游戲”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。