c語言實現(xiàn)可自定義的游戲地圖
本文實例為大家分享了c語言實現(xiàn)可自定義的游戲地圖的具體代碼,供大家參考,具體內容如下
博主相信每個人都有想做游戲的沖動,那么本文將給出一個用c語言制作的可自定義大小的游戲地圖(包含player,撞墻設置)。廢話不多說,直接給出全代碼!
1.完整代碼
#include<stdio.h>
#include<windows.h>
#include<conio.h>?
?
//this is the add function?
int drawroom(int length,int height,int x,int y);
int transform(int tran);
?
//begin the function
int main()
{ ? ??
? ??
? ? ?int p=10;
?? ? int q=10;
? ? ?printf("control player to move:up“8” down“2” left“4” right“6”\n");//control the player
? ? ?
? ? ?int y,x;
? ? ?int ret=1;
? ? ?int a,b;
? ? ?printf("請輸入地圖的大小,例如:10 10:\n");
? ? ?scanf("%d %d",&p,&q);
? ? ?printf("請輸入玩家的位置:“例如:3 5”\n"); //get the first player place
?? ? scanf("%d %d",&y,&x);
? ? drawroom(p,q,y,x);
? ? printf("\n");
? ?
? ? while(ret!=0){
?? ? ? ?printf("\n");
? ? ?? ?int i;
? ? ?? ?i=0;
? ? ?? ?int tran;
? ? ?? ?tran=getch();
? ? ?? ?i=transform(tran);
? ? ?? ?
? ? ?? ?if(i==8){
? ? ?? ??? ?drawroom(p,q,y-1,x);
? ? ?? ??? ?y=y-1;
?? ??? ?}
?? ??? ? else if(i==2){
?? ??? ??? ?drawroom(p,q,y+1,x);
?? ??? ??? ?y=y+1;
?? ??? ?}
?? ??? ? ?else if(i==4){
?? ??? ??? ?drawroom(p,q,y,x-1);
?? ??? ??? ?x=x-1;
?? ??? ?}
?? ??? ?else if(i==6){
?? ??? ??? ?drawroom(p,q,y,x+1);
?? ??? ??? ?x=x+1;
?? ??? ?}
?? ??? ?if(y==0 || x==0){
?? ??? ??? ?ret=0;
?? ??? ??? ?printf("\n\nyou touch the board!game over??!");
?? ??? ??? ?break;?
?? ??? ?}
?? ??? ?if(y==p+1 || x==q+1){
?? ??? ??? ?ret=0;
?? ??? ??? ?printf("\n\nyou touch the board!game over?。?);
?? ??? ??? ?break;
?? ??? ?}
?? ??? ?
}
? ??
? ??
?? ?getchar();
?? ?system("pause");
?? ?return 0;
}
?
int drawroom(int length,int height,int y,int x)
{ ? int ret=1;
?? ?int size1=height+2;
?? ?int size2=length+2;
?? ?int a[size1][size2];
?? ?int i,j;
?? ?int count=1;
?? ?
?? ??? ?for(i=0;i<size1;i++){
?? ??? ?for(j=0;j<size2;j++){
?? ??? ??? ?a[i][j]=0;
?? ??? ?}
}
?? ?a[0][0]=1;
?? ?a[0][size2-1]=1;
?? ?a[size1-1][0]=1;
?? ?a[size1-1][size2-1]=1;
?? ?for(j=1;j<size2-1;j++){
?? ??? ?a[0][j]=2;
?? ?}?? ?
?? ?for(j=1;j<size2-1;j++){
?? ??? ?a[size1-1][j]=2;
?? ?}
?? ?for(i=1;i<size1-1;i++){
?? ??? ?a[i][0]=3;
?? ?}
?? ?for(i=1;i<size1-1;i++){
?? ??? ?a[i][size2-1]=3;
?? ?}
?? ?a[y][x]=4;
?? ??? ?for(i=0;i<size1;i++){
?? ??? ??? ?printf("\n");
?? ??? ?for(j=0;j<size2;j++){
?? ??? ??? ?if(a[i][j]==1){
?? ??? ??? ??? ?printf("+ ");
?? ??? ??? ?}else if(a[i][j]==2){
?? ??? ??? ??? ?printf("- ");
?? ??? ??? ?}else if(a[i][j]==3){
?? ??? ??? ??? ?
?? ??? ??? ?printf("| ");
?? ??? ??? ?}else if(a[i][j]==4){
?? ??? ??? ??? ?printf("@ ");
?? ??? ??? ?}else{
?? ??? ??? ??? ?printf(". ");
?? ??? ? ? ? ?}
?? ??? ??? ?}?? ?
?? ??? ? ?}?? ?
?? ??? ? ?printf("\n\n\n\n\n\n\n\n\n\n");
?? ??? ? ?return 0;
?? ??? ?}
?
int transform(int tran)
{
?? ?int tot;
?? ?if(tran==52)tot=4;
?? ?if(tran==54)tot=6;
?? ?if(tran==50)tot=2;
?? ?if(tran==56)tot=8;
?? ?return tot;
}注:游戲說明:先自定義游戲地圖的大小,然后自定義玩家生成在游戲棋盤中的哪個位置,最后通過數(shù)字鍵盤控制玩家的移動:下:2 上:8 左:4 右:6
2.運行成果


大家可以自己在游戲地圖的基礎上設置不同的玩家,甚至可以進行雙人對戰(zhàn)!
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
C語言數(shù)據(jù)結構二叉樹之堆的實現(xiàn)和堆排序詳解
堆是計算機科學中一類特殊的數(shù)據(jù)結構的統(tǒng)稱,通常是一個可以被看做一棵完全二叉樹的數(shù)組對象。而堆排序是利用堆這種數(shù)據(jù)結構所設計的一種排序算法。本文將詳細介紹堆的實現(xiàn)和堆排序,需要的可以參考一下2022-04-04
Matlab實現(xiàn)數(shù)據(jù)的動態(tài)顯示方法
這篇文章主要為大家詳細介紹了Matlab使用Plot函數(shù)實現(xiàn)數(shù)據(jù)動態(tài)顯示方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-06-06

